\frac{\frac{1}{x}}{y \cdot \left(1 + z \cdot z\right)}\begin{array}{l}
\mathbf{if}\;\left(1 + z \cdot z\right) \cdot y = -\infty:\\
\;\;\;\;\frac{1}{y} \cdot \left(\frac{\frac{\frac{1}{x}}{z}}{z} - \frac{\frac{\frac{1}{x}}{z \cdot z}}{z \cdot z} \cdot 1\right)\\
\mathbf{elif}\;\left(1 + z \cdot z\right) \cdot y \le 1.862479689839605283071532494157124524407 \cdot 10^{307}:\\
\;\;\;\;\frac{1}{\left(\left(1 + z \cdot z\right) \cdot y\right) \cdot x}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{y} \cdot \left(\frac{\frac{\frac{1}{x}}{z}}{z} - \frac{\frac{\frac{1}{x}}{z \cdot z}}{z \cdot z} \cdot 1\right)\\
\end{array}double f(double x, double y, double z) {
double r18567576 = 1.0;
double r18567577 = x;
double r18567578 = r18567576 / r18567577;
double r18567579 = y;
double r18567580 = z;
double r18567581 = r18567580 * r18567580;
double r18567582 = r18567576 + r18567581;
double r18567583 = r18567579 * r18567582;
double r18567584 = r18567578 / r18567583;
return r18567584;
}
double f(double x, double y, double z) {
double r18567585 = 1.0;
double r18567586 = z;
double r18567587 = r18567586 * r18567586;
double r18567588 = r18567585 + r18567587;
double r18567589 = y;
double r18567590 = r18567588 * r18567589;
double r18567591 = -inf.0;
bool r18567592 = r18567590 <= r18567591;
double r18567593 = r18567585 / r18567589;
double r18567594 = 1.0;
double r18567595 = x;
double r18567596 = r18567594 / r18567595;
double r18567597 = r18567596 / r18567586;
double r18567598 = r18567597 / r18567586;
double r18567599 = r18567596 / r18567587;
double r18567600 = r18567599 / r18567587;
double r18567601 = r18567600 * r18567585;
double r18567602 = r18567598 - r18567601;
double r18567603 = r18567593 * r18567602;
double r18567604 = 1.8624796898396053e+307;
bool r18567605 = r18567590 <= r18567604;
double r18567606 = r18567590 * r18567595;
double r18567607 = r18567585 / r18567606;
double r18567608 = r18567605 ? r18567607 : r18567603;
double r18567609 = r18567592 ? r18567603 : r18567608;
return r18567609;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.5 |
|---|---|
| Target | 5.7 |
| Herbie | 2.3 |
if (* y (+ 1.0 (* z z))) < -inf.0 or 1.8624796898396053e+307 < (* y (+ 1.0 (* z z))) Initial program 18.6
rmApplied div-inv18.6
Applied times-frac14.3
Taylor expanded around inf 14.4
Simplified5.7
if -inf.0 < (* y (+ 1.0 (* z z))) < 1.8624796898396053e+307Initial program 0.3
rmApplied div-inv0.3
Applied associate-/l*0.6
Simplified0.6
Final simplification2.3
herbie shell --seed 2019171
(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)))))