\tan \left(x + \varepsilon\right) - \tan x
\frac{\frac{\sin \varepsilon}{\cos \varepsilon}}{1 - \frac{\frac{\sin x}{\frac{\cos \varepsilon}{\sin \varepsilon}}}{\cos x}} + \left(\frac{\frac{\sin x}{\cos x}}{1 - \frac{\frac{\sin x}{\frac{\cos \varepsilon}{\sin \varepsilon}}}{\cos x}} - \frac{\sin x}{\cos x}\right)double f(double x, double eps) {
double r3957885 = x;
double r3957886 = eps;
double r3957887 = r3957885 + r3957886;
double r3957888 = tan(r3957887);
double r3957889 = tan(r3957885);
double r3957890 = r3957888 - r3957889;
return r3957890;
}
double f(double x, double eps) {
double r3957891 = eps;
double r3957892 = sin(r3957891);
double r3957893 = cos(r3957891);
double r3957894 = r3957892 / r3957893;
double r3957895 = 1.0;
double r3957896 = x;
double r3957897 = sin(r3957896);
double r3957898 = r3957893 / r3957892;
double r3957899 = r3957897 / r3957898;
double r3957900 = cos(r3957896);
double r3957901 = r3957899 / r3957900;
double r3957902 = r3957895 - r3957901;
double r3957903 = r3957894 / r3957902;
double r3957904 = r3957897 / r3957900;
double r3957905 = r3957904 / r3957902;
double r3957906 = r3957905 - r3957904;
double r3957907 = r3957903 + r3957906;
return r3957907;
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.3 |
|---|---|
| Target | 15.2 |
| Herbie | 13.0 |
Initial program 37.3
rmApplied tan-sum21.9
rmApplied div-inv21.9
Applied fma-neg21.9
rmApplied add-log-exp22.0
Taylor expanded around -inf 22.0
Simplified13.0
Final simplification13.0
herbie shell --seed 2019151 +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)))