Average Error: 10.2 → 1.4
Time: 3.1s
Precision: 64
\[\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\]
\[\frac{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}\]
\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}
\frac{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}
double f(double x, double y, double z) {
        double r667136 = x;
        double r667137 = y;
        double r667138 = z;
        double r667139 = r667137 - r667138;
        double r667140 = 1.0;
        double r667141 = r667139 + r667140;
        double r667142 = r667136 * r667141;
        double r667143 = r667142 / r667138;
        return r667143;
}

double f(double x, double y, double z) {
        double r667144 = y;
        double r667145 = z;
        double r667146 = r667144 - r667145;
        double r667147 = 1.0;
        double r667148 = r667146 + r667147;
        double r667149 = cbrt(r667148);
        double r667150 = r667149 * r667149;
        double r667151 = cbrt(r667145);
        double r667152 = r667151 * r667151;
        double r667153 = r667150 / r667152;
        double r667154 = x;
        double r667155 = r667151 / r667149;
        double r667156 = r667154 / r667155;
        double r667157 = r667153 * r667156;
        return r667157;
}

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

Original10.2
Target0.6
Herbie1.4
\[\begin{array}{l} \mathbf{if}\;x \lt -2.7148310671343599 \cdot 10^{-162}:\\ \;\;\;\;\left(1 + y\right) \cdot \frac{x}{z} - x\\ \mathbf{elif}\;x \lt 3.87410881643954616 \cdot 10^{-197}:\\ \;\;\;\;\left(x \cdot \left(\left(y - z\right) + 1\right)\right) \cdot \frac{1}{z}\\ \mathbf{else}:\\ \;\;\;\;\left(1 + y\right) \cdot \frac{x}{z} - x\\ \end{array}\]

Derivation

  1. Initial program 10.2

    \[\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\]
  2. Using strategy rm
  3. Applied associate-/l*3.1

    \[\leadsto \color{blue}{\frac{x}{\frac{z}{\left(y - z\right) + 1}}}\]
  4. Using strategy rm
  5. Applied add-cube-cbrt3.9

    \[\leadsto \frac{x}{\frac{z}{\color{blue}{\left(\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}\right) \cdot \sqrt[3]{\left(y - z\right) + 1}}}}\]
  6. Applied add-cube-cbrt3.8

    \[\leadsto \frac{x}{\frac{\color{blue}{\left(\sqrt[3]{z} \cdot \sqrt[3]{z}\right) \cdot \sqrt[3]{z}}}{\left(\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}\right) \cdot \sqrt[3]{\left(y - z\right) + 1}}}\]
  7. Applied times-frac3.8

    \[\leadsto \frac{x}{\color{blue}{\frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}} \cdot \frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}}\]
  8. Applied *-un-lft-identity3.8

    \[\leadsto \frac{\color{blue}{1 \cdot x}}{\frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}} \cdot \frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}\]
  9. Applied times-frac1.4

    \[\leadsto \color{blue}{\frac{1}{\frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}}\]
  10. Simplified1.4

    \[\leadsto \color{blue}{\frac{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}{\sqrt[3]{z} \cdot \sqrt[3]{z}}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}\]
  11. Final simplification1.4

    \[\leadsto \frac{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}\]

Reproduce

herbie shell --seed 2020039 
(FPCore (x y z)
  :name "Diagrams.TwoD.Segment.Bernstein:evaluateBernstein from diagrams-lib-1.3.0.3"
  :precision binary64

  :herbie-target
  (if (< x -2.71483106713436e-162) (- (* (+ 1 y) (/ x z)) x) (if (< x 3.874108816439546e-197) (* (* x (+ (- y z) 1)) (/ 1 z)) (- (* (+ 1 y) (/ x z)) x)))

  (/ (* x (+ (- y z) 1)) z))