x + \frac{y \cdot \left(z - t\right)}{z - a}\mathsf{fma}\left(\frac{z - t}{z - a}, y, x\right)double f(double x, double y, double z, double t, double a) {
double r771346 = x;
double r771347 = y;
double r771348 = z;
double r771349 = t;
double r771350 = r771348 - r771349;
double r771351 = r771347 * r771350;
double r771352 = a;
double r771353 = r771348 - r771352;
double r771354 = r771351 / r771353;
double r771355 = r771346 + r771354;
return r771355;
}
double f(double x, double y, double z, double t, double a) {
double r771356 = z;
double r771357 = t;
double r771358 = r771356 - r771357;
double r771359 = a;
double r771360 = r771356 - r771359;
double r771361 = r771358 / r771360;
double r771362 = y;
double r771363 = x;
double r771364 = fma(r771361, r771362, r771363);
return r771364;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 11.1 |
|---|---|
| Target | 1.3 |
| Herbie | 1.4 |
Initial program 11.1
Simplified2.7
rmApplied clear-num3.0
rmApplied fma-udef3.0
Simplified2.8
rmApplied associate-/r/1.4
Applied fma-def1.4
Final simplification1.4
herbie shell --seed 2020025 +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))))