\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;z \le -3.021762082410781549036184893167115988887 \cdot 10^{147} \lor \neg \left(z \le 2.635494250498725666564973693616699303691 \cdot 10^{-102}\right):\\
\;\;\;\;\frac{\frac{x \cdot 2}{z}}{y - t}\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot 2}{y \cdot z + \left(-t\right) \cdot z}\\
\end{array}double f(double x, double y, double z, double t) {
double r476115 = x;
double r476116 = 2.0;
double r476117 = r476115 * r476116;
double r476118 = y;
double r476119 = z;
double r476120 = r476118 * r476119;
double r476121 = t;
double r476122 = r476121 * r476119;
double r476123 = r476120 - r476122;
double r476124 = r476117 / r476123;
return r476124;
}
double f(double x, double y, double z, double t) {
double r476125 = z;
double r476126 = -3.0217620824107815e+147;
bool r476127 = r476125 <= r476126;
double r476128 = 2.6354942504987257e-102;
bool r476129 = r476125 <= r476128;
double r476130 = !r476129;
bool r476131 = r476127 || r476130;
double r476132 = x;
double r476133 = 2.0;
double r476134 = r476132 * r476133;
double r476135 = r476134 / r476125;
double r476136 = y;
double r476137 = t;
double r476138 = r476136 - r476137;
double r476139 = r476135 / r476138;
double r476140 = r476136 * r476125;
double r476141 = -r476137;
double r476142 = r476141 * r476125;
double r476143 = r476140 + r476142;
double r476144 = r476134 / r476143;
double r476145 = r476131 ? r476139 : r476144;
return r476145;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.7 |
|---|---|
| Target | 2.0 |
| Herbie | 2.9 |
if z < -3.0217620824107815e+147 or 2.6354942504987257e-102 < z Initial program 10.2
Simplified8.4
rmApplied associate-/r*2.5
if -3.0217620824107815e+147 < z < 2.6354942504987257e-102Initial program 3.3
Simplified3.2
rmApplied sub-neg3.2
Applied distribute-lft-in3.3
Simplified3.3
Simplified3.3
Final simplification2.9
herbie shell --seed 2019208
(FPCore (x y z t)
:name "Linear.Projection:infinitePerspective from linear-1.19.1.3, A"
:precision binary64
:herbie-target
(if (< (/ (* x 2) (- (* y z) (* t z))) -2.559141628295061e-13) (* (/ x (* (- y t) z)) 2) (if (< (/ (* x 2) (- (* y z) (* t z))) 1.045027827330126e-269) (/ (* (/ x z) 2) (- y t)) (* (/ x (* (- y t) z)) 2)))
(/ (* x 2) (- (* y z) (* t z))))