\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\begin{array}{l}
\mathbf{if}\;re \le -1.427484018494741 \cdot 10^{+134}:\\
\;\;\;\;\frac{-\log \left(\frac{-1}{re}\right)}{\log 10}\\
\mathbf{elif}\;re \le 1.5824798583418597 \cdot 10^{+66}:\\
\;\;\;\;\left(\frac{1}{\sqrt{\log 10}} \cdot \log \left(\left|\sqrt[3]{im \cdot im + re \cdot re}\right| \cdot \sqrt{\sqrt[3]{im \cdot im + re \cdot re}}\right)\right) \cdot \frac{1}{\sqrt{\log 10}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\log re}{\log 10}\\
\end{array}double f(double re, double im) {
double r1273888 = re;
double r1273889 = r1273888 * r1273888;
double r1273890 = im;
double r1273891 = r1273890 * r1273890;
double r1273892 = r1273889 + r1273891;
double r1273893 = sqrt(r1273892);
double r1273894 = log(r1273893);
double r1273895 = 10.0;
double r1273896 = log(r1273895);
double r1273897 = r1273894 / r1273896;
return r1273897;
}
double f(double re, double im) {
double r1273898 = re;
double r1273899 = -1.427484018494741e+134;
bool r1273900 = r1273898 <= r1273899;
double r1273901 = -1.0;
double r1273902 = r1273901 / r1273898;
double r1273903 = log(r1273902);
double r1273904 = -r1273903;
double r1273905 = 10.0;
double r1273906 = log(r1273905);
double r1273907 = r1273904 / r1273906;
double r1273908 = 1.5824798583418597e+66;
bool r1273909 = r1273898 <= r1273908;
double r1273910 = 1.0;
double r1273911 = sqrt(r1273906);
double r1273912 = r1273910 / r1273911;
double r1273913 = im;
double r1273914 = r1273913 * r1273913;
double r1273915 = r1273898 * r1273898;
double r1273916 = r1273914 + r1273915;
double r1273917 = cbrt(r1273916);
double r1273918 = fabs(r1273917);
double r1273919 = sqrt(r1273917);
double r1273920 = r1273918 * r1273919;
double r1273921 = log(r1273920);
double r1273922 = r1273912 * r1273921;
double r1273923 = r1273922 * r1273912;
double r1273924 = log(r1273898);
double r1273925 = r1273924 / r1273906;
double r1273926 = r1273909 ? r1273923 : r1273925;
double r1273927 = r1273900 ? r1273907 : r1273926;
return r1273927;
}



Bits error versus re



Bits error versus im
Results
if re < -1.427484018494741e+134Initial program 56.7
Taylor expanded around -inf 7.8
if -1.427484018494741e+134 < re < 1.5824798583418597e+66Initial program 21.5
rmApplied add-cube-cbrt21.5
Applied sqrt-prod21.5
Simplified21.5
rmApplied add-sqr-sqrt21.5
Applied pow121.5
Applied pow121.5
Applied pow-prod-down21.5
Applied log-pow21.5
Applied times-frac21.4
rmApplied div-inv21.3
if 1.5824798583418597e+66 < re Initial program 46.3
Taylor expanded around inf 10.5
Final simplification17.4
herbie shell --seed 2019163
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))