x + \left(y - x\right) \cdot \frac{z}{t}x + \left(\left(y - x\right) \cdot \frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{t} \cdot \sqrt[3]{t}}\right) \cdot \frac{\sqrt[3]{z}}{\sqrt[3]{t}}double f(double x, double y, double z, double t) {
double r776612 = x;
double r776613 = y;
double r776614 = r776613 - r776612;
double r776615 = z;
double r776616 = t;
double r776617 = r776615 / r776616;
double r776618 = r776614 * r776617;
double r776619 = r776612 + r776618;
return r776619;
}
double f(double x, double y, double z, double t) {
double r776620 = x;
double r776621 = y;
double r776622 = r776621 - r776620;
double r776623 = z;
double r776624 = cbrt(r776623);
double r776625 = r776624 * r776624;
double r776626 = t;
double r776627 = cbrt(r776626);
double r776628 = r776627 * r776627;
double r776629 = r776625 / r776628;
double r776630 = r776622 * r776629;
double r776631 = r776624 / r776627;
double r776632 = r776630 * r776631;
double r776633 = r776620 + r776632;
return r776633;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.1 |
|---|---|
| Target | 2.2 |
| Herbie | 1.0 |
Initial program 2.1
rmApplied add-cube-cbrt2.6
Applied add-cube-cbrt2.7
Applied times-frac2.7
Applied associate-*r*1.0
Final simplification1.0
herbie shell --seed 2019350 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:tickPosition from plot-0.2.3.4"
:precision binary64
:herbie-target
(if (< (* (- y x) (/ z t)) -1013646692435.887) (+ x (/ (- y x) (/ t z))) (if (< (* (- y x) (/ z t)) -0.0) (+ x (/ (* (- y x) z) t)) (+ x (/ (- y x) (/ t z)))))
(+ x (* (- y x) (/ z t))))