\left(\left(x \cdot 0.5 - y\right) \cdot \sqrt{z \cdot 2}\right) \cdot e^{\frac{t \cdot t}{2}}\left(\sqrt{e^{\frac{t \cdot t}{2}}} \cdot \left(\left(x \cdot 0.5 - y\right) \cdot \sqrt{z \cdot 2}\right)\right) \cdot \sqrt{e^{\frac{t \cdot t}{2}}}double f(double x, double y, double z, double t) {
double r40791703 = x;
double r40791704 = 0.5;
double r40791705 = r40791703 * r40791704;
double r40791706 = y;
double r40791707 = r40791705 - r40791706;
double r40791708 = z;
double r40791709 = 2.0;
double r40791710 = r40791708 * r40791709;
double r40791711 = sqrt(r40791710);
double r40791712 = r40791707 * r40791711;
double r40791713 = t;
double r40791714 = r40791713 * r40791713;
double r40791715 = r40791714 / r40791709;
double r40791716 = exp(r40791715);
double r40791717 = r40791712 * r40791716;
return r40791717;
}
double f(double x, double y, double z, double t) {
double r40791718 = t;
double r40791719 = r40791718 * r40791718;
double r40791720 = 2.0;
double r40791721 = r40791719 / r40791720;
double r40791722 = exp(r40791721);
double r40791723 = sqrt(r40791722);
double r40791724 = x;
double r40791725 = 0.5;
double r40791726 = r40791724 * r40791725;
double r40791727 = y;
double r40791728 = r40791726 - r40791727;
double r40791729 = z;
double r40791730 = r40791729 * r40791720;
double r40791731 = sqrt(r40791730);
double r40791732 = r40791728 * r40791731;
double r40791733 = r40791723 * r40791732;
double r40791734 = r40791733 * r40791723;
return r40791734;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 0.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 0.3
rmApplied add-sqr-sqrt0.3
Applied associate-*r*0.3
Final simplification0.3
herbie shell --seed 2019172 +o rules:numerics
(FPCore (x y z t)
:name "Data.Number.Erf:$cinvnormcdf from erf-2.0.0.0, A"
:herbie-target
(* (* (- (* x 0.5) y) (sqrt (* z 2.0))) (pow (exp 1.0) (/ (* t t) 2.0)))
(* (* (- (* x 0.5) y) (sqrt (* z 2.0))) (exp (/ (* t t) 2.0))))