\tan \left(x + \varepsilon\right) - \tan x
\frac{\sin \varepsilon \cdot \frac{\cos x}{\cos \varepsilon} + \frac{\frac{1 - \cos \left(x + x\right)}{2}}{\cos x \cdot \cos \varepsilon} \cdot \sin \varepsilon}{\left(1 - \tan \varepsilon \cdot \tan x\right) \cdot \cos x}double f(double x, double eps) {
double r1582096 = x;
double r1582097 = eps;
double r1582098 = r1582096 + r1582097;
double r1582099 = tan(r1582098);
double r1582100 = tan(r1582096);
double r1582101 = r1582099 - r1582100;
return r1582101;
}
double f(double x, double eps) {
double r1582102 = eps;
double r1582103 = sin(r1582102);
double r1582104 = x;
double r1582105 = cos(r1582104);
double r1582106 = cos(r1582102);
double r1582107 = r1582105 / r1582106;
double r1582108 = r1582103 * r1582107;
double r1582109 = 1.0;
double r1582110 = r1582104 + r1582104;
double r1582111 = cos(r1582110);
double r1582112 = r1582109 - r1582111;
double r1582113 = 2.0;
double r1582114 = r1582112 / r1582113;
double r1582115 = r1582105 * r1582106;
double r1582116 = r1582114 / r1582115;
double r1582117 = r1582116 * r1582103;
double r1582118 = r1582108 + r1582117;
double r1582119 = tan(r1582102);
double r1582120 = tan(r1582104);
double r1582121 = r1582119 * r1582120;
double r1582122 = r1582109 - r1582121;
double r1582123 = r1582122 * r1582105;
double r1582124 = r1582118 / r1582123;
return r1582124;
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.6 |
|---|---|
| Target | 15.3 |
| Herbie | 0.5 |
Initial program 37.6
rmApplied tan-quot37.6
Applied tan-sum22.3
Applied frac-sub22.3
Taylor expanded around -inf 0.4
Simplified0.4
rmApplied sin-mult0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019128
(FPCore (x eps)
:name "2tan (problem 3.3.2)"
:herbie-target
(/ (sin eps) (* (cos x) (cos (+ x eps))))
(- (tan (+ x eps)) (tan x)))