\log \left(x + \sqrt{x \cdot x - 1}\right)\log 2 + \left(\log x - \left(\frac{0.09375}{{x}^{4}} + \frac{0.25}{x \cdot x}\right)\right)double code(double x) {
return ((double) log(((double) (x + ((double) sqrt(((double) (((double) (x * x)) - 1.0))))))));
}
double code(double x) {
return ((double) (((double) log(2.0)) + ((double) (((double) log(x)) - ((double) (((double) (0.09375 / ((double) pow(x, 4.0)))) + ((double) (0.25 / ((double) (x * x))))))))));
}



Bits error versus x
Results
Initial program 31.4
Taylor expanded around inf 0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020179
(FPCore (x)
:name "Hyperbolic arc-cosine"
:precision binary64
(log (+ x (sqrt (- (* x x) 1.0)))))