\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\begin{array}{l}
\mathbf{if}\;x \cdot y \le 1.196151169485302342273884046453796637229 \cdot 10^{-315}:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \left(\left(\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}\right) \cdot \sqrt[3]{\sqrt[3]{x}}\right)}{z} \cdot \left(\frac{\sqrt[3]{x}}{z} \cdot \frac{y}{z + 1}\right)\\
\mathbf{elif}\;x \cdot y \le 7.947895648765829788288380988796806250372 \cdot 10^{212}:\\
\;\;\;\;\frac{\frac{x \cdot y}{z}}{z \cdot \left(z + 1\right)}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{z} \cdot \frac{\sqrt[3]{x}}{z}\right) \cdot \frac{y}{z + 1}\\
\end{array}double f(double x, double y, double z) {
double r192532 = x;
double r192533 = y;
double r192534 = r192532 * r192533;
double r192535 = z;
double r192536 = r192535 * r192535;
double r192537 = 1.0;
double r192538 = r192535 + r192537;
double r192539 = r192536 * r192538;
double r192540 = r192534 / r192539;
return r192540;
}
double f(double x, double y, double z) {
double r192541 = x;
double r192542 = y;
double r192543 = r192541 * r192542;
double r192544 = 1.1961511694853e-315;
bool r192545 = r192543 <= r192544;
double r192546 = cbrt(r192541);
double r192547 = cbrt(r192546);
double r192548 = r192547 * r192547;
double r192549 = r192548 * r192547;
double r192550 = r192546 * r192549;
double r192551 = z;
double r192552 = r192550 / r192551;
double r192553 = r192546 / r192551;
double r192554 = 1.0;
double r192555 = r192551 + r192554;
double r192556 = r192542 / r192555;
double r192557 = r192553 * r192556;
double r192558 = r192552 * r192557;
double r192559 = 7.94789564876583e+212;
bool r192560 = r192543 <= r192559;
double r192561 = r192543 / r192551;
double r192562 = r192551 * r192555;
double r192563 = r192561 / r192562;
double r192564 = r192546 * r192546;
double r192565 = r192564 / r192551;
double r192566 = r192565 * r192553;
double r192567 = r192566 * r192556;
double r192568 = r192560 ? r192563 : r192567;
double r192569 = r192545 ? r192558 : r192568;
return r192569;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 14.6 |
|---|---|
| Target | 4.0 |
| Herbie | 1.1 |
if (* x y) < 1.1961511694853e-315Initial program 16.0
rmApplied times-frac11.6
rmApplied add-cube-cbrt11.9
Applied times-frac6.4
Applied associate-*l*1.2
rmApplied add-cube-cbrt1.4
if 1.1961511694853e-315 < (* x y) < 7.94789564876583e+212Initial program 6.9
rmApplied times-frac9.7
rmApplied add-cube-cbrt10.1
Applied times-frac7.6
Applied associate-*l*1.5
rmApplied associate-*r/1.4
Applied frac-times0.9
Simplified0.4
if 7.94789564876583e+212 < (* x y) Initial program 41.0
rmApplied times-frac13.3
rmApplied add-cube-cbrt13.7
Applied times-frac1.7
Final simplification1.1
herbie shell --seed 2019323
(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))))