x + \frac{y \cdot \left(z - x\right)}{t}\begin{array}{l}
\mathbf{if}\;x + \frac{y \cdot \left(z - x\right)}{t} = -\infty:\\
\;\;\;\;x + \frac{\frac{y}{t}}{\frac{1}{z - x}}\\
\mathbf{elif}\;x + \frac{y \cdot \left(z - x\right)}{t} \le 8.6537122954451224 \cdot 10^{266}:\\
\;\;\;\;x + \frac{y \cdot \left(z - x\right)}{t}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y}{t}, z - x, x\right)\\
\end{array}double code(double x, double y, double z, double t) {
return (x + ((y * (z - x)) / t));
}
double code(double x, double y, double z, double t) {
double VAR;
if (((x + ((y * (z - x)) / t)) <= -inf.0)) {
VAR = (x + ((y / t) / (1.0 / (z - x))));
} else {
double VAR_1;
if (((x + ((y * (z - x)) / t)) <= 8.653712295445122e+266)) {
VAR_1 = (x + ((y * (z - x)) / t));
} else {
VAR_1 = fma((y / t), (z - x), x);
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 5.9 |
|---|---|
| Target | 2.0 |
| Herbie | 0.9 |
if (+ x (/ (* y (- z x)) t)) < -inf.0Initial program 64.0
rmApplied associate-/l*0.2
rmApplied div-inv0.3
Applied associate-/r*0.2
if -inf.0 < (+ x (/ (* y (- z x)) t)) < 8.653712295445122e+266Initial program 0.7
if 8.653712295445122e+266 < (+ x (/ (* y (- z x)) t)) Initial program 31.9
Simplified2.9
Final simplification0.9
herbie shell --seed 2020100 +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)))