\sqrt{re \cdot re + im \cdot im}\begin{array}{l}
\mathbf{if}\;re \le -6.8846914672875272 \cdot 10^{72}:\\
\;\;\;\;-1 \cdot re\\
\mathbf{elif}\;re \le -6.10111052612686754 \cdot 10^{-93}:\\
\;\;\;\;\sqrt{re \cdot re + im \cdot im}\\
\mathbf{elif}\;re \le -3.3124292600034948 \cdot 10^{-125}:\\
\;\;\;\;im\\
\mathbf{elif}\;re \le 9.88783731726367163 \cdot 10^{72}:\\
\;\;\;\;\sqrt{re \cdot re + im \cdot im}\\
\mathbf{else}:\\
\;\;\;\;re\\
\end{array}double f(double re, double im) {
double r48854 = re;
double r48855 = r48854 * r48854;
double r48856 = im;
double r48857 = r48856 * r48856;
double r48858 = r48855 + r48857;
double r48859 = sqrt(r48858);
return r48859;
}
double f(double re, double im) {
double r48860 = re;
double r48861 = -6.884691467287527e+72;
bool r48862 = r48860 <= r48861;
double r48863 = -1.0;
double r48864 = r48863 * r48860;
double r48865 = -6.1011105261268675e-93;
bool r48866 = r48860 <= r48865;
double r48867 = r48860 * r48860;
double r48868 = im;
double r48869 = r48868 * r48868;
double r48870 = r48867 + r48869;
double r48871 = sqrt(r48870);
double r48872 = -3.312429260003495e-125;
bool r48873 = r48860 <= r48872;
double r48874 = 9.887837317263672e+72;
bool r48875 = r48860 <= r48874;
double r48876 = r48875 ? r48871 : r48860;
double r48877 = r48873 ? r48868 : r48876;
double r48878 = r48866 ? r48871 : r48877;
double r48879 = r48862 ? r48864 : r48878;
return r48879;
}



Bits error versus re



Bits error versus im
Results
if re < -6.884691467287527e+72Initial program 47.3
Taylor expanded around -inf 12.7
if -6.884691467287527e+72 < re < -6.1011105261268675e-93 or -3.312429260003495e-125 < re < 9.887837317263672e+72Initial program 22.1
if -6.1011105261268675e-93 < re < -3.312429260003495e-125Initial program 17.7
Taylor expanded around 0 38.9
if 9.887837317263672e+72 < re Initial program 48.3
Taylor expanded around inf 12.6
Final simplification18.9
herbie shell --seed 2020083
(FPCore (re im)
:name "math.abs on complex"
:precision binary64
(sqrt (+ (* re re) (* im im))))