\tan^{-1} \left(N + 1\right) - \tan^{-1} N\tan^{-1}_* \frac{1}{N + \mathsf{fma}\left(N, N, 1\right)}double f(double N) {
double r2070166 = N;
double r2070167 = 1.0;
double r2070168 = r2070166 + r2070167;
double r2070169 = atan(r2070168);
double r2070170 = atan(r2070166);
double r2070171 = r2070169 - r2070170;
return r2070171;
}
double f(double N) {
double r2070172 = 1.0;
double r2070173 = N;
double r2070174 = fma(r2070173, r2070173, r2070172);
double r2070175 = r2070173 + r2070174;
double r2070176 = atan2(r2070172, r2070175);
return r2070176;
}




Bits error versus N
| Original | 14.9 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 14.9
rmApplied diff-atan13.8
Simplified0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019154 +o rules:numerics
(FPCore (N)
:name "2atan (example 3.5)"
:herbie-target
(atan (/ 1 (+ 1 (* N (+ N 1)))))
(- (atan (+ N 1)) (atan N)))