\frac{\frac{1}{x}}{y \cdot \left(1 + z \cdot z\right)}\begin{array}{l}
\mathbf{if}\;z \le -3.388362437333713663189698402008227229826 \cdot 10^{192}:\\
\;\;\;\;\frac{\frac{1}{x}}{z \cdot \left(z \cdot y\right)}\\
\mathbf{elif}\;z \le 2189352106627621.75:\\
\;\;\;\;\frac{\frac{\frac{1}{x}}{1 + z \cdot z}}{y}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{x \cdot \left(z \cdot \left(z \cdot y\right)\right)}\\
\end{array}double f(double x, double y, double z) {
double r16985536 = 1.0;
double r16985537 = x;
double r16985538 = r16985536 / r16985537;
double r16985539 = y;
double r16985540 = z;
double r16985541 = r16985540 * r16985540;
double r16985542 = r16985536 + r16985541;
double r16985543 = r16985539 * r16985542;
double r16985544 = r16985538 / r16985543;
return r16985544;
}
double f(double x, double y, double z) {
double r16985545 = z;
double r16985546 = -3.3883624373337137e+192;
bool r16985547 = r16985545 <= r16985546;
double r16985548 = 1.0;
double r16985549 = x;
double r16985550 = r16985548 / r16985549;
double r16985551 = y;
double r16985552 = r16985545 * r16985551;
double r16985553 = r16985545 * r16985552;
double r16985554 = r16985550 / r16985553;
double r16985555 = 2189352106627621.8;
bool r16985556 = r16985545 <= r16985555;
double r16985557 = r16985545 * r16985545;
double r16985558 = r16985548 + r16985557;
double r16985559 = r16985550 / r16985558;
double r16985560 = r16985559 / r16985551;
double r16985561 = r16985549 * r16985553;
double r16985562 = r16985548 / r16985561;
double r16985563 = r16985556 ? r16985560 : r16985562;
double r16985564 = r16985547 ? r16985554 : r16985563;
return r16985564;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.2 |
|---|---|
| Target | 5.6 |
| Herbie | 4.3 |
if z < -3.3883624373337137e+192Initial program 14.6
rmApplied add-sqr-sqrt14.6
Applied associate-*r*14.6
Taylor expanded around inf 14.6
Simplified7.8
if -3.3883624373337137e+192 < z < 2189352106627621.8Initial program 2.8
rmApplied div-inv2.8
Applied times-frac2.7
rmApplied associate-*l/2.7
Simplified2.7
if 2189352106627621.8 < z Initial program 11.6
rmApplied div-inv11.6
Applied times-frac11.7
Taylor expanded around inf 11.7
Simplified7.1
Final simplification4.3
herbie shell --seed 2019170
(FPCore (x y z)
:name "Statistics.Distribution.CauchyLorentz:$cdensity from math-functions-0.1.5.2"
:herbie-target
(if (< (* y (+ 1.0 (* z z))) -inf.0) (/ (/ 1.0 y) (* (+ 1.0 (* z z)) x)) (if (< (* y (+ 1.0 (* z z))) 8.680743250567252e+305) (/ (/ 1.0 x) (* (+ 1.0 (* z z)) y)) (/ (/ 1.0 y) (* (+ 1.0 (* z z)) x))))
(/ (/ 1.0 x) (* y (+ 1.0 (* z z)))))