\log \left(\sqrt{re \cdot re + im \cdot im}\right)\begin{array}{l}
\mathbf{if}\;im \leq -5.810506997467958 \cdot 10^{+110}:\\
\;\;\;\;\log \left(-im\right)\\
\mathbf{elif}\;im \leq -4.996387093174353 \cdot 10^{-297}:\\
\;\;\;\;\log \left(\sqrt{re \cdot re + im \cdot im}\right)\\
\mathbf{elif}\;im \leq 3.135452371686857 \cdot 10^{-180}:\\
\;\;\;\;\log \left(-re\right)\\
\mathbf{elif}\;im \leq 3.757890946018409 \cdot 10^{+89}:\\
\;\;\;\;\log \left(\sqrt{re \cdot re + im \cdot im}\right)\\
\mathbf{else}:\\
\;\;\;\;\log im\\
\end{array}(FPCore (re im) :precision binary64 (log (sqrt (+ (* re re) (* im im)))))
(FPCore (re im)
:precision binary64
(if (<= im -5.810506997467958e+110)
(log (- im))
(if (<= im -4.996387093174353e-297)
(log (sqrt (+ (* re re) (* im im))))
(if (<= im 3.135452371686857e-180)
(log (- re))
(if (<= im 3.757890946018409e+89)
(log (sqrt (+ (* re re) (* im im))))
(log im))))))double code(double re, double im) {
return log(sqrt((re * re) + (im * im)));
}
double code(double re, double im) {
double tmp;
if (im <= -5.810506997467958e+110) {
tmp = log(-im);
} else if (im <= -4.996387093174353e-297) {
tmp = log(sqrt((re * re) + (im * im)));
} else if (im <= 3.135452371686857e-180) {
tmp = log(-re);
} else if (im <= 3.757890946018409e+89) {
tmp = log(sqrt((re * re) + (im * im)));
} else {
tmp = log(im);
}
return tmp;
}



Bits error versus re



Bits error versus im
Results
if im < -5.810506997467958e110Initial program 52.7
Taylor expanded around -inf 8.5
if -5.810506997467958e110 < im < -4.9963870931743528e-297 or 3.1354523716868571e-180 < im < 3.7578909460184092e89Initial program 19.4
if -4.9963870931743528e-297 < im < 3.1354523716868571e-180Initial program 32.4
Taylor expanded around -inf 33.4
Simplified33.4
if 3.7578909460184092e89 < im Initial program 50.1
Taylor expanded around 0 8.8
Final simplification17.5
herbie shell --seed 2021022
(FPCore (re im)
:name "math.log/1 on complex, real part"
:precision binary64
(log (sqrt (+ (* re re) (* im im)))))