\left(x \cdot y - z \cdot y\right) \cdot t
\begin{array}{l}
\mathbf{if}\;y \le -1.43405946159005389 \cdot 10^{-73}:\\
\;\;\;\;\left(\left(x - z\right) \cdot t\right) \cdot y\\
\mathbf{elif}\;y \le 8.82218830134679759 \cdot 10^{-152}:\\
\;\;\;\;t \cdot \left(y \cdot \left(x - z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x - z\right) \cdot \left(t \cdot y\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r633523 = x;
double r633524 = y;
double r633525 = r633523 * r633524;
double r633526 = z;
double r633527 = r633526 * r633524;
double r633528 = r633525 - r633527;
double r633529 = t;
double r633530 = r633528 * r633529;
return r633530;
}
double f(double x, double y, double z, double t) {
double r633531 = y;
double r633532 = -1.434059461590054e-73;
bool r633533 = r633531 <= r633532;
double r633534 = x;
double r633535 = z;
double r633536 = r633534 - r633535;
double r633537 = t;
double r633538 = r633536 * r633537;
double r633539 = r633538 * r633531;
double r633540 = 8.822188301346798e-152;
bool r633541 = r633531 <= r633540;
double r633542 = r633531 * r633536;
double r633543 = r633537 * r633542;
double r633544 = r633537 * r633531;
double r633545 = r633536 * r633544;
double r633546 = r633541 ? r633543 : r633545;
double r633547 = r633533 ? r633539 : r633546;
return r633547;
}




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 associate-*r*3.6
rmApplied *-commutative3.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 associate-*r*4.3
rmApplied *-commutative4.3
Final simplification3.5
herbie shell --seed 2020060
(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))