\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1.0\right)}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -7.4960041203550645 \cdot 10^{+289}:\\
\;\;\;\;\left(\frac{y}{z + 1.0} \cdot \frac{1}{z}\right) \cdot \left(\frac{1}{z} \cdot x\right)\\
\mathbf{elif}\;x \cdot y \le -4.94154134334905 \cdot 10^{-156}:\\
\;\;\;\;\frac{\frac{x \cdot y}{z \cdot z}}{z + 1.0}\\
\mathbf{elif}\;x \cdot y \le 1.0218548433569062 \cdot 10^{-145}:\\
\;\;\;\;\left(\frac{y}{z + 1.0} \cdot \frac{1}{z}\right) \cdot \left(\frac{1}{z} \cdot x\right)\\
\mathbf{elif}\;x \cdot y \le 8.072639718356034 \cdot 10^{+159}:\\
\;\;\;\;\frac{\frac{x \cdot y}{z \cdot z}}{z + 1.0}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{y}{z + 1.0} \cdot \frac{1}{z}\right) \cdot \left(\frac{1}{z} \cdot x\right)\\
\end{array}double f(double x, double y, double z) {
double r6289687 = x;
double r6289688 = y;
double r6289689 = r6289687 * r6289688;
double r6289690 = z;
double r6289691 = r6289690 * r6289690;
double r6289692 = 1.0;
double r6289693 = r6289690 + r6289692;
double r6289694 = r6289691 * r6289693;
double r6289695 = r6289689 / r6289694;
return r6289695;
}
double f(double x, double y, double z) {
double r6289696 = x;
double r6289697 = y;
double r6289698 = r6289696 * r6289697;
double r6289699 = -7.4960041203550645e+289;
bool r6289700 = r6289698 <= r6289699;
double r6289701 = z;
double r6289702 = 1.0;
double r6289703 = r6289701 + r6289702;
double r6289704 = r6289697 / r6289703;
double r6289705 = 1.0;
double r6289706 = r6289705 / r6289701;
double r6289707 = r6289704 * r6289706;
double r6289708 = r6289706 * r6289696;
double r6289709 = r6289707 * r6289708;
double r6289710 = -4.94154134334905e-156;
bool r6289711 = r6289698 <= r6289710;
double r6289712 = r6289701 * r6289701;
double r6289713 = r6289698 / r6289712;
double r6289714 = r6289713 / r6289703;
double r6289715 = 1.0218548433569062e-145;
bool r6289716 = r6289698 <= r6289715;
double r6289717 = 8.072639718356034e+159;
bool r6289718 = r6289698 <= r6289717;
double r6289719 = r6289718 ? r6289714 : r6289709;
double r6289720 = r6289716 ? r6289709 : r6289719;
double r6289721 = r6289711 ? r6289714 : r6289720;
double r6289722 = r6289700 ? r6289709 : r6289721;
return r6289722;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 13.9 |
|---|---|
| Target | 3.9 |
| Herbie | 1.8 |
if (* x y) < -7.4960041203550645e+289 or -4.94154134334905e-156 < (* x y) < 1.0218548433569062e-145 or 8.072639718356034e+159 < (* x y) Initial program 22.5
rmApplied times-frac13.6
rmApplied *-un-lft-identity13.6
Applied times-frac5.1
Applied associate-*l*2.6
rmApplied div-inv2.6
Applied associate-*l*3.0
rmApplied associate-*r*1.2
if -7.4960041203550645e+289 < (* x y) < -4.94154134334905e-156 or 1.0218548433569062e-145 < (* x y) < 8.072639718356034e+159Initial program 5.0
rmApplied associate-/r*2.5
Final simplification1.8
herbie shell --seed 2019156
(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 z)) x) z))
(/ (* x y) (* (* z z) (+ z 1.0))))