\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\begin{array}{l}
\mathbf{if}\;re \le -86.01993975715544:\\
\;\;\;\;\frac{\log \left(-re\right)}{\log 10}\\
\mathbf{elif}\;re \le 3.7915490690311645 \cdot 10^{-225}:\\
\;\;\;\;\frac{1}{\sqrt[3]{\left(\frac{\log 10}{\log \left(\left(\left|\sqrt[3]{im \cdot im + re \cdot re}\right| \cdot \left|\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}\right|\right) \cdot \sqrt{\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}}\right)} \cdot \frac{\log 10}{\log \left(\left(\left|\sqrt[3]{im \cdot im + re \cdot re}\right| \cdot \left|\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}\right|\right) \cdot \sqrt{\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}}\right)}\right) \cdot \frac{\log 10}{\log \left(\left(\left|\sqrt[3]{im \cdot im + re \cdot re}\right| \cdot \left|\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}\right|\right) \cdot \sqrt{\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}}\right)}}}\\
\mathbf{elif}\;re \le 5.785268620035206 \cdot 10^{-190}:\\
\;\;\;\;\frac{\log im}{\log 10}\\
\mathbf{elif}\;re \le 3.884985694072655 \cdot 10^{+111}:\\
\;\;\;\;\frac{\log \left(\left(\left|\sqrt[3]{im \cdot im + re \cdot re}\right| \cdot \left|\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}\right|\right) \cdot \sqrt{\sqrt[3]{\sqrt[3]{im \cdot im + re \cdot re}}}\right)}{\log 10}\\
\mathbf{else}:\\
\;\;\;\;\frac{\log re}{\log 10}\\
\end{array}double f(double re, double im) {
double r642333 = re;
double r642334 = r642333 * r642333;
double r642335 = im;
double r642336 = r642335 * r642335;
double r642337 = r642334 + r642336;
double r642338 = sqrt(r642337);
double r642339 = log(r642338);
double r642340 = 10.0;
double r642341 = log(r642340);
double r642342 = r642339 / r642341;
return r642342;
}
double f(double re, double im) {
double r642343 = re;
double r642344 = -86.01993975715544;
bool r642345 = r642343 <= r642344;
double r642346 = -r642343;
double r642347 = log(r642346);
double r642348 = 10.0;
double r642349 = log(r642348);
double r642350 = r642347 / r642349;
double r642351 = 3.7915490690311645e-225;
bool r642352 = r642343 <= r642351;
double r642353 = 1.0;
double r642354 = im;
double r642355 = r642354 * r642354;
double r642356 = r642343 * r642343;
double r642357 = r642355 + r642356;
double r642358 = cbrt(r642357);
double r642359 = fabs(r642358);
double r642360 = cbrt(r642358);
double r642361 = fabs(r642360);
double r642362 = r642359 * r642361;
double r642363 = sqrt(r642360);
double r642364 = r642362 * r642363;
double r642365 = log(r642364);
double r642366 = r642349 / r642365;
double r642367 = r642366 * r642366;
double r642368 = r642367 * r642366;
double r642369 = cbrt(r642368);
double r642370 = r642353 / r642369;
double r642371 = 5.785268620035206e-190;
bool r642372 = r642343 <= r642371;
double r642373 = log(r642354);
double r642374 = r642373 / r642349;
double r642375 = 3.884985694072655e+111;
bool r642376 = r642343 <= r642375;
double r642377 = r642365 / r642349;
double r642378 = log(r642343);
double r642379 = r642378 / r642349;
double r642380 = r642376 ? r642377 : r642379;
double r642381 = r642372 ? r642374 : r642380;
double r642382 = r642352 ? r642370 : r642381;
double r642383 = r642345 ? r642350 : r642382;
return r642383;
}



Bits error versus re



Bits error versus im
Results
if re < -86.01993975715544Initial program 38.8
Taylor expanded around -inf 12.7
Simplified12.7
if -86.01993975715544 < re < 3.7915490690311645e-225Initial program 24.7
rmApplied add-cube-cbrt24.7
Applied sqrt-prod24.7
Simplified24.7
rmApplied add-cube-cbrt24.7
Applied sqrt-prod24.7
Applied associate-*r*24.7
Simplified24.7
rmApplied clear-num24.7
rmApplied add-cbrt-cube24.8
Applied add-cbrt-cube25.1
Applied cbrt-undiv24.8
Simplified24.8
if 3.7915490690311645e-225 < re < 5.785268620035206e-190Initial program 34.6
Taylor expanded around 0 32.1
if 5.785268620035206e-190 < re < 3.884985694072655e+111Initial program 17.4
rmApplied add-cube-cbrt17.4
Applied sqrt-prod17.4
Simplified17.4
rmApplied add-cube-cbrt17.4
Applied sqrt-prod17.4
Applied associate-*r*17.4
Simplified17.4
if 3.884985694072655e+111 < re Initial program 52.8
Taylor expanded around inf 9.4
Final simplification17.6
herbie shell --seed 2019153
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))