\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\begin{array}{l}
\mathbf{if}\;re \le -6.296857350600111 \cdot 10^{83}:\\
\;\;\;\;\frac{1}{\sqrt{\log 10}} \cdot \log \left({\left(\frac{-1}{re}\right)}^{\left(-\sqrt{\frac{1}{\log 10}}\right)}\right)\\
\mathbf{elif}\;re \le 9.19480309029371711 \cdot 10^{-296}:\\
\;\;\;\;\frac{1}{\sqrt{\log 10}} \cdot \log \left(\sqrt[3]{{\left({\left(\left(\sqrt[3]{\sqrt{re \cdot re + im \cdot im}} \cdot \sqrt[3]{\sqrt{re \cdot re + im \cdot im}}\right) \cdot \sqrt[3]{\sqrt{re \cdot re + im \cdot im}}\right)}^{\left(\frac{1}{\sqrt{\log 10}}\right)}\right)}^{3}}\right)\\
\mathbf{elif}\;re \le 3.4134902923337802 \cdot 10^{-133}:\\
\;\;\;\;\frac{1}{\sqrt{\log 10}} \cdot \log \left({im}^{\left(\sqrt{\frac{1}{\log 10}}\right)}\right)\\
\mathbf{elif}\;re \le 1.71884971088463661 \cdot 10^{152}:\\
\;\;\;\;\frac{1}{\sqrt{\log 10}} \cdot \log \left(\sqrt[3]{{\left({\left(\left(\sqrt[3]{\sqrt{re \cdot re + im \cdot im}} \cdot \sqrt[3]{\sqrt{re \cdot re + im \cdot im}}\right) \cdot \sqrt[3]{\sqrt{re \cdot re + im \cdot im}}\right)}^{\left(\frac{1}{\sqrt{\log 10}}\right)}\right)}^{3}}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\sqrt{\log 10}} \cdot \left(-1 \cdot \left(\log \left(\frac{1}{re}\right) \cdot \sqrt{\frac{1}{\log 10}}\right)\right)\\
\end{array}double f(double re, double im) {
double r45970 = re;
double r45971 = r45970 * r45970;
double r45972 = im;
double r45973 = r45972 * r45972;
double r45974 = r45971 + r45973;
double r45975 = sqrt(r45974);
double r45976 = log(r45975);
double r45977 = 10.0;
double r45978 = log(r45977);
double r45979 = r45976 / r45978;
return r45979;
}
double f(double re, double im) {
double r45980 = re;
double r45981 = -6.296857350600111e+83;
bool r45982 = r45980 <= r45981;
double r45983 = 1.0;
double r45984 = 10.0;
double r45985 = log(r45984);
double r45986 = sqrt(r45985);
double r45987 = r45983 / r45986;
double r45988 = -1.0;
double r45989 = r45988 / r45980;
double r45990 = r45983 / r45985;
double r45991 = sqrt(r45990);
double r45992 = -r45991;
double r45993 = pow(r45989, r45992);
double r45994 = log(r45993);
double r45995 = r45987 * r45994;
double r45996 = 9.194803090293717e-296;
bool r45997 = r45980 <= r45996;
double r45998 = r45980 * r45980;
double r45999 = im;
double r46000 = r45999 * r45999;
double r46001 = r45998 + r46000;
double r46002 = sqrt(r46001);
double r46003 = cbrt(r46002);
double r46004 = r46003 * r46003;
double r46005 = r46004 * r46003;
double r46006 = pow(r46005, r45987);
double r46007 = 3.0;
double r46008 = pow(r46006, r46007);
double r46009 = cbrt(r46008);
double r46010 = log(r46009);
double r46011 = r45987 * r46010;
double r46012 = 3.4134902923337802e-133;
bool r46013 = r45980 <= r46012;
double r46014 = pow(r45999, r45991);
double r46015 = log(r46014);
double r46016 = r45987 * r46015;
double r46017 = 1.7188497108846366e+152;
bool r46018 = r45980 <= r46017;
double r46019 = r45983 / r45980;
double r46020 = log(r46019);
double r46021 = r46020 * r45991;
double r46022 = r45988 * r46021;
double r46023 = r45987 * r46022;
double r46024 = r46018 ? r46011 : r46023;
double r46025 = r46013 ? r46016 : r46024;
double r46026 = r45997 ? r46011 : r46025;
double r46027 = r45982 ? r45995 : r46026;
return r46027;
}



Bits error versus re



Bits error versus im
Results
if re < -6.296857350600111e+83Initial program 50.0
rmApplied add-sqr-sqrt50.0
Applied pow150.0
Applied log-pow50.0
Applied times-frac50.0
rmApplied add-log-exp50.0
Simplified49.9
Taylor expanded around -inf 10.0
Simplified9.9
if -6.296857350600111e+83 < re < 9.194803090293717e-296 or 3.4134902923337802e-133 < re < 1.7188497108846366e+152Initial program 19.8
rmApplied add-sqr-sqrt19.8
Applied pow119.8
Applied log-pow19.8
Applied times-frac19.8
rmApplied add-log-exp19.8
Simplified19.6
rmApplied add-cube-cbrt19.6
rmApplied add-cbrt-cube19.6
Simplified19.6
if 9.194803090293717e-296 < re < 3.4134902923337802e-133Initial program 30.0
rmApplied add-sqr-sqrt30.0
Applied pow130.0
Applied log-pow30.0
Applied times-frac29.9
rmApplied add-log-exp29.9
Simplified29.8
rmApplied add-cube-cbrt29.8
Taylor expanded around 0 35.2
Simplified35.2
if 1.7188497108846366e+152 < re Initial program 63.5
rmApplied add-sqr-sqrt63.5
Applied pow163.5
Applied log-pow63.5
Applied times-frac63.5
Taylor expanded around inf 6.7
Final simplification18.3
herbie shell --seed 2020049
(FPCore (re im)
:name "math.log10 on complex, real part"
:precision binary64
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))