\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\frac{\sqrt[3]{x}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \left(\left({\left(\sqrt[3]{\frac{\sqrt[3]{x}}{z}}\right)}^{3} \cdot \frac{y}{z + 1}\right) \cdot \frac{\sqrt[3]{x}}{\sqrt[3]{z}}\right)double f(double x, double y, double z) {
double r388512 = x;
double r388513 = y;
double r388514 = r388512 * r388513;
double r388515 = z;
double r388516 = r388515 * r388515;
double r388517 = 1.0;
double r388518 = r388515 + r388517;
double r388519 = r388516 * r388518;
double r388520 = r388514 / r388519;
return r388520;
}
double f(double x, double y, double z) {
double r388521 = x;
double r388522 = cbrt(r388521);
double r388523 = z;
double r388524 = cbrt(r388523);
double r388525 = r388524 * r388524;
double r388526 = r388522 / r388525;
double r388527 = r388522 / r388523;
double r388528 = cbrt(r388527);
double r388529 = 3.0;
double r388530 = pow(r388528, r388529);
double r388531 = y;
double r388532 = 1.0;
double r388533 = r388523 + r388532;
double r388534 = r388531 / r388533;
double r388535 = r388530 * r388534;
double r388536 = r388522 / r388524;
double r388537 = r388535 * r388536;
double r388538 = r388526 * r388537;
return r388538;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.7 |
|---|---|
| Target | 4.4 |
| Herbie | 1.5 |
Initial program 15.7
rmApplied times-frac11.8
rmApplied add-cube-cbrt12.1
Applied times-frac7.0
Applied associate-*l*1.3
rmApplied add-cube-cbrt1.5
Applied associate-*l*1.5
rmApplied add-cube-cbrt1.6
Applied times-frac1.6
Applied associate-*l*1.5
Simplified1.5
Final simplification1.5
herbie shell --seed 2020047
(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))))