\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 r44453 = re;
double r44454 = r44453 * r44453;
double r44455 = im;
double r44456 = r44455 * r44455;
double r44457 = r44454 + r44456;
double r44458 = sqrt(r44457);
double r44459 = log(r44458);
double r44460 = 10.0;
double r44461 = log(r44460);
double r44462 = r44459 / r44461;
return r44462;
}
double f(double re, double im) {
double r44463 = re;
double r44464 = -2.2710920961423764e+59;
bool r44465 = r44463 <= r44464;
double r44466 = 0.5;
double r44467 = 10.0;
double r44468 = log(r44467);
double r44469 = sqrt(r44468);
double r44470 = r44466 / r44469;
double r44471 = -2.0;
double r44472 = -1.0;
double r44473 = r44472 / r44463;
double r44474 = log(r44473);
double r44475 = 1.0;
double r44476 = r44475 / r44468;
double r44477 = sqrt(r44476);
double r44478 = r44474 * r44477;
double r44479 = r44471 * r44478;
double r44480 = r44470 * r44479;
double r44481 = 7.475371235488843e+131;
bool r44482 = r44463 <= r44481;
double r44483 = r44463 * r44463;
double r44484 = im;
double r44485 = r44484 * r44484;
double r44486 = r44483 + r44485;
double r44487 = r44475 / r44469;
double r44488 = pow(r44486, r44487);
double r44489 = log(r44488);
double r44490 = r44470 * r44489;
double r44491 = cbrt(r44466);
double r44492 = r44491 * r44491;
double r44493 = sqrt(r44469);
double r44494 = r44492 / r44493;
double r44495 = r44491 / r44493;
double r44496 = log(r44463);
double r44497 = 2.0;
double r44498 = r44496 * r44497;
double r44499 = r44498 / r44469;
double r44500 = r44495 * r44499;
double r44501 = r44494 * r44500;
double r44502 = r44482 ? r44490 : r44501;
double r44503 = r44465 ? r44480 : r44502;
return r44503;
}



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)))