\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} = -\infty:\\
\;\;\;\;\frac{t}{b} - \frac{a}{b}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \le -8.00947989807014 \cdot 10^{-223}:\\
\;\;\;\;\frac{\mathsf{fma}\left(x, y, z \cdot \left(t - a\right)\right) + z \cdot \mathsf{fma}\left(-\sqrt[3]{a}, \sqrt[3]{a} \cdot \sqrt[3]{a}, \sqrt[3]{a} \cdot \left(\sqrt[3]{a} \cdot \left(\sqrt[3]{\sqrt[3]{a} \cdot \sqrt[3]{a}} \cdot \sqrt[3]{\sqrt[3]{a}}\right)\right)\right)}{y + z \cdot \left(b - y\right)}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \le -0.0:\\
\;\;\;\;\frac{t}{b} - \frac{a}{b}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \le 1.37529062950492253 \cdot 10^{304}:\\
\;\;\;\;\frac{1}{\frac{\mathsf{fma}\left(z, b - y, y\right)}{\mathsf{fma}\left(x, y, z \cdot \left(t - a\right)\right)}}\\
\mathbf{else}:\\
\;\;\;\;\frac{t}{b} - \frac{a}{b}\\
\end{array}double code(double x, double y, double z, double t, double a, double b) {
return ((double) (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y))))))));
}
double code(double x, double y, double z, double t, double a, double b) {
double VAR;
if ((((double) (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y)))))))) <= -inf.0)) {
VAR = ((double) (((double) (t / b)) - ((double) (a / b))));
} else {
double VAR_1;
if ((((double) (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y)))))))) <= -8.00947989807014e-223)) {
VAR_1 = ((double) (((double) (((double) fma(x, y, ((double) (z * ((double) (t - a)))))) + ((double) (z * ((double) fma(((double) -(((double) cbrt(a)))), ((double) (((double) cbrt(a)) * ((double) cbrt(a)))), ((double) (((double) cbrt(a)) * ((double) (((double) cbrt(a)) * ((double) (((double) cbrt(((double) (((double) cbrt(a)) * ((double) cbrt(a)))))) * ((double) cbrt(((double) cbrt(a)))))))))))))))) / ((double) (y + ((double) (z * ((double) (b - y))))))));
} else {
double VAR_2;
if ((((double) (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y)))))))) <= -0.0)) {
VAR_2 = ((double) (((double) (t / b)) - ((double) (a / b))));
} else {
double VAR_3;
if ((((double) (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y)))))))) <= 1.3752906295049225e+304)) {
VAR_3 = ((double) (1.0 / ((double) (((double) fma(z, ((double) (b - y)), y)) / ((double) fma(x, y, ((double) (z * ((double) (t - a))))))))));
} else {
VAR_3 = ((double) (((double) (t / b)) - ((double) (a / b))));
}
VAR_2 = VAR_3;
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
Results
| Original | 23.4 |
|---|---|
| Target | 18.1 |
| Herbie | 16.4 |
if (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) < -inf.0 or -8.00947989807014e-223 < (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) < -0.0 or 1.3752906295049225e+304 < (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) Initial program 57.9
rmApplied clear-num57.9
Simplified57.9
Taylor expanded around inf 40.1
if -inf.0 < (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) < -8.00947989807014e-223Initial program 0.3
rmApplied add-cube-cbrt0.6
Applied add-sqr-sqrt31.6
Applied prod-diff31.6
Applied distribute-lft-in31.6
Applied associate-+r+31.6
Simplified0.3
rmApplied add-cube-cbrt0.4
Applied cbrt-prod0.5
if -0.0 < (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) < 1.3752906295049225e+304Initial program 0.3
rmApplied clear-num0.5
Simplified0.5
Final simplification16.4
herbie shell --seed 2020121 +o rules:numerics
(FPCore (x y z t a b)
:name "Development.Shake.Progress:decay from shake-0.15.5"
:precision binary64
:herbie-target
(- (/ (+ (* z t) (* y x)) (+ y (* z (- b y)))) (/ a (+ (- b y) (/ y z))))
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))