\tan \left(x + \varepsilon\right) - \tan x
\log \left(e^{\frac{\frac{\sin x}{\cos x}}{1 - \frac{\sin \varepsilon}{\cos \varepsilon} \cdot \frac{\sin x}{\cos x}} - \frac{\sin x}{\cos x}}\right) + \frac{\frac{\sin \varepsilon}{\cos \varepsilon}}{1 - \frac{\sin \varepsilon}{\cos \varepsilon} \cdot \frac{\sin x}{\cos x}}double f(double x, double eps) {
double r3426285 = x;
double r3426286 = eps;
double r3426287 = r3426285 + r3426286;
double r3426288 = tan(r3426287);
double r3426289 = tan(r3426285);
double r3426290 = r3426288 - r3426289;
return r3426290;
}
double f(double x, double eps) {
double r3426291 = x;
double r3426292 = sin(r3426291);
double r3426293 = cos(r3426291);
double r3426294 = r3426292 / r3426293;
double r3426295 = 1.0;
double r3426296 = eps;
double r3426297 = sin(r3426296);
double r3426298 = cos(r3426296);
double r3426299 = r3426297 / r3426298;
double r3426300 = r3426299 * r3426294;
double r3426301 = r3426295 - r3426300;
double r3426302 = r3426294 / r3426301;
double r3426303 = r3426302 - r3426294;
double r3426304 = exp(r3426303);
double r3426305 = log(r3426304);
double r3426306 = r3426299 / r3426301;
double r3426307 = r3426305 + r3426306;
return r3426307;
}




Bits error versus x




Bits error versus eps
Results
| Original | 36.8 |
|---|---|
| Target | 14.7 |
| Herbie | 12.9 |
Initial program 36.8
rmApplied tan-sum22.1
rmApplied tan-quot22.1
Applied associate-*l/22.1
Taylor expanded around inf 22.2
Simplified12.9
rmApplied add-log-exp21.8
Applied add-log-exp12.9
Applied diff-log12.9
Simplified12.9
Final simplification12.9
herbie shell --seed 2019146 +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)))