\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 r379298 = x;
double r379299 = y;
double r379300 = r379298 * r379299;
double r379301 = z;
double r379302 = r379301 * r379301;
double r379303 = 1.0;
double r379304 = r379301 + r379303;
double r379305 = r379302 * r379304;
double r379306 = r379300 / r379305;
return r379306;
}
double f(double x, double y, double z) {
double r379307 = x;
double r379308 = cbrt(r379307);
double r379309 = r379308 * r379308;
double r379310 = z;
double r379311 = r379309 / r379310;
double r379312 = r379308 / r379310;
double r379313 = y;
double r379314 = 1.0;
double r379315 = r379310 + r379314;
double r379316 = r379313 / r379315;
double r379317 = r379312 * r379316;
double r379318 = r379311 * r379317;
double r379319 = cbrt(r379318);
double r379320 = r379319 * r379319;
double r379321 = r379320 * r379319;
return r379321;
}




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
(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))))