2 \cdot \tan^{-1} \left(\sqrt{\frac{1 - x}{1 + x}}\right)2 \cdot \tan^{-1} \left(\sqrt{\log \left(e^{\frac{\sqrt{1 - x}}{\sqrt{1 + x}}}\right) \cdot \frac{\sqrt{1 - x \cdot 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
(*
(log (exp (/ (sqrt (- 1.0 x)) (sqrt (+ 1.0 x)))))
(/ (sqrt (- 1.0 (* x 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(log(exp(sqrt(1.0 - x) / sqrt(1.0 + x))) * (sqrt(1.0 - (x * x)) / (1.0 + x))));
}










Bits error versus x
Results
| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 19904 |
| Alternative 2 | |
|---|---|
| Error | 0.0 |
| Cost | 13376 |
| Alternative 3 | |
|---|---|
| Error | 0.3 |
| Cost | 7360 |
| Alternative 4 | |
|---|---|
| Error | 0.4 |
| Cost | 7104 |
| Alternative 5 | |
|---|---|
| Error | 0.6 |
| Cost | 6720 |
| Alternative 6 | |
|---|---|
| Error | 1.3 |
| Cost | 6592 |
| Alternative 7 | |
|---|---|
| Error | 51.2 |
| Cost | 64 |


Initial program 0.0
rmApplied add-sqr-sqrt_binary640.0
Applied associate-/l*_binary640.0
rmApplied flip--_binary640.0
Applied sqrt-div_binary640.0
Applied associate-/r/_binary640.0
Applied *-un-lft-identity_binary640.0
Applied sqrt-prod_binary640.0
Applied times-frac_binary640.0
Simplified0.0
rmApplied add-log-exp_binary640.0
rmApplied *-commutative_binary640.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2021045
(FPCore (x)
:name "arccos"
:precision binary64
(* 2.0 (atan (sqrt (/ (- 1.0 x) (+ 1.0 x))))))