\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 r22330644 = x;
double r22330645 = y;
double r22330646 = r22330644 * r22330645;
double r22330647 = z;
double r22330648 = r22330647 * r22330647;
double r22330649 = 1.0;
double r22330650 = r22330647 + r22330649;
double r22330651 = r22330648 * r22330650;
double r22330652 = r22330646 / r22330651;
return r22330652;
}
double f(double x, double y, double z) {
double r22330653 = x;
double r22330654 = cbrt(r22330653);
double r22330655 = r22330654 * r22330654;
double r22330656 = z;
double r22330657 = r22330655 / r22330656;
double r22330658 = y;
double r22330659 = 1.0;
double r22330660 = r22330656 + r22330659;
double r22330661 = r22330658 / r22330660;
double r22330662 = r22330654 / r22330656;
double r22330663 = r22330661 * r22330662;
double r22330664 = r22330657 * r22330663;
return r22330664;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.1 |
|---|---|
| Target | 4.0 |
| Herbie | 1.1 |
Initial program 15.1
rmApplied times-frac11.2
rmApplied add-cube-cbrt11.6
Applied times-frac6.5
Applied associate-*l*1.1
Final simplification1.1
herbie shell --seed 2019171
(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))))