\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\left(\left(\frac{\sqrt[3]{x}}{\sqrt[3]{z}} \cdot \frac{y}{1 + z}\right) \cdot \frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{z} \cdot \sqrt[3]{z}}\right) \cdot \frac{1}{z}double f(double x, double y, double z) {
double r17640016 = x;
double r17640017 = y;
double r17640018 = r17640016 * r17640017;
double r17640019 = z;
double r17640020 = r17640019 * r17640019;
double r17640021 = 1.0;
double r17640022 = r17640019 + r17640021;
double r17640023 = r17640020 * r17640022;
double r17640024 = r17640018 / r17640023;
return r17640024;
}
double f(double x, double y, double z) {
double r17640025 = x;
double r17640026 = cbrt(r17640025);
double r17640027 = z;
double r17640028 = cbrt(r17640027);
double r17640029 = r17640026 / r17640028;
double r17640030 = y;
double r17640031 = 1.0;
double r17640032 = r17640031 + r17640027;
double r17640033 = r17640030 / r17640032;
double r17640034 = r17640029 * r17640033;
double r17640035 = r17640026 * r17640026;
double r17640036 = r17640028 * r17640028;
double r17640037 = r17640035 / r17640036;
double r17640038 = r17640034 * r17640037;
double r17640039 = 1.0;
double r17640040 = r17640039 / r17640027;
double r17640041 = r17640038 * r17640040;
return r17640041;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 14.6 |
|---|---|
| Target | 3.9 |
| Herbie | 2.0 |
Initial program 14.6
rmApplied times-frac10.9
rmApplied *-un-lft-identity10.9
Applied times-frac5.9
Applied associate-*l*2.5
rmApplied add-cube-cbrt3.0
Applied add-cube-cbrt3.2
Applied times-frac3.2
Applied associate-*l*2.0
Final simplification2.0
herbie shell --seed 2019172
(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))))