\sqrt{re \cdot re + im \cdot im}\mathsf{hypot}\left(re, im\right)double f(double re, double im) {
double r2046938 = re;
double r2046939 = r2046938 * r2046938;
double r2046940 = im;
double r2046941 = r2046940 * r2046940;
double r2046942 = r2046939 + r2046941;
double r2046943 = sqrt(r2046942);
return r2046943;
}
double f(double re, double im) {
double r2046944 = re;
double r2046945 = im;
double r2046946 = hypot(r2046944, r2046945);
return r2046946;
}



Bits error versus re



Bits error versus im
Results
Initial program 29.4
Simplified0.0
Final simplification0.0
herbie shell --seed 2019165 +o rules:numerics
(FPCore (re im)
:name "math.abs on complex"
(sqrt (+ (* re re) (* im im))))