\left(x \cdot y - z \cdot y\right) \cdot t
\begin{array}{l}
\mathbf{if}\;\left(x \cdot y - z \cdot y\right) \cdot t = -\infty \lor \neg \left(\left(x \cdot y - z \cdot y\right) \cdot t \le 1.26480869441227944 \cdot 10^{250}\right):\\
\;\;\;\;y \cdot \left(\left(x - z\right) \cdot t\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot y - z \cdot y\right) \cdot t\\
\end{array}double code(double x, double y, double z, double t) {
return (((x * y) - (z * y)) * t);
}
double code(double x, double y, double z, double t) {
double VAR;
if ((((((x * y) - (z * y)) * t) <= -inf.0) || !((((x * y) - (z * y)) * t) <= 1.2648086944122794e+250))) {
VAR = (y * ((x - z) * t));
} else {
VAR = (((x * y) - (z * y)) * t);
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.1 |
|---|---|
| Target | 2.9 |
| Herbie | 2.1 |
if (* (- (* x y) (* z y)) t) < -inf.0 or 1.2648086944122794e+250 < (* (- (* x y) (* z y)) t) Initial program 49.1
rmApplied distribute-rgt-out--49.1
Applied associate-*l*6.3
if -inf.0 < (* (- (* x y) (* z y)) t) < 1.2648086944122794e+250Initial program 1.5
Final simplification2.1
herbie shell --seed 2020106
(FPCore (x y z t)
:name "Linear.Projection:inverseInfinitePerspective from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< t -9.231879582886777e-80) (* (* y t) (- x z)) (if (< t 2.543067051564877e+83) (* y (* t (- x z))) (* (* y (- x z)) t)))
(* (- (* x y) (* z y)) t))