x \cdot e^{y \cdot y}\left({\left(e^{y}\right)}^{\left(y \cdot 0.6666666666666666\right)} \cdot x\right) \cdot \sqrt[3]{{\left(e^{y}\right)}^{y}}(FPCore (x y) :precision binary64 (* x (exp (* y y))))
(FPCore (x y) :precision binary64 (* (* (pow (exp y) (* y 0.6666666666666666)) x) (cbrt (pow (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) (((double) pow(((double) exp(y)), ((double) (y * 0.6666666666666666)))) * x)) * ((double) cbrt(((double) pow(((double) exp(y)), y))))));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program Error: 0.0 bits
rmApplied add-log-expError: 0.0 bits
Applied exp-to-powError: 0.0 bits
rmApplied add-cbrt-cubeError: 0.1 bits
SimplifiedError: 0.1 bits
rmApplied cube-multError: 0.1 bits
Applied cbrt-prodError: 0.1 bits
Applied associate-*r*Error: 0.1 bits
SimplifiedError: 0.1 bits
rmApplied cbrt-prodError: 0.0 bits
Applied associate-*r*Error: 0.0 bits
SimplifiedError: 0.0 bits
Final simplificationError: 0.0 bits
herbie shell --seed 2020205
(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))))