\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\begin{array}{l}
\mathbf{if}\;re \le -2.27109209614237641 \cdot 10^{59}:\\
\;\;\;\;\frac{\frac{1}{2}}{\sqrt{\log 10}} \cdot \left(-2 \cdot \left(\log \left(\frac{-1}{re}\right) \cdot \sqrt{\frac{1}{\log 10}}\right)\right)\\
\mathbf{elif}\;re \le 7.47537123548884264 \cdot 10^{131}:\\
\;\;\;\;\frac{\frac{1}{2}}{\sqrt{\log 10}} \cdot \log \left({\left(re \cdot re + im \cdot im\right)}^{\left(\frac{1}{\sqrt{\log 10}}\right)}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{\frac{1}{2}} \cdot \sqrt[3]{\frac{1}{2}}}{\sqrt{\sqrt{\log 10}}} \cdot \left(\frac{\sqrt[3]{\frac{1}{2}}}{\sqrt{\sqrt{\log 10}}} \cdot \frac{\log re \cdot 2}{\sqrt{\log 10}}\right)\\
\end{array}double f(double re, double im) {
double r44440 = re;
double r44441 = r44440 * r44440;
double r44442 = im;
double r44443 = r44442 * r44442;
double r44444 = r44441 + r44443;
double r44445 = sqrt(r44444);
double r44446 = log(r44445);
double r44447 = 10.0;
double r44448 = log(r44447);
double r44449 = r44446 / r44448;
return r44449;
}
double f(double re, double im) {
double r44450 = re;
double r44451 = -2.2710920961423764e+59;
bool r44452 = r44450 <= r44451;
double r44453 = 0.5;
double r44454 = 10.0;
double r44455 = log(r44454);
double r44456 = sqrt(r44455);
double r44457 = r44453 / r44456;
double r44458 = -2.0;
double r44459 = -1.0;
double r44460 = r44459 / r44450;
double r44461 = log(r44460);
double r44462 = 1.0;
double r44463 = r44462 / r44455;
double r44464 = sqrt(r44463);
double r44465 = r44461 * r44464;
double r44466 = r44458 * r44465;
double r44467 = r44457 * r44466;
double r44468 = 7.475371235488843e+131;
bool r44469 = r44450 <= r44468;
double r44470 = r44450 * r44450;
double r44471 = im;
double r44472 = r44471 * r44471;
double r44473 = r44470 + r44472;
double r44474 = r44462 / r44456;
double r44475 = pow(r44473, r44474);
double r44476 = log(r44475);
double r44477 = r44457 * r44476;
double r44478 = cbrt(r44453);
double r44479 = r44478 * r44478;
double r44480 = sqrt(r44456);
double r44481 = r44479 / r44480;
double r44482 = r44478 / r44480;
double r44483 = log(r44450);
double r44484 = 2.0;
double r44485 = r44483 * r44484;
double r44486 = r44485 / r44456;
double r44487 = r44482 * r44486;
double r44488 = r44481 * r44487;
double r44489 = r44469 ? r44477 : r44488;
double r44490 = r44452 ? r44467 : r44489;
return r44490;
}



Bits error versus re



Bits error versus im
Results
if re < -2.2710920961423764e+59Initial program 45.3
rmApplied add-sqr-sqrt45.3
Applied pow1/245.3
Applied log-pow45.3
Applied times-frac45.3
Taylor expanded around -inf 11.3
if -2.2710920961423764e+59 < re < 7.475371235488843e+131Initial program 22.6
rmApplied add-sqr-sqrt22.6
Applied pow1/222.6
Applied log-pow22.6
Applied times-frac22.6
rmApplied add-log-exp22.6
Simplified22.4
if 7.475371235488843e+131 < re Initial program 57.8
rmApplied add-sqr-sqrt57.8
Applied pow1/257.8
Applied log-pow57.8
Applied times-frac57.8
rmApplied add-sqr-sqrt57.8
Applied sqrt-prod57.8
Applied add-cube-cbrt57.8
Applied times-frac57.8
Applied associate-*l*57.8
Taylor expanded around inf 7.5
Simplified7.5
Final simplification18.0
herbie shell --seed 2020062
(FPCore (re im)
:name "math.log10 on complex, real part"
:precision binary64
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))