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 r556198 = x;
double r556199 = y;
double r556200 = z;
double r556201 = t;
double r556202 = r556200 - r556201;
double r556203 = r556199 * r556202;
double r556204 = a;
double r556205 = r556200 - r556204;
double r556206 = r556203 / r556205;
double r556207 = r556198 + r556206;
return r556207;
}
double f(double x, double y, double z, double t, double a) {
double r556208 = z;
double r556209 = t;
double r556210 = r556208 - r556209;
double r556211 = a;
double r556212 = r556208 - r556211;
double r556213 = r556210 / r556212;
double r556214 = y;
double r556215 = r556213 * r556214;
double r556216 = x;
double r556217 = r556215 + r556216;
return r556217;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 11.1 |
|---|---|
| Target | 1.1 |
| Herbie | 1.3 |
Initial program 11.1
Simplified2.9
rmApplied clear-num3.2
rmApplied fma-udef3.2
Simplified3.0
rmApplied associate-/r/1.3
Final simplification1.3
herbie shell --seed 2020056 +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))))