\frac{\frac{1.0}{x}}{y \cdot \left(1.0 + z \cdot z\right)}\frac{\frac{\frac{1}{x}}{\sqrt[3]{y}}}{\sqrt{1.0 + z \cdot z}} \cdot \frac{\frac{1.0}{\sqrt[3]{y} \cdot \sqrt[3]{y}}}{\sqrt{1.0 + z \cdot z}}double f(double x, double y, double z) {
double r16238099 = 1.0;
double r16238100 = x;
double r16238101 = r16238099 / r16238100;
double r16238102 = y;
double r16238103 = z;
double r16238104 = r16238103 * r16238103;
double r16238105 = r16238099 + r16238104;
double r16238106 = r16238102 * r16238105;
double r16238107 = r16238101 / r16238106;
return r16238107;
}
double f(double x, double y, double z) {
double r16238108 = 1.0;
double r16238109 = x;
double r16238110 = r16238108 / r16238109;
double r16238111 = y;
double r16238112 = cbrt(r16238111);
double r16238113 = r16238110 / r16238112;
double r16238114 = 1.0;
double r16238115 = z;
double r16238116 = r16238115 * r16238115;
double r16238117 = r16238114 + r16238116;
double r16238118 = sqrt(r16238117);
double r16238119 = r16238113 / r16238118;
double r16238120 = r16238112 * r16238112;
double r16238121 = r16238114 / r16238120;
double r16238122 = r16238121 / r16238118;
double r16238123 = r16238119 * r16238122;
return r16238123;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.4 |
|---|---|
| Target | 5.7 |
| Herbie | 5.9 |
Initial program 6.4
rmApplied associate-/r*6.3
rmApplied add-sqr-sqrt6.3
Applied add-cube-cbrt6.9
Applied div-inv6.9
Applied times-frac6.9
Applied times-frac5.9
Final simplification5.9
herbie shell --seed 2019168
(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)))))