\frac{a1 \cdot a2}{b1 \cdot b2}\begin{array}{l}
\mathbf{if}\;\frac{a1 \cdot a2}{b1 \cdot b2} \leq -\infty:\\
\;\;\;\;\frac{\frac{a1}{b1}}{\frac{b2}{a2}}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \leq -4.125263103070185 \cdot 10^{-282}:\\
\;\;\;\;\frac{a1 \cdot a2}{b1 \cdot b2}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \leq 0:\\
\;\;\;\;\frac{\frac{a1}{b1} \cdot \frac{a2}{\sqrt[3]{b2} \cdot \sqrt[3]{b2}}}{\sqrt[3]{b2}}\\
\mathbf{elif}\;\frac{a1 \cdot a2}{b1 \cdot b2} \leq 4.355807106222864 \cdot 10^{+289}:\\
\;\;\;\;\frac{a1 \cdot a2}{b1 \cdot b2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{a1}{b1}}{\sqrt[3]{1}} \cdot \frac{a2}{b2}\\
\end{array}(FPCore (a1 a2 b1 b2) :precision binary64 (/ (* a1 a2) (* b1 b2)))
(FPCore (a1 a2 b1 b2)
:precision binary64
(if (<= (/ (* a1 a2) (* b1 b2)) (- INFINITY))
(/ (/ a1 b1) (/ b2 a2))
(if (<= (/ (* a1 a2) (* b1 b2)) -4.125263103070185e-282)
(/ (* a1 a2) (* b1 b2))
(if (<= (/ (* a1 a2) (* b1 b2)) 0.0)
(/ (* (/ a1 b1) (/ a2 (* (cbrt b2) (cbrt b2)))) (cbrt b2))
(if (<= (/ (* a1 a2) (* b1 b2)) 4.355807106222864e+289)
(/ (* a1 a2) (* b1 b2))
(* (/ (/ a1 b1) (cbrt 1.0)) (/ a2 b2)))))))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 tmp;
if (((a1 * a2) / (b1 * b2)) <= -((double) INFINITY)) {
tmp = (a1 / b1) / (b2 / a2);
} else if (((a1 * a2) / (b1 * b2)) <= -4.125263103070185e-282) {
tmp = (a1 * a2) / (b1 * b2);
} else if (((a1 * a2) / (b1 * b2)) <= 0.0) {
tmp = ((a1 / b1) * (a2 / (cbrt(b2) * cbrt(b2)))) / cbrt(b2);
} else if (((a1 * a2) / (b1 * b2)) <= 4.355807106222864e+289) {
tmp = (a1 * a2) / (b1 * b2);
} else {
tmp = ((a1 / b1) / cbrt(1.0)) * (a2 / b2);
}
return tmp;
}




Bits error versus a1




Bits error versus a2




Bits error versus b1




Bits error versus b2
Results
| Original | 11.6 |
|---|---|
| Target | 11.6 |
| Herbie | 2.5 |
if (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) < -inf.0Initial program 64.0
rmApplied associate-/r*_binary64_309135.0
Simplified18.6
rmApplied add-cube-cbrt_binary64_318219.4
Applied associate-/r*_binary64_309119.4
Simplified14.2
rmApplied associate-/l*_binary64_309212.6
Simplified11.5
if -inf.0 < (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) < -4.1252631030701847e-282 or 0.0 < (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) < 4.3558071062228637e289Initial program 0.7
if -4.1252631030701847e-282 < (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) < 0.0Initial program 13.6
rmApplied associate-/r*_binary64_30916.7
Simplified3.8
rmApplied add-cube-cbrt_binary64_31824.0
Applied associate-/r*_binary64_30914.0
Simplified3.2
if 4.3558071062228637e289 < (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) Initial program 58.9
rmApplied associate-/r*_binary64_309147.0
Simplified14.8
rmApplied add-cube-cbrt_binary64_318215.6
Applied associate-/r*_binary64_309115.6
Simplified9.2
rmApplied *-un-lft-identity_binary64_31479.2
Applied cbrt-prod_binary64_31789.2
Applied times-frac_binary64_31539.5
Simplified8.7
Final simplification2.5
herbie shell --seed 2021091
(FPCore (a1 a2 b1 b2)
:name "Quotient of products"
:precision binary64
:herbie-target
(* (/ a1 b1) (/ a2 b2))
(/ (* a1 a2) (* b1 b2)))