\tan \left(x + \varepsilon\right) - \tan x
\frac{\frac{\sin \varepsilon}{\cos \varepsilon}}{1 - \sqrt[3]{\left(\frac{\sin x}{\frac{\cos x}{\frac{\sin \varepsilon}{\cos \varepsilon}}} \cdot \frac{\sin x}{\frac{\cos x}{\frac{\sin \varepsilon}{\cos \varepsilon}}}\right) \cdot \frac{\sin x}{\frac{\cos x}{\frac{\sin \varepsilon}{\cos \varepsilon}}}}} + \left(\frac{\frac{\sin x}{\cos x}}{1 - \frac{\sin x}{\frac{\cos x}{\frac{\sin \varepsilon}{\cos \varepsilon}}}} - \frac{\sin x}{\cos x}\right)double f(double x, double eps) {
double r5213836 = x;
double r5213837 = eps;
double r5213838 = r5213836 + r5213837;
double r5213839 = tan(r5213838);
double r5213840 = tan(r5213836);
double r5213841 = r5213839 - r5213840;
return r5213841;
}
double f(double x, double eps) {
double r5213842 = eps;
double r5213843 = sin(r5213842);
double r5213844 = cos(r5213842);
double r5213845 = r5213843 / r5213844;
double r5213846 = 1.0;
double r5213847 = x;
double r5213848 = sin(r5213847);
double r5213849 = cos(r5213847);
double r5213850 = r5213849 / r5213845;
double r5213851 = r5213848 / r5213850;
double r5213852 = r5213851 * r5213851;
double r5213853 = r5213852 * r5213851;
double r5213854 = cbrt(r5213853);
double r5213855 = r5213846 - r5213854;
double r5213856 = r5213845 / r5213855;
double r5213857 = r5213848 / r5213849;
double r5213858 = r5213846 - r5213851;
double r5213859 = r5213857 / r5213858;
double r5213860 = r5213859 - r5213857;
double r5213861 = r5213856 + r5213860;
return r5213861;
}




Bits error versus x




Bits error versus eps
Results
| Original | 36.9 |
|---|---|
| Target | 15.1 |
| Herbie | 12.8 |
Initial program 36.9
rmApplied tan-sum21.8
Taylor expanded around inf 21.9
Simplified12.8
rmApplied add-cbrt-cube12.8
Final simplification12.8
herbie shell --seed 2019144 +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)))