\frac{a1 \cdot a2}{b1 \cdot b2}\begin{array}{l}
\mathbf{if}\;b1 \cdot b2 \le -7.08416398127913 \cdot 10^{204}:\\
\;\;\;\;\frac{a1}{b1} \cdot \frac{a2}{b2}\\
\mathbf{elif}\;b1 \cdot b2 \le -4.09602219250447997 \cdot 10^{-100}:\\
\;\;\;\;\frac{\sqrt[3]{a1} \cdot \sqrt[3]{a1}}{b1 \cdot b2} \cdot \left(a2 \cdot \sqrt[3]{a1}\right)\\
\mathbf{elif}\;b1 \cdot b2 \le 2.2243731052410934 \cdot 10^{-300}:\\
\;\;\;\;\frac{1}{b1} \cdot \frac{a1}{\frac{b2}{a2}}\\
\mathbf{elif}\;b1 \cdot b2 \le 1.3444595232338455 \cdot 10^{228}:\\
\;\;\;\;\frac{a1}{\frac{b1 \cdot b2}{a2}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{a1 \cdot a2}{b1}}{b2}\\
\end{array}double code(double a1, double a2, double b1, double b2) {
return ((a1 * a2) / (b1 * b2));
}
double code(double a1, double a2, double b1, double b2) {
double VAR;
if (((b1 * b2) <= -7.08416398127913e+204)) {
VAR = ((a1 / b1) * (a2 / b2));
} else {
double VAR_1;
if (((b1 * b2) <= -4.09602219250448e-100)) {
VAR_1 = (((cbrt(a1) * cbrt(a1)) / (b1 * b2)) * (a2 * cbrt(a1)));
} else {
double VAR_2;
if (((b1 * b2) <= 2.2243731052410934e-300)) {
VAR_2 = ((1.0 / b1) * (a1 / (b2 / a2)));
} else {
double VAR_3;
if (((b1 * b2) <= 1.3444595232338455e+228)) {
VAR_3 = (a1 / ((b1 * b2) / a2));
} else {
VAR_3 = (((a1 * a2) / b1) / b2);
}
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 | 11.7 |
| Herbie | 5.6 |
if (* b1 b2) < -7.08416398127913e+204Initial program 14.9
rmApplied times-frac4.5
if -7.08416398127913e+204 < (* b1 b2) < -4.09602219250448e-100Initial program 3.9
rmApplied associate-/l*3.5
rmApplied div-inv3.6
Applied add-cube-cbrt4.3
Applied times-frac2.3
Simplified2.3
if -4.09602219250448e-100 < (* b1 b2) < 2.2243731052410934e-300Initial program 27.3
rmApplied associate-/l*28.4
rmApplied *-un-lft-identity28.4
Applied times-frac16.2
Applied *-un-lft-identity16.2
Applied times-frac11.6
Simplified11.6
if 2.2243731052410934e-300 < (* b1 b2) < 1.3444595232338455e+228Initial program 5.7
rmApplied associate-/l*5.1
if 1.3444595232338455e+228 < (* b1 b2) Initial program 16.8
rmApplied associate-/r*7.5
Final simplification5.6
herbie shell --seed 2020078 +o rules:numerics
(FPCore (a1 a2 b1 b2)
:name "Quotient of products"
:precision binary64
:herbie-target
(* (/ a1 b1) (/ a2 b2))
(/ (* a1 a2) (* b1 b2)))