Average Error: 6.0 → 1.1
Time: 20.3s
Precision: 64
\[x + \frac{e^{y \cdot \log \left(\frac{y}{z + y}\right)}}{y}\]
\[x + \frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right) \cdot y + \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right) \cdot y}}{y}\]
x + \frac{e^{y \cdot \log \left(\frac{y}{z + y}\right)}}{y}
x + \frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right) \cdot y + \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right) \cdot y}}{y}
double f(double x, double y, double z) {
        double r290554 = x;
        double r290555 = y;
        double r290556 = z;
        double r290557 = r290556 + r290555;
        double r290558 = r290555 / r290557;
        double r290559 = log(r290558);
        double r290560 = r290555 * r290559;
        double r290561 = exp(r290560);
        double r290562 = r290561 / r290555;
        double r290563 = r290554 + r290562;
        return r290563;
}

double f(double x, double y, double z) {
        double r290564 = x;
        double r290565 = 2.0;
        double r290566 = y;
        double r290567 = cbrt(r290566);
        double r290568 = z;
        double r290569 = r290568 + r290566;
        double r290570 = cbrt(r290569);
        double r290571 = r290567 / r290570;
        double r290572 = log(r290571);
        double r290573 = r290565 * r290572;
        double r290574 = r290573 * r290566;
        double r290575 = r290572 * r290566;
        double r290576 = r290574 + r290575;
        double r290577 = exp(r290576);
        double r290578 = r290577 / r290566;
        double r290579 = r290564 + r290578;
        return r290579;
}

Error

Bits error versus x

Bits error versus y

Bits error versus z

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original6.0
Target1.1
Herbie1.1
\[\begin{array}{l} \mathbf{if}\;\frac{y}{z + y} \lt 7.115415759790762719541517221498726780517 \cdot 10^{-315}:\\ \;\;\;\;x + \frac{e^{\frac{-1}{z}}}{y}\\ \mathbf{else}:\\ \;\;\;\;x + \frac{e^{\log \left({\left(\frac{y}{y + z}\right)}^{y}\right)}}{y}\\ \end{array}\]

Derivation

  1. Initial program 6.0

    \[x + \frac{e^{y \cdot \log \left(\frac{y}{z + y}\right)}}{y}\]
  2. Using strategy rm
  3. Applied add-cube-cbrt19.4

    \[\leadsto x + \frac{e^{y \cdot \log \left(\frac{y}{\color{blue}{\left(\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}\right) \cdot \sqrt[3]{z + y}}}\right)}}{y}\]
  4. Applied add-cube-cbrt6.1

    \[\leadsto x + \frac{e^{y \cdot \log \left(\frac{\color{blue}{\left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) \cdot \sqrt[3]{y}}}{\left(\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}\right) \cdot \sqrt[3]{z + y}}\right)}}{y}\]
  5. Applied times-frac6.1

    \[\leadsto x + \frac{e^{y \cdot \log \color{blue}{\left(\frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}} \cdot \frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)}}}{y}\]
  6. Applied log-prod2.1

    \[\leadsto x + \frac{e^{y \cdot \color{blue}{\left(\log \left(\frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}}\right) + \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right)}}}{y}\]
  7. Applied distribute-lft-in2.1

    \[\leadsto x + \frac{e^{\color{blue}{y \cdot \log \left(\frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}}\right) + y \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)}}}{y}\]
  8. Simplified1.1

    \[\leadsto x + \frac{e^{\color{blue}{\left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right) \cdot y} + y \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)}}{y}\]
  9. Simplified1.1

    \[\leadsto x + \frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right) \cdot y + \color{blue}{\log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right) \cdot y}}}{y}\]
  10. Final simplification1.1

    \[\leadsto x + \frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right) \cdot y + \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right) \cdot y}}{y}\]

Reproduce

herbie shell --seed 2019303 
(FPCore (x y z)
  :name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, G"
  :precision binary64

  :herbie-target
  (if (< (/ y (+ z y)) 7.1154157598e-315) (+ x (/ (exp (/ -1 z)) y)) (+ x (/ (exp (log (pow (/ y (+ y z)) y))) y)))

  (+ x (/ (exp (* y (log (/ y (+ z y))))) y)))