Average Error: 0.0 → 0.1
Time: 12.9s
Precision: 64
\[\frac{2}{e^{x} + e^{-x}}\]
\[\sqrt[3]{{\left(\frac{2}{e^{x} + e^{-x}}\right)}^{3}}\]
\frac{2}{e^{x} + e^{-x}}
\sqrt[3]{{\left(\frac{2}{e^{x} + e^{-x}}\right)}^{3}}
double f(double x) {
        double r53401 = 2.0;
        double r53402 = x;
        double r53403 = exp(r53402);
        double r53404 = -r53402;
        double r53405 = exp(r53404);
        double r53406 = r53403 + r53405;
        double r53407 = r53401 / r53406;
        return r53407;
}

double f(double x) {
        double r53408 = 2.0;
        double r53409 = x;
        double r53410 = exp(r53409);
        double r53411 = -r53409;
        double r53412 = exp(r53411);
        double r53413 = r53410 + r53412;
        double r53414 = r53408 / r53413;
        double r53415 = 3.0;
        double r53416 = pow(r53414, r53415);
        double r53417 = cbrt(r53416);
        return r53417;
}

Error

Bits error versus x

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 0.0

    \[\frac{2}{e^{x} + e^{-x}}\]
  2. Using strategy rm
  3. Applied add-cbrt-cube0.1

    \[\leadsto \frac{2}{\color{blue}{\sqrt[3]{\left(\left(e^{x} + e^{-x}\right) \cdot \left(e^{x} + e^{-x}\right)\right) \cdot \left(e^{x} + e^{-x}\right)}}}\]
  4. Applied add-cbrt-cube0.1

    \[\leadsto \frac{\color{blue}{\sqrt[3]{\left(2 \cdot 2\right) \cdot 2}}}{\sqrt[3]{\left(\left(e^{x} + e^{-x}\right) \cdot \left(e^{x} + e^{-x}\right)\right) \cdot \left(e^{x} + e^{-x}\right)}}\]
  5. Applied cbrt-undiv0.1

    \[\leadsto \color{blue}{\sqrt[3]{\frac{\left(2 \cdot 2\right) \cdot 2}{\left(\left(e^{x} + e^{-x}\right) \cdot \left(e^{x} + e^{-x}\right)\right) \cdot \left(e^{x} + e^{-x}\right)}}}\]
  6. Simplified0.1

    \[\leadsto \sqrt[3]{\color{blue}{{\left(\frac{2}{e^{x} + e^{-x}}\right)}^{3}}}\]
  7. Final simplification0.1

    \[\leadsto \sqrt[3]{{\left(\frac{2}{e^{x} + e^{-x}}\right)}^{3}}\]

Reproduce

herbie shell --seed 2019325 +o rules:numerics
(FPCore (x)
  :name "Hyperbolic secant"
  :precision binary64
  (/ 2 (+ (exp x) (exp (- x)))))