\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot y}{z} \le -1.4526984435754821 \cdot 10^{-308}:\\
\;\;\;\;\frac{1}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{y}}\\
\mathbf{elif}\;\frac{x \cdot y}{z} \le 0.0:\\
\;\;\;\;\frac{x}{z} \cdot y\\
\mathbf{elif}\;\frac{x \cdot y}{z} \le 4.389265348889587 \cdot 10^{299}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{z} \cdot y\\
\end{array}double code(double x, double y, double z) {
return ((x * y) / z);
}
double code(double x, double y, double z) {
double VAR;
if ((((x * y) / z) <= -1.452698443575482e-308)) {
VAR = ((1.0 / (cbrt(z) * cbrt(z))) * (x / (cbrt(z) / y)));
} else {
double VAR_1;
if ((((x * y) / z) <= 0.0)) {
VAR_1 = ((x / z) * y);
} else {
double VAR_2;
if ((((x * y) / z) <= 4.389265348889587e+299)) {
VAR_2 = ((x * y) / z);
} else {
VAR_2 = ((x / z) * y);
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 5.8 |
|---|---|
| Target | 6.0 |
| Herbie | 2.2 |
if (/ (* x y) z) < -1.452698443575482e-308Initial program 4.1
rmApplied associate-/l*7.8
rmApplied *-un-lft-identity7.8
Applied add-cube-cbrt8.8
Applied times-frac8.8
Applied *-un-lft-identity8.8
Applied times-frac4.9
Simplified4.9
if -1.452698443575482e-308 < (/ (* x y) z) < 0.0 or 4.389265348889587e+299 < (/ (* x y) z) Initial program 15.4
rmApplied associate-/l*0.5
rmApplied associate-/r/0.5
if 0.0 < (/ (* x y) z) < 4.389265348889587e+299Initial program 0.5
Final simplification2.2
herbie shell --seed 2020079
(FPCore (x y z)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, A"
:precision binary64
:herbie-target
(if (< z -4.262230790519429e-138) (/ (* x y) z) (if (< z 1.7042130660650472e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))