\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.8
Final simplification31.8
herbie shell --seed 2020152
(FPCore (xre xim)
:name "(sqrt (+ (* xre xre) (* xim xim)))"
:precision binary64
(sqrt (+ (* xre xre) (* xim xim))))