\frac{x \cdot \left(y + z\right)}{z}\frac{\sqrt[3]{y + z} \cdot \sqrt[3]{y + z}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{y + z}}}double f(double x, double y, double z) {
double r519792 = x;
double r519793 = y;
double r519794 = z;
double r519795 = r519793 + r519794;
double r519796 = r519792 * r519795;
double r519797 = r519796 / r519794;
return r519797;
}
double f(double x, double y, double z) {
double r519798 = y;
double r519799 = z;
double r519800 = r519798 + r519799;
double r519801 = cbrt(r519800);
double r519802 = r519801 * r519801;
double r519803 = cbrt(r519799);
double r519804 = r519803 * r519803;
double r519805 = r519802 / r519804;
double r519806 = x;
double r519807 = r519803 / r519801;
double r519808 = r519806 / r519807;
double r519809 = r519805 * r519808;
return r519809;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 12.2 |
|---|---|
| Target | 3.0 |
| Herbie | 1.1 |
Initial program 12.2
rmApplied associate-/l*3.0
rmApplied add-cube-cbrt4.2
Applied add-cube-cbrt3.5
Applied times-frac3.5
Applied *-un-lft-identity3.5
Applied times-frac1.1
Simplified1.1
Final simplification1.1
herbie shell --seed 2019350
(FPCore (x y z)
:name "Numeric.SpecFunctions:choose from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(/ x (/ z (+ y z)))
(/ (* x (+ y z)) z))