\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le 7.14147297711 \cdot 10^{-314}:\\
\;\;\;\;\left(\frac{x}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{\sqrt[3]{z} \cdot \sqrt[3]{z}}}\right) \cdot \frac{\sqrt[3]{y}}{\sqrt[3]{\sqrt[3]{z}}}\\
\mathbf{elif}\;x \cdot y \le 4.09863767648200739 \cdot 10^{175}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\end{array}double code(double x, double y, double z) {
return (((double) (x * y)) / z);
}
double code(double x, double y, double z) {
double VAR;
if ((((double) (x * y)) <= 7.1414729771084e-314)) {
VAR = ((double) (((double) ((x / ((double) (((double) cbrt(z)) * ((double) cbrt(z))))) * (((double) (((double) cbrt(y)) * ((double) cbrt(y)))) / ((double) cbrt(((double) (((double) cbrt(z)) * ((double) cbrt(z))))))))) * (((double) cbrt(y)) / ((double) cbrt(((double) cbrt(z)))))));
} else {
double VAR_1;
if ((((double) (x * y)) <= 4.0986376764820074e+175)) {
VAR_1 = (((double) (x * y)) / z);
} else {
VAR_1 = (x / (z / y));
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.3 |
|---|---|
| Target | 6.3 |
| Herbie | 2.6 |
if (* x y) < 7.14147297711e-314Initial program 8.2
rmApplied add-cube-cbrt8.9
Applied times-frac5.1
rmApplied add-cube-cbrt5.2
Applied cbrt-prod5.2
Applied add-cube-cbrt5.4
Applied times-frac5.4
Applied associate-*r*4.2
if 7.14147297711e-314 < (* x y) < 4.09863767648200739e175Initial program 0.2
if 4.09863767648200739e175 < (* x y) Initial program 21.6
rmApplied associate-/l*1.5
Final simplification2.6
herbie shell --seed 2020182
(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))