\tan \left(x + \varepsilon\right) - \tan x
\mathsf{fma}\left(\frac{\frac{\sin x}{\cos x}}{1 - \frac{\sin x}{\frac{\cos \varepsilon \cdot \cos x}{\sin \varepsilon}} \cdot \frac{\sin x}{\frac{\cos \varepsilon \cdot \cos x}{\sin \varepsilon}}}, 1 + \frac{\sin x}{\frac{\cos \varepsilon \cdot \cos x}{\sin \varepsilon}}, \frac{-\sin x}{\cos x}\right) + \frac{\frac{\sin \varepsilon}{\cos \varepsilon}}{\mathsf{fma}\left(\frac{-\sin x}{\cos x}, \frac{\sin \varepsilon}{\cos \varepsilon}, 1\right)}double f(double x, double eps) {
double r4183032 = x;
double r4183033 = eps;
double r4183034 = r4183032 + r4183033;
double r4183035 = tan(r4183034);
double r4183036 = tan(r4183032);
double r4183037 = r4183035 - r4183036;
return r4183037;
}
double f(double x, double eps) {
double r4183038 = x;
double r4183039 = sin(r4183038);
double r4183040 = cos(r4183038);
double r4183041 = r4183039 / r4183040;
double r4183042 = 1.0;
double r4183043 = eps;
double r4183044 = cos(r4183043);
double r4183045 = r4183044 * r4183040;
double r4183046 = sin(r4183043);
double r4183047 = r4183045 / r4183046;
double r4183048 = r4183039 / r4183047;
double r4183049 = r4183048 * r4183048;
double r4183050 = r4183042 - r4183049;
double r4183051 = r4183041 / r4183050;
double r4183052 = r4183042 + r4183048;
double r4183053 = -r4183039;
double r4183054 = r4183053 / r4183040;
double r4183055 = fma(r4183051, r4183052, r4183054);
double r4183056 = r4183046 / r4183044;
double r4183057 = fma(r4183054, r4183056, r4183042);
double r4183058 = r4183056 / r4183057;
double r4183059 = r4183055 + r4183058;
return r4183059;
}




Bits error versus x




Bits error versus eps
| Original | 36.8 |
|---|---|
| Target | 15.1 |
| Herbie | 12.9 |
Initial program 36.8
rmApplied tan-sum21.7
Taylor expanded around inf 21.9
Simplified12.9
Taylor expanded around inf 12.9
Simplified12.9
rmApplied flip--13.0
Applied associate-/r/13.0
Applied fma-neg12.9
Final simplification12.9
herbie shell --seed 2019172 +o rules:numerics
(FPCore (x eps)
:name "2tan (problem 3.3.2)"
:herbie-target
(/ (sin eps) (* (cos x) (cos (+ x eps))))
(- (tan (+ x eps)) (tan x)))