\tan \left(x + \varepsilon\right) - \tan x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -6.248907778173893262746741592331412477694 \cdot 10^{-50}:\\
\;\;\;\;\mathsf{fma}\left(\frac{\tan x + \tan \varepsilon}{1 - \frac{\left(\tan x \cdot \sin \varepsilon\right) \cdot \left(\tan x \cdot \sin \varepsilon\right)}{\cos \varepsilon \cdot \cos \varepsilon}}, 1 + \tan x \cdot \tan \varepsilon, -\tan x\right)\\
\mathbf{elif}\;\varepsilon \le 3.496400468760211769169676099038170360789 \cdot 10^{-74}:\\
\;\;\;\;\mathsf{fma}\left(\varepsilon \cdot x, x + \varepsilon, \varepsilon\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{\tan x + \tan \varepsilon}{1 - \frac{\left(\tan x \cdot \sin \varepsilon\right) \cdot \left(\tan x \cdot \sin \varepsilon\right)}{\cos \varepsilon \cdot \cos \varepsilon}}, 1 + \tan x \cdot \tan \varepsilon, -\tan x\right)\\
\end{array}double f(double x, double eps) {
double r12586626 = x;
double r12586627 = eps;
double r12586628 = r12586626 + r12586627;
double r12586629 = tan(r12586628);
double r12586630 = tan(r12586626);
double r12586631 = r12586629 - r12586630;
return r12586631;
}
double f(double x, double eps) {
double r12586632 = eps;
double r12586633 = -6.248907778173893e-50;
bool r12586634 = r12586632 <= r12586633;
double r12586635 = x;
double r12586636 = tan(r12586635);
double r12586637 = tan(r12586632);
double r12586638 = r12586636 + r12586637;
double r12586639 = 1.0;
double r12586640 = sin(r12586632);
double r12586641 = r12586636 * r12586640;
double r12586642 = r12586641 * r12586641;
double r12586643 = cos(r12586632);
double r12586644 = r12586643 * r12586643;
double r12586645 = r12586642 / r12586644;
double r12586646 = r12586639 - r12586645;
double r12586647 = r12586638 / r12586646;
double r12586648 = r12586636 * r12586637;
double r12586649 = r12586639 + r12586648;
double r12586650 = -r12586636;
double r12586651 = fma(r12586647, r12586649, r12586650);
double r12586652 = 3.4964004687602118e-74;
bool r12586653 = r12586632 <= r12586652;
double r12586654 = r12586632 * r12586635;
double r12586655 = r12586635 + r12586632;
double r12586656 = fma(r12586654, r12586655, r12586632);
double r12586657 = r12586653 ? r12586656 : r12586651;
double r12586658 = r12586634 ? r12586651 : r12586657;
return r12586658;
}




Bits error versus x




Bits error versus eps
| Original | 37.0 |
|---|---|
| Target | 15.1 |
| Herbie | 15.5 |
if eps < -6.248907778173893e-50 or 3.4964004687602118e-74 < eps Initial program 30.3
rmApplied tan-sum4.9
rmApplied flip--4.9
Applied associate-/r/4.9
Applied fma-neg4.9
rmApplied tan-quot4.9
Applied associate-*r/4.9
Applied tan-quot4.9
Applied associate-*r/4.9
Applied frac-times4.9
if -6.248907778173893e-50 < eps < 3.4964004687602118e-74Initial program 47.0
Taylor expanded around 0 31.4
Simplified31.2
Final simplification15.5
herbie shell --seed 2019173 +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)))