2 \cdot \tan^{-1} \left(\sqrt{\frac{1 - x}{1 + x}}\right)2 \cdot \tan^{-1} \left(\left|\frac{\sqrt{1 - x}}{\sqrt{1 + x}}\right|\right)double f(double x) {
double r5400 = 2.0;
double r5401 = 1.0;
double r5402 = x;
double r5403 = r5401 - r5402;
double r5404 = r5401 + r5402;
double r5405 = r5403 / r5404;
double r5406 = sqrt(r5405);
double r5407 = atan(r5406);
double r5408 = r5400 * r5407;
return r5408;
}
double f(double x) {
double r5409 = 2.0;
double r5410 = 1.0;
double r5411 = x;
double r5412 = r5410 - r5411;
double r5413 = sqrt(r5412);
double r5414 = r5410 + r5411;
double r5415 = sqrt(r5414);
double r5416 = r5413 / r5415;
double r5417 = fabs(r5416);
double r5418 = atan(r5417);
double r5419 = r5409 * r5418;
return r5419;
}



Bits error versus x
Results
Initial program 0.0
rmApplied add-sqr-sqrt0.0
Applied add-sqr-sqrt0.0
Applied times-frac0.0
Applied rem-sqrt-square0.0
Final simplification0.0
herbie shell --seed 2020003 +o rules:numerics
(FPCore (x)
:name "arccos"
:precision binary64
(* 2 (atan (sqrt (/ (- 1 x) (+ 1 x))))))