\log \left(\frac{1}{x} + \frac{\sqrt{1 - x \cdot x}}{x}\right)\left(-\log \left(\sqrt{x}\right)\right) + \log \left(\frac{1}{\sqrt{x}} + \frac{\sqrt{\mathsf{fma}\left(x, -x, 1\right)}}{\sqrt{x}}\right)double f(double x) {
double r79996 = 1.0;
double r79997 = x;
double r79998 = r79996 / r79997;
double r79999 = r79997 * r79997;
double r80000 = r79996 - r79999;
double r80001 = sqrt(r80000);
double r80002 = r80001 / r79997;
double r80003 = r79998 + r80002;
double r80004 = log(r80003);
return r80004;
}
double f(double x) {
double r80005 = x;
double r80006 = sqrt(r80005);
double r80007 = log(r80006);
double r80008 = -r80007;
double r80009 = 1.0;
double r80010 = r80009 / r80006;
double r80011 = -r80005;
double r80012 = fma(r80005, r80011, r80009);
double r80013 = sqrt(r80012);
double r80014 = r80013 / r80006;
double r80015 = r80010 + r80014;
double r80016 = log(r80015);
double r80017 = r80008 + r80016;
return r80017;
}



Bits error versus x
Initial program 0.1
rmApplied add-sqr-sqrt0.1
Applied *-un-lft-identity0.1
Applied times-frac0.1
Applied add-sqr-sqrt0.1
Applied *-un-lft-identity0.1
Applied times-frac0.1
Applied distribute-lft-out0.1
Applied log-prod0.2
Simplified0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019195 +o rules:numerics
(FPCore (x)
:name "Hyperbolic arc-(co)secant"
(log (+ (/ 1.0 x) (/ (sqrt (- 1.0 (* x x))) x))))