\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\frac{\frac{\sqrt[3]{x}}{\sqrt[3]{z}}}{1 + z} \cdot \left(\left(\frac{\sqrt[3]{x}}{\sqrt[3]{z}} \cdot \frac{\sqrt[3]{x}}{\sqrt[3]{z}}\right) \cdot \frac{y}{z}\right)double f(double x, double y, double z) {
double r276906 = x;
double r276907 = y;
double r276908 = r276906 * r276907;
double r276909 = z;
double r276910 = r276909 * r276909;
double r276911 = 1.0;
double r276912 = r276909 + r276911;
double r276913 = r276910 * r276912;
double r276914 = r276908 / r276913;
return r276914;
}
double f(double x, double y, double z) {
double r276915 = x;
double r276916 = cbrt(r276915);
double r276917 = z;
double r276918 = cbrt(r276917);
double r276919 = r276916 / r276918;
double r276920 = 1.0;
double r276921 = r276920 + r276917;
double r276922 = r276919 / r276921;
double r276923 = r276919 * r276919;
double r276924 = y;
double r276925 = r276924 / r276917;
double r276926 = r276923 * r276925;
double r276927 = r276922 * r276926;
return r276927;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 14.9 |
|---|---|
| Target | 3.9 |
| Herbie | 2.0 |
Initial program 14.9
Simplified3.2
rmApplied *-un-lft-identity3.2
Applied add-cube-cbrt3.7
Applied add-cube-cbrt3.9
Applied times-frac3.9
Applied times-frac3.9
Applied associate-*r*2.0
Simplified2.0
Final simplification2.0
herbie shell --seed 2019179
(FPCore (x y z)
:name "Statistics.Distribution.Beta:$cvariance from math-functions-0.1.5.2"
:herbie-target
(if (< z 249.6182814532307) (/ (* y (/ x z)) (+ z (* z z))) (/ (* (/ (/ y z) (+ 1.0 z)) x) z))
(/ (* x y) (* (* z z) (+ z 1.0))))