\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -3.48711103202709677 \cdot 10^{146}:\\
\;\;\;\;\left(x \cdot y\right) \cdot -1\\
\mathbf{elif}\;z \le -1.56344281963474788 \cdot 10^{-286}:\\
\;\;\;\;x \cdot \left(y \cdot \frac{z}{\sqrt{z \cdot z - t \cdot a}}\right)\\
\mathbf{elif}\;z \le 1.8216614650284523 \cdot 10^{-230}:\\
\;\;\;\;1 \cdot \frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\\
\mathbf{elif}\;z \le 2.966256665740778 \cdot 10^{111}:\\
\;\;\;\;\left(x \cdot y\right) \cdot \frac{z}{\sqrt{z \cdot z - t \cdot a}}\\
\mathbf{else}:\\
\;\;\;\;x \cdot y\\
\end{array}double code(double x, double y, double z, double t, double a) {
return (((x * y) * z) / sqrt(((z * z) - (t * a))));
}
double code(double x, double y, double z, double t, double a) {
double temp;
if ((z <= -3.4871110320270968e+146)) {
temp = ((x * y) * -1.0);
} else {
double temp_1;
if ((z <= -1.5634428196347479e-286)) {
temp_1 = (x * (y * (z / sqrt(((z * z) - (t * a))))));
} else {
double temp_2;
if ((z <= 1.8216614650284523e-230)) {
temp_2 = (1.0 * (((x * y) * z) / sqrt(((z * z) - (t * a)))));
} else {
double temp_3;
if ((z <= 2.966256665740778e+111)) {
temp_3 = ((x * y) * (z / sqrt(((z * z) - (t * a)))));
} else {
temp_3 = (x * y);
}
temp_2 = temp_3;
}
temp_1 = temp_2;
}
temp = temp_1;
}
return temp;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.5 |
|---|---|
| Target | 7.6 |
| Herbie | 6.1 |
if z < -3.4871110320270968e+146Initial program 51.7
rmApplied *-un-lft-identity51.7
Applied sqrt-prod51.7
Applied times-frac50.9
Simplified50.9
Taylor expanded around -inf 1.4
if -3.4871110320270968e+146 < z < -1.5634428196347479e-286Initial program 10.9
rmApplied *-un-lft-identity10.9
Applied sqrt-prod10.9
Applied times-frac8.6
Simplified8.6
rmApplied associate-*l*8.4
if -1.5634428196347479e-286 < z < 1.8216614650284523e-230Initial program 16.5
rmApplied add-sqr-sqrt16.5
Applied sqrt-prod16.6
Applied times-frac17.6
rmApplied *-un-lft-identity17.6
Applied associate-*l*17.6
Simplified16.5
if 1.8216614650284523e-230 < z < 2.966256665740778e+111Initial program 8.9
rmApplied *-un-lft-identity8.9
Applied sqrt-prod8.9
Applied times-frac6.7
Simplified6.7
if 2.966256665740778e+111 < z Initial program 44.7
Taylor expanded around inf 2.5
Final simplification6.1
herbie shell --seed 2020049 +o rules:numerics
(FPCore (x y z t a)
:name "Statistics.Math.RootFinding:ridders from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< z -3.1921305903852764e+46) (- (* y x)) (if (< z 5.976268120920894e+90) (/ (* x z) (/ (sqrt (- (* z z) (* a t))) y)) (* y x)))
(/ (* (* x y) z) (sqrt (- (* z z) (* t a)))))