2 \cdot \tan^{-1} \left(\sqrt{\frac{1 - x}{1 + x}}\right)2 \cdot \tan^{-1} \left(\sqrt{\frac{1 - x}{1 + x}}\right)(FPCore (x) :precision binary64 (* 2.0 (atan (sqrt (/ (- 1.0 x) (+ 1.0 x))))))
(FPCore (x) :precision binary64 (* 2.0 (atan (sqrt (/ (- 1.0 x) (+ 1.0 x))))))
double code(double x) {
return 2.0 * atan(sqrt((1.0 - x) / (1.0 + x)));
}
double code(double x) {
return 2.0 * atan(sqrt((1.0 - x) / (1.0 + x)));
}







Bits error versus x
Results
| Alternative 1 | |
|---|---|
| Error | 0.4 |
| Cost | 7104 |
| Alternative 2 | |
|---|---|
| Error | 0.6 |
| Cost | 6720 |
| Alternative 3 | |
|---|---|
| Error | 1.3 |
| Cost | 6592 |
| Alternative 4 | |
|---|---|
| Error | 51.2 |
| Cost | 64 |


Initial program 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2021065
(FPCore (x)
:name "arccos"
:precision binary64
(* 2.0 (atan (sqrt (/ (- 1.0 x) (+ 1.0 x))))))