x + \frac{y \cdot \left(z - t\right)}{a - t}x + \frac{\frac{y}{a - t}}{\frac{1}{z - t}}double code(double x, double y, double z, double t, double a) {
return (x + ((y * (z - t)) / (a - t)));
}
double code(double x, double y, double z, double t, double a) {
return (x + ((y / (a - t)) / (1.0 / (z - t))));
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 10.9 |
|---|---|
| Target | 1.3 |
| Herbie | 3.2 |
Initial program 10.9
rmApplied associate-/l*1.3
rmApplied div-inv1.4
Applied associate-/r*3.2
Final simplification3.2
herbie shell --seed 2020078
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTicks from plot-0.2.3.4, B"
:precision binary64
:herbie-target
(+ x (/ y (/ (- a t) (- z t))))
(+ x (/ (* y (- z t)) (- a t))))