\tan \left(x + \varepsilon\right) - \tan x
\frac{\frac{\sin \varepsilon \cdot \cos x}{\cos \varepsilon} + \frac{{\left(\sin x\right)}^{2} \cdot \sin \varepsilon}{\cos x \cdot \cos \varepsilon}}{\left(1 - \tan x \cdot \tan \varepsilon\right) \cdot \cos x}double f(double x, double eps) {
double r118681 = x;
double r118682 = eps;
double r118683 = r118681 + r118682;
double r118684 = tan(r118683);
double r118685 = tan(r118681);
double r118686 = r118684 - r118685;
return r118686;
}
double f(double x, double eps) {
double r118687 = eps;
double r118688 = sin(r118687);
double r118689 = x;
double r118690 = cos(r118689);
double r118691 = r118688 * r118690;
double r118692 = cos(r118687);
double r118693 = r118691 / r118692;
double r118694 = sin(r118689);
double r118695 = 2.0;
double r118696 = pow(r118694, r118695);
double r118697 = r118696 * r118688;
double r118698 = r118690 * r118692;
double r118699 = r118697 / r118698;
double r118700 = r118693 + r118699;
double r118701 = 1.0;
double r118702 = tan(r118689);
double r118703 = tan(r118687);
double r118704 = r118702 * r118703;
double r118705 = r118701 - r118704;
double r118706 = r118705 * r118690;
double r118707 = r118700 / r118706;
return r118707;
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.2 |
|---|---|
| Target | 15.1 |
| Herbie | 0.4 |
Initial program 37.2
rmApplied tan-sum21.9
rmApplied tan-quot22.0
Applied tan-quot22.1
Applied frac-add22.1
rmApplied tan-quot22.0
Applied frac-sub22.1
Taylor expanded around inf 0.4
Final simplification0.4
herbie shell --seed 2020018
(FPCore (x eps)
:name "2tan (problem 3.3.2)"
:precision binary64
:herbie-target
(/ (sin eps) (* (cos x) (cos (+ x eps))))
(- (tan (+ x eps)) (tan x)))