\tan \left(x + \varepsilon\right) - \tan x
\left(\mathsf{fma}\left(\sin x, \frac{\frac{1}{\cos x}}{1 - \frac{\frac{\sin \varepsilon}{\cos \varepsilon} \cdot \sin x}{\cos x}}, \frac{-1}{\cos x} \cdot \sin x\right) + \mathsf{fma}\left(\frac{-1}{\cos x}, \sin x, \frac{1}{\cos x} \cdot \sin x\right)\right) + \frac{\frac{\sin \varepsilon}{\cos \varepsilon}}{1 - \frac{\frac{\sin \varepsilon}{\cos \varepsilon} \cdot \sin x}{\cos x}}double f(double x, double eps) {
double r2312173 = x;
double r2312174 = eps;
double r2312175 = r2312173 + r2312174;
double r2312176 = tan(r2312175);
double r2312177 = tan(r2312173);
double r2312178 = r2312176 - r2312177;
return r2312178;
}
double f(double x, double eps) {
double r2312179 = x;
double r2312180 = sin(r2312179);
double r2312181 = 1.0;
double r2312182 = cos(r2312179);
double r2312183 = r2312181 / r2312182;
double r2312184 = eps;
double r2312185 = sin(r2312184);
double r2312186 = cos(r2312184);
double r2312187 = r2312185 / r2312186;
double r2312188 = r2312187 * r2312180;
double r2312189 = r2312188 / r2312182;
double r2312190 = r2312181 - r2312189;
double r2312191 = r2312183 / r2312190;
double r2312192 = -1.0;
double r2312193 = r2312192 / r2312182;
double r2312194 = r2312193 * r2312180;
double r2312195 = fma(r2312180, r2312191, r2312194);
double r2312196 = r2312183 * r2312180;
double r2312197 = fma(r2312193, r2312180, r2312196);
double r2312198 = r2312195 + r2312197;
double r2312199 = r2312187 / r2312190;
double r2312200 = r2312198 + r2312199;
return r2312200;
}




Bits error versus x




Bits error versus eps
| Original | 37.0 |
|---|---|
| Target | 15.4 |
| Herbie | 12.7 |
Initial program 37.0
rmApplied tan-sum21.5
Taylor expanded around inf 21.6
Simplified12.7
rmApplied div-inv13.5
Applied *-un-lft-identity13.5
Applied *-un-lft-identity13.5
Applied distribute-lft-out--13.5
Applied div-inv12.7
Applied times-frac12.7
Applied prod-diff12.7
Final simplification12.7
herbie shell --seed 2019152 +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)))