x + \frac{y \cdot \left(z - x\right)}{t}\mathsf{fma}\left(\frac{y}{t}, z - x, x\right)double f(double x, double y, double z, double t) {
double r319321 = x;
double r319322 = y;
double r319323 = z;
double r319324 = r319323 - r319321;
double r319325 = r319322 * r319324;
double r319326 = t;
double r319327 = r319325 / r319326;
double r319328 = r319321 + r319327;
return r319328;
}
double f(double x, double y, double z, double t) {
double r319329 = y;
double r319330 = t;
double r319331 = r319329 / r319330;
double r319332 = z;
double r319333 = x;
double r319334 = r319332 - r319333;
double r319335 = fma(r319331, r319334, r319333);
return r319335;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 6.9 |
|---|---|
| Target | 2.1 |
| Herbie | 2.1 |
Initial program 6.9
Simplified2.1
Final simplification2.1
herbie shell --seed 2020083 +o rules:numerics
(FPCore (x y z t)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, D"
:precision binary64
:herbie-target
(- x (+ (* x (/ y t)) (* (- z) (/ y t))))
(+ x (/ (* y (- z x)) t)))