\left(x \cdot y - z \cdot y\right) \cdot t
\begin{array}{l}
\mathbf{if}\;y \le -1.43405946159005389 \cdot 10^{-73}:\\
\;\;\;\;1 \cdot \left(\left(\left(x - z\right) \cdot t\right) \cdot y\right)\\
\mathbf{elif}\;y \le 8.82218830134679759 \cdot 10^{-152}:\\
\;\;\;\;t \cdot \left(y \cdot \left(x - z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;1 \cdot \left(\left(x - z\right) \cdot \left(t \cdot y\right)\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r566593 = x;
double r566594 = y;
double r566595 = r566593 * r566594;
double r566596 = z;
double r566597 = r566596 * r566594;
double r566598 = r566595 - r566597;
double r566599 = t;
double r566600 = r566598 * r566599;
return r566600;
}
double f(double x, double y, double z, double t) {
double r566601 = y;
double r566602 = -1.434059461590054e-73;
bool r566603 = r566601 <= r566602;
double r566604 = 1.0;
double r566605 = x;
double r566606 = z;
double r566607 = r566605 - r566606;
double r566608 = t;
double r566609 = r566607 * r566608;
double r566610 = r566609 * r566601;
double r566611 = r566604 * r566610;
double r566612 = 8.822188301346798e-152;
bool r566613 = r566601 <= r566612;
double r566614 = r566601 * r566607;
double r566615 = r566608 * r566614;
double r566616 = r566608 * r566601;
double r566617 = r566607 * r566616;
double r566618 = r566604 * r566617;
double r566619 = r566613 ? r566615 : r566618;
double r566620 = r566603 ? r566611 : r566619;
return r566620;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.6 |
|---|---|
| Target | 3.1 |
| Herbie | 3.5 |
if y < -1.434059461590054e-73Initial program 12.4
Simplified12.4
rmApplied *-un-lft-identity12.4
Applied associate-*l*12.4
Simplified3.6
rmApplied associate-*r*3.5
if -1.434059461590054e-73 < y < 8.822188301346798e-152Initial program 2.9
Simplified2.9
if 8.822188301346798e-152 < y Initial program 9.7
Simplified9.7
rmApplied *-un-lft-identity9.7
Applied associate-*l*9.7
Simplified4.3
Final simplification3.5
herbie shell --seed 2020060 +o rules:numerics
(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))