\frac{a1 \cdot a2}{b1 \cdot b2}\begin{array}{l}
\mathbf{if}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le -1.650144306002728 \cdot 10^{227}:\\
\;\;\;\;\frac{a1}{b1} \cdot \frac{a2}{b2}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le -6.71929 \cdot 10^{-322}:\\
\;\;\;\;\frac{\frac{a1 \cdot a2}{b1}}{b2}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le 3.7028333602929563 \cdot 10^{-281}:\\
\;\;\;\;\frac{a1 \cdot \frac{a2}{b2}}{b1}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le 6.81317694408275437 \cdot 10^{-90}:\\
\;\;\;\;\left(a1 \cdot a2\right) \cdot \frac{1}{b1 \cdot b2}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le 650281902230843.375:\\
\;\;\;\;\frac{a1}{\frac{b1 \cdot b2}{a2}}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \le 1.8321206570887691 \cdot 10^{223}:\\
\;\;\;\;\left(a1 \cdot a2\right) \cdot \frac{1}{b1 \cdot b2}\\
\mathbf{else}:\\
\;\;\;\;\frac{a1}{b1} \cdot \frac{a2}{b2}\\
\end{array}double code(double a1, double a2, double b1, double b2) {
return ((double) (((double) (a1 * a2)) / ((double) (b1 * b2))));
}
double code(double a1, double a2, double b1, double b2) {
double VAR;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= -1.650144306002728e+227)) {
VAR = ((double) (((double) (a1 / b1)) * ((double) (a2 / b2))));
} else {
double VAR_1;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= -6.719292783441e-322)) {
VAR_1 = ((double) (((double) (((double) (a1 * a2)) / b1)) / b2));
} else {
double VAR_2;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= 3.702833360292956e-281)) {
VAR_2 = ((double) (((double) (a1 * ((double) (a2 / b2)))) / b1));
} else {
double VAR_3;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= 6.813176944082754e-90)) {
VAR_3 = ((double) (((double) (a1 * a2)) * ((double) (1.0 / ((double) (b1 * b2))))));
} else {
double VAR_4;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= 650281902230843.4)) {
VAR_4 = ((double) (a1 / ((double) (((double) (b1 * b2)) / a2))));
} else {
double VAR_5;
if ((((double) (((double) (a1 * a2)) / ((double) (b1 * b2)))) <= 1.832120657088769e+223)) {
VAR_5 = ((double) (((double) (a1 * a2)) * ((double) (1.0 / ((double) (b1 * b2))))));
} else {
VAR_5 = ((double) (((double) (a1 / b1)) * ((double) (a2 / b2))));
}
VAR_4 = VAR_5;
}
VAR_3 = VAR_4;
}
VAR_2 = VAR_3;
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus a1




Bits error versus a2




Bits error versus b1




Bits error versus b2
Results
| Original | 11.2 |
|---|---|
| Target | 10.8 |
| Herbie | 5.5 |
if (/ (* a1 a2) (* b1 b2)) < -1.650144306002728e227 or 1.8321206570887691e223 < (/ (* a1 a2) (* b1 b2)) Initial program 42.1
rmApplied times-frac12.6
if -1.650144306002728e227 < (/ (* a1 a2) (* b1 b2)) < -6.71929e-322Initial program 0.9
rmApplied associate-/r*7.0
if -6.71929e-322 < (/ (* a1 a2) (* b1 b2)) < 3.7028333602929563e-281Initial program 13.0
rmApplied times-frac3.2
rmApplied associate-*l/4.2
if 3.7028333602929563e-281 < (/ (* a1 a2) (* b1 b2)) < 6.81317694408275437e-90 or 650281902230843.375 < (/ (* a1 a2) (* b1 b2)) < 1.8321206570887691e223Initial program 0.7
rmApplied div-inv1.0
if 6.81317694408275437e-90 < (/ (* a1 a2) (* b1 b2)) < 650281902230843.375Initial program 0.7
rmApplied associate-/l*1.9
Final simplification5.5
herbie shell --seed 2020162
(FPCore (a1 a2 b1 b2)
:name "Quotient of products"
:precision binary64
:herbie-target
(* (/ a1 b1) (/ a2 b2))
(/ (* a1 a2) (* b1 b2)))