\frac{\frac{1}{x}}{y \cdot \left(1 + z \cdot z\right)}\begin{array}{l}
\mathbf{if}\;x \leq -3.2719025730029142 \cdot 10^{+103} \lor \neg \left(x \leq 1.3704778646666072 \cdot 10^{+49}\right):\\
\;\;\;\;\frac{\frac{\frac{1}{x}}{y}}{1 + z \cdot z}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{y}}{x \cdot \left(1 + z \cdot z\right)}\\
\end{array}(FPCore (x y z) :precision binary64 (/ (/ 1.0 x) (* y (+ 1.0 (* z z)))))
(FPCore (x y z) :precision binary64 (if (or (<= x -3.2719025730029142e+103) (not (<= x 1.3704778646666072e+49))) (/ (/ (/ 1.0 x) y) (+ 1.0 (* z z))) (/ (/ 1.0 y) (* x (+ 1.0 (* z z))))))
double code(double x, double y, double z) {
return ((1.0 / x) / ((double) (y * ((double) (1.0 + ((double) (z * z)))))));
}
double code(double x, double y, double z) {
double tmp;
if (((x <= -3.2719025730029142e+103) || !(x <= 1.3704778646666072e+49))) {
tmp = (((1.0 / x) / y) / ((double) (1.0 + ((double) (z * z)))));
} else {
tmp = ((1.0 / y) / ((double) (x * ((double) (1.0 + ((double) (z * z)))))));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.3 |
|---|---|
| Target | 5.6 |
| Herbie | 5.1 |
if x < -3.27190257300291421e103 or 1.37047786466660717e49 < x Initial program 0.9
rmApplied associate-/r*_binary640.9
if -3.27190257300291421e103 < x < 1.37047786466660717e49Initial program 9.8
rmApplied clear-num_binary6410.0
Simplified9.9
rmApplied associate-/r*_binary649.8
rmApplied *-un-lft-identity_binary649.8
Applied times-frac_binary649.7
Applied associate-/l*_binary647.9
Simplified7.9
Final simplification5.1
herbie shell --seed 2020219
(FPCore (x y z)
:name "Statistics.Distribution.CauchyLorentz:$cdensity from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< (* y (+ 1.0 (* z z))) (- INFINITY)) (/ (/ 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)))))