double code(double x) {
return ((double) sqrt(((double) (2.0 * ((double) (x * x))))));
}
double code(double x) {
return ((double) (((double) (((double) cbrt(((double) sqrt(2.0)))) * ((double) cbrt(((double) sqrt(2.0)))))) * ((double) (((double) cbrt(((double) sqrt(2.0)))) * ((double) fabs(x))))));
}



Bits error versus x
Results
Initial program 30.7
rmApplied sqrt-prod30.9
Simplified0.4
rmApplied add-cube-cbrt0.4
Applied associate-*l*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020180
(FPCore (x)
:name "sqrt C"
:precision binary64
(sqrt (* 2.0 (* x x))))