\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \left(\frac{y}{z + 1} \cdot \frac{\sqrt[3]{x}}{z}\right)double f(double x, double y, double z) {
double r17184610 = x;
double r17184611 = y;
double r17184612 = r17184610 * r17184611;
double r17184613 = z;
double r17184614 = r17184613 * r17184613;
double r17184615 = 1.0;
double r17184616 = r17184613 + r17184615;
double r17184617 = r17184614 * r17184616;
double r17184618 = r17184612 / r17184617;
return r17184618;
}
double f(double x, double y, double z) {
double r17184619 = x;
double r17184620 = cbrt(r17184619);
double r17184621 = r17184620 * r17184620;
double r17184622 = z;
double r17184623 = r17184621 / r17184622;
double r17184624 = y;
double r17184625 = 1.0;
double r17184626 = r17184622 + r17184625;
double r17184627 = r17184624 / r17184626;
double r17184628 = r17184620 / r17184622;
double r17184629 = r17184627 * r17184628;
double r17184630 = r17184623 * r17184629;
return r17184630;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.2 |
|---|---|
| Target | 4.2 |
| Herbie | 1.3 |
Initial program 15.2
rmApplied times-frac11.4
rmApplied add-cube-cbrt11.8
Applied times-frac6.5
Applied associate-*l*1.3
Final simplification1.3
herbie shell --seed 2019200
(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))))