\sqrt{xre \cdot xre + xim \cdot xim}\sqrt{xre \cdot xre + xim \cdot xim}double code(double xre, double xim) {
return ((double) sqrt(((double) (((double) (xre * xre)) + ((double) (xim * xim))))));
}
double code(double xre, double xim) {
return ((double) sqrt(((double) (((double) (xre * xre)) + ((double) (xim * xim))))));
}



Bits error versus xre



Bits error versus xim
Results
Initial program 31.7
Final simplification31.7
herbie shell --seed 2020153
(FPCore (xre xim)
:name "(sqrt (+ (* xre xre) (* xim xim)))"
:precision binary64
(sqrt (+ (* xre xre) (* xim xim))))