\frac{\frac{1}{x}}{y \cdot \left(1 + z \cdot z\right)}\frac{\frac{1}{1}}{\left(1 + z \cdot z\right) \cdot \left(x \cdot y\right)}double f(double x, double y, double z) {
double r425135 = 1.0;
double r425136 = x;
double r425137 = r425135 / r425136;
double r425138 = y;
double r425139 = z;
double r425140 = r425139 * r425139;
double r425141 = r425135 + r425140;
double r425142 = r425138 * r425141;
double r425143 = r425137 / r425142;
return r425143;
}
double f(double x, double y, double z) {
double r425144 = 1.0;
double r425145 = 1.0;
double r425146 = r425144 / r425145;
double r425147 = z;
double r425148 = r425147 * r425147;
double r425149 = r425144 + r425148;
double r425150 = x;
double r425151 = y;
double r425152 = r425150 * r425151;
double r425153 = r425149 * r425152;
double r425154 = r425146 / r425153;
return r425154;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.6 |
|---|---|
| Target | 5.9 |
| Herbie | 6.6 |
Initial program 6.6
rmApplied associate-/r*6.4
Simplified6.4
rmApplied *-un-lft-identity6.4
Applied div-inv6.4
Applied times-frac6.4
Applied associate-/l*6.7
Simplified6.6
Final simplification6.6
herbie shell --seed 2019362
(FPCore (x y z)
:name "Statistics.Distribution.CauchyLorentz:$cdensity from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< (* y (+ 1 (* z z))) #f) (/ (/ 1 y) (* (+ 1 (* z z)) x)) (if (< (* y (+ 1 (* z z))) 8.680743250567252e+305) (/ (/ 1 x) (* (+ 1 (* z z)) y)) (/ (/ 1 y) (* (+ 1 (* z z)) x))))
(/ (/ 1 x) (* y (+ 1 (* z z)))))