x \cdot e^{y \cdot y}\left(x \cdot \left({\left(\sqrt{e^{y}}\right)}^{y} \cdot \sqrt{{\left(\sqrt[3]{e^{y}} \cdot \sqrt[3]{e^{y}}\right)}^{y}}\right)\right) \cdot \sqrt{{\left(\sqrt[3]{e^{y}}\right)}^{y}}(FPCore (x y) :precision binary64 (* x (exp (* y y))))
(FPCore (x y) :precision binary64 (* (* x (* (pow (sqrt (exp y)) y) (sqrt (pow (* (cbrt (exp y)) (cbrt (exp y))) y)))) (sqrt (pow (cbrt (exp y)) y))))
double code(double x, double y) {
return ((double) (x * ((double) exp(((double) (y * y))))));
}
double code(double x, double y) {
return ((double) (((double) (x * ((double) (((double) pow(((double) sqrt(((double) exp(y)))), y)) * ((double) sqrt(((double) pow(((double) (((double) cbrt(((double) exp(y)))) * ((double) cbrt(((double) exp(y)))))), y)))))))) * ((double) sqrt(((double) pow(((double) cbrt(((double) exp(y)))), y))))));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program Error: 0.0 bits
SimplifiedError: 0.0 bits
rmApplied add-sqr-sqrtError: 0.0 bits
Applied associate-*r*Error: 0.0 bits
SimplifiedError: 0.0 bits
rmApplied add-cube-cbrtError: 0.0 bits
Applied unpow-prod-downError: 0.0 bits
Applied sqrt-prodError: 0.0 bits
Applied associate-*r*Error: 0.0 bits
SimplifiedError: 0.1 bits
Final simplificationError: 0.1 bits
herbie shell --seed 2020204
(FPCore (x y)
:name "Data.Number.Erf:$dmerfcx from erf-2.0.0.0"
:precision binary64
:herbie-target
(* x (pow (exp y) y))
(* x (exp (* y y))))