\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\begin{array}{l}
\mathbf{if}\;re \le -5.520517811877752757460528826883111925737 \cdot 10^{150}:\\
\;\;\;\;\frac{\frac{1}{2}}{\sqrt{\log 10}} \cdot \left(\left(\sqrt{\frac{1}{\log 10}} \cdot \log \left(\frac{-1}{re}\right)\right) \cdot -2\right)\\
\mathbf{elif}\;re \le 7.901470933521205940623300473159413989659 \cdot 10^{126}:\\
\;\;\;\;\frac{\sqrt[3]{\frac{1}{2}} \cdot \sqrt[3]{\frac{1}{2}}}{\sqrt{\sqrt{\log 10}}} \cdot \left(\frac{\log \left(re \cdot re + im \cdot im\right)}{\sqrt{\log 10}} \cdot \frac{\sqrt[3]{\frac{1}{2}}}{\sqrt{\sqrt{\log 10}}}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\sqrt{\frac{1}{\log 10}} \cdot \left(\log re \cdot 2\right)\right) \cdot \frac{\frac{1}{2}}{\sqrt{\log 10}}\\
\end{array}double f(double re, double im) {
double r1324405 = re;
double r1324406 = r1324405 * r1324405;
double r1324407 = im;
double r1324408 = r1324407 * r1324407;
double r1324409 = r1324406 + r1324408;
double r1324410 = sqrt(r1324409);
double r1324411 = log(r1324410);
double r1324412 = 10.0;
double r1324413 = log(r1324412);
double r1324414 = r1324411 / r1324413;
return r1324414;
}
double f(double re, double im) {
double r1324415 = re;
double r1324416 = -5.520517811877753e+150;
bool r1324417 = r1324415 <= r1324416;
double r1324418 = 0.5;
double r1324419 = 10.0;
double r1324420 = log(r1324419);
double r1324421 = sqrt(r1324420);
double r1324422 = r1324418 / r1324421;
double r1324423 = 1.0;
double r1324424 = r1324423 / r1324420;
double r1324425 = sqrt(r1324424);
double r1324426 = -1.0;
double r1324427 = r1324426 / r1324415;
double r1324428 = log(r1324427);
double r1324429 = r1324425 * r1324428;
double r1324430 = -2.0;
double r1324431 = r1324429 * r1324430;
double r1324432 = r1324422 * r1324431;
double r1324433 = 7.901470933521206e+126;
bool r1324434 = r1324415 <= r1324433;
double r1324435 = cbrt(r1324418);
double r1324436 = r1324435 * r1324435;
double r1324437 = sqrt(r1324421);
double r1324438 = r1324436 / r1324437;
double r1324439 = r1324415 * r1324415;
double r1324440 = im;
double r1324441 = r1324440 * r1324440;
double r1324442 = r1324439 + r1324441;
double r1324443 = log(r1324442);
double r1324444 = r1324443 / r1324421;
double r1324445 = r1324435 / r1324437;
double r1324446 = r1324444 * r1324445;
double r1324447 = r1324438 * r1324446;
double r1324448 = log(r1324415);
double r1324449 = 2.0;
double r1324450 = r1324448 * r1324449;
double r1324451 = r1324425 * r1324450;
double r1324452 = r1324451 * r1324422;
double r1324453 = r1324434 ? r1324447 : r1324452;
double r1324454 = r1324417 ? r1324432 : r1324453;
return r1324454;
}



Bits error versus re



Bits error versus im
Results
if re < -5.520517811877753e+150Initial program 63.0
rmApplied add-sqr-sqrt63.0
Applied pow1/263.0
Applied log-pow63.0
Applied times-frac63.0
Taylor expanded around -inf 7.4
if -5.520517811877753e+150 < re < 7.901470933521206e+126Initial program 21.1
rmApplied add-sqr-sqrt21.1
Applied pow1/221.1
Applied log-pow21.1
Applied times-frac21.0
rmApplied add-sqr-sqrt21.0
Applied sqrt-prod21.6
Applied add-cube-cbrt21.0
Applied times-frac21.0
Applied associate-*l*21.0
if 7.901470933521206e+126 < re Initial program 56.5
rmApplied add-sqr-sqrt56.5
Applied pow1/256.5
Applied log-pow56.5
Applied times-frac56.5
Taylor expanded around inf 8.1
Simplified8.1
Final simplification17.3
herbie shell --seed 2019174
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))