\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \frac{\frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{y} \cdot \sqrt[3]{y}}}}{\frac{1 + z}{\sqrt[3]{y}}}double f(double x, double y, double z) {
double r307671 = x;
double r307672 = y;
double r307673 = r307671 * r307672;
double r307674 = z;
double r307675 = r307674 * r307674;
double r307676 = 1.0;
double r307677 = r307674 + r307676;
double r307678 = r307675 * r307677;
double r307679 = r307673 / r307678;
return r307679;
}
double f(double x, double y, double z) {
double r307680 = x;
double r307681 = cbrt(r307680);
double r307682 = r307681 * r307681;
double r307683 = z;
double r307684 = r307682 / r307683;
double r307685 = y;
double r307686 = cbrt(r307685);
double r307687 = r307686 * r307686;
double r307688 = r307683 / r307687;
double r307689 = r307681 / r307688;
double r307690 = 1.0;
double r307691 = r307690 + r307683;
double r307692 = r307691 / r307686;
double r307693 = r307689 / r307692;
double r307694 = r307684 * r307693;
return r307694;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.0 |
|---|---|
| Target | 4.1 |
| Herbie | 1.4 |
Initial program 15.0
rmApplied associate-/l*13.2
Simplified11.6
rmApplied unpow211.6
Applied associate-*l*7.6
Simplified8.1
rmApplied add-cube-cbrt8.5
Applied times-frac4.6
rmApplied add-cube-cbrt4.7
Applied times-frac2.9
Applied associate-/r*1.4
Final simplification1.4
herbie shell --seed 2020042 +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))))