\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\left(\sqrt[3]{\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \left(\frac{\sqrt[3]{x}}{z} \cdot \frac{y}{z + 1}\right)} \cdot \sqrt[3]{\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \left(\frac{\sqrt[3]{x}}{z} \cdot \frac{y}{z + 1}\right)}\right) \cdot \sqrt[3]{\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \left(\frac{\sqrt[3]{x}}{z} \cdot \frac{y}{z + 1}\right)}double f(double x, double y, double z) {
double r304675 = x;
double r304676 = y;
double r304677 = r304675 * r304676;
double r304678 = z;
double r304679 = r304678 * r304678;
double r304680 = 1.0;
double r304681 = r304678 + r304680;
double r304682 = r304679 * r304681;
double r304683 = r304677 / r304682;
return r304683;
}
double f(double x, double y, double z) {
double r304684 = x;
double r304685 = cbrt(r304684);
double r304686 = r304685 * r304685;
double r304687 = z;
double r304688 = r304686 / r304687;
double r304689 = r304685 / r304687;
double r304690 = y;
double r304691 = 1.0;
double r304692 = r304687 + r304691;
double r304693 = r304690 / r304692;
double r304694 = r304689 * r304693;
double r304695 = r304688 * r304694;
double r304696 = cbrt(r304695);
double r304697 = r304696 * r304696;
double r304698 = r304697 * r304696;
return r304698;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 14.8 |
|---|---|
| Target | 3.9 |
| Herbie | 1.4 |
Initial program 14.8
rmApplied times-frac10.8
rmApplied add-cube-cbrt11.2
Applied times-frac6.4
Applied associate-*l*1.2
rmApplied add-cube-cbrt1.4
Final simplification1.4
herbie shell --seed 2020036 +o rules:numerics
(FPCore (x y z)
:name "Statistics.Distribution.Beta:$cvariance from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< z 249.6182814532307) (/ (* y (/ x z)) (+ z (* z z))) (/ (* (/ (/ y z) (+ 1 z)) x) z))
(/ (* x y) (* (* z z) (+ z 1))))