\left(x \cdot y - z \cdot y\right) \cdot t
\begin{array}{l}
\mathbf{if}\;y \le -4.049647329143563 \cdot 10^{27} \lor \neg \left(y \le 1.1333992022375297 \cdot 10^{48}\right):\\
\;\;\;\;\left(t \cdot y\right) \cdot \left(x - z\right)\\
\mathbf{else}:\\
\;\;\;\;t \cdot \left(y \cdot \left(x - z\right)\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r1351817 = x;
double r1351818 = y;
double r1351819 = r1351817 * r1351818;
double r1351820 = z;
double r1351821 = r1351820 * r1351818;
double r1351822 = r1351819 - r1351821;
double r1351823 = t;
double r1351824 = r1351822 * r1351823;
return r1351824;
}
double f(double x, double y, double z, double t) {
double r1351825 = y;
double r1351826 = -4.049647329143563e+27;
bool r1351827 = r1351825 <= r1351826;
double r1351828 = 1.1333992022375297e+48;
bool r1351829 = r1351825 <= r1351828;
double r1351830 = !r1351829;
bool r1351831 = r1351827 || r1351830;
double r1351832 = t;
double r1351833 = r1351832 * r1351825;
double r1351834 = x;
double r1351835 = z;
double r1351836 = r1351834 - r1351835;
double r1351837 = r1351833 * r1351836;
double r1351838 = r1351825 * r1351836;
double r1351839 = r1351832 * r1351838;
double r1351840 = r1351831 ? r1351837 : r1351839;
return r1351840;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.9 |
|---|---|
| Target | 2.9 |
| Herbie | 3.0 |
if y < -4.049647329143563e+27 or 1.1333992022375297e+48 < y Initial program 17.2
Simplified17.2
rmApplied associate-*r*4.4
if -4.049647329143563e+27 < y < 1.1333992022375297e+48Initial program 2.3
Simplified2.3
rmApplied associate-*r*7.5
rmApplied associate-*l*2.3
Final simplification3.0
herbie shell --seed 2020057
(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))