x + \frac{y \cdot \left(z - t\right)}{z - a}\frac{z - t}{z - a} \cdot y + xdouble f(double x, double y, double z, double t, double a) {
double r420505 = x;
double r420506 = y;
double r420507 = z;
double r420508 = t;
double r420509 = r420507 - r420508;
double r420510 = r420506 * r420509;
double r420511 = a;
double r420512 = r420507 - r420511;
double r420513 = r420510 / r420512;
double r420514 = r420505 + r420513;
return r420514;
}
double f(double x, double y, double z, double t, double a) {
double r420515 = z;
double r420516 = t;
double r420517 = r420515 - r420516;
double r420518 = a;
double r420519 = r420515 - r420518;
double r420520 = r420517 / r420519;
double r420521 = y;
double r420522 = r420520 * r420521;
double r420523 = x;
double r420524 = r420522 + r420523;
return r420524;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 10.4 |
|---|---|
| Target | 1.4 |
| Herbie | 1.4 |
Initial program 10.4
Simplified3.0
rmApplied clear-num3.2
rmApplied fma-udef3.2
Simplified2.9
rmApplied associate-/r/1.4
Final simplification1.4
herbie shell --seed 2019325 +o rules:numerics
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTicks from plot-0.2.3.4, A"
:precision binary64
:herbie-target
(+ x (/ y (/ (- z a) (- z t))))
(+ x (/ (* y (- z t)) (- z a))))