Average Error: 37.2 → 0.4
Time: 9.8s
Precision: 64
\[\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}\]
\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;
}

Error

Bits error versus x

Bits error versus eps

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original37.2
Target15.1
Herbie0.4
\[\frac{\sin \varepsilon}{\cos x \cdot \cos \left(x + \varepsilon\right)}\]

Derivation

  1. Initial program 37.2

    \[\tan \left(x + \varepsilon\right) - \tan x\]
  2. Using strategy rm
  3. Applied tan-sum21.9

    \[\leadsto \color{blue}{\frac{\tan x + \tan \varepsilon}{1 - \tan x \cdot \tan \varepsilon}} - \tan x\]
  4. Using strategy rm
  5. Applied tan-quot22.0

    \[\leadsto \frac{\tan x + \color{blue}{\frac{\sin \varepsilon}{\cos \varepsilon}}}{1 - \tan x \cdot \tan \varepsilon} - \tan x\]
  6. Applied tan-quot22.1

    \[\leadsto \frac{\color{blue}{\frac{\sin x}{\cos x}} + \frac{\sin \varepsilon}{\cos \varepsilon}}{1 - \tan x \cdot \tan \varepsilon} - \tan x\]
  7. Applied frac-add22.1

    \[\leadsto \frac{\color{blue}{\frac{\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon}{\cos x \cdot \cos \varepsilon}}}{1 - \tan x \cdot \tan \varepsilon} - \tan x\]
  8. Using strategy rm
  9. Applied tan-quot22.0

    \[\leadsto \frac{\frac{\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon}{\cos x \cdot \cos \varepsilon}}{1 - \tan x \cdot \tan \varepsilon} - \color{blue}{\frac{\sin x}{\cos x}}\]
  10. Applied frac-sub22.1

    \[\leadsto \color{blue}{\frac{\frac{\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon}{\cos x \cdot \cos \varepsilon} \cdot \cos x - \left(1 - \tan x \cdot \tan \varepsilon\right) \cdot \sin x}{\left(1 - \tan x \cdot \tan \varepsilon\right) \cdot \cos x}}\]
  11. Taylor expanded around inf 0.4

    \[\leadsto \frac{\color{blue}{\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}\]
  12. Final simplification0.4

    \[\leadsto \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}\]

Reproduce

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)))