x + y \cdot \frac{z - t}{z - a}x + \left(\left(\frac{\sqrt[3]{z - t}}{\sqrt[3]{z - a}} \cdot \frac{\sqrt[3]{z - t}}{\sqrt[3]{z - a}}\right) \cdot y\right) \cdot \frac{\sqrt[3]{z - t}}{\sqrt[3]{z - a}}double f(double x, double y, double z, double t, double a) {
double r30718503 = x;
double r30718504 = y;
double r30718505 = z;
double r30718506 = t;
double r30718507 = r30718505 - r30718506;
double r30718508 = a;
double r30718509 = r30718505 - r30718508;
double r30718510 = r30718507 / r30718509;
double r30718511 = r30718504 * r30718510;
double r30718512 = r30718503 + r30718511;
return r30718512;
}
double f(double x, double y, double z, double t, double a) {
double r30718513 = x;
double r30718514 = z;
double r30718515 = t;
double r30718516 = r30718514 - r30718515;
double r30718517 = cbrt(r30718516);
double r30718518 = a;
double r30718519 = r30718514 - r30718518;
double r30718520 = cbrt(r30718519);
double r30718521 = r30718517 / r30718520;
double r30718522 = r30718521 * r30718521;
double r30718523 = y;
double r30718524 = r30718522 * r30718523;
double r30718525 = r30718524 * r30718521;
double r30718526 = r30718513 + r30718525;
return r30718526;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 1.4 |
|---|---|
| Target | 1.3 |
| Herbie | 0.6 |
Initial program 1.4
rmApplied add-cube-cbrt2.0
Applied add-cube-cbrt1.8
Applied times-frac1.8
Applied associate-*r*0.5
Simplified0.6
Final simplification0.6
herbie shell --seed 2019200
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisLine from plot-0.2.3.4, A"
:herbie-target
(+ x (/ y (/ (- z a) (- z t))))
(+ x (* y (/ (- z t) (- z a)))))