\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\frac{1}{\sqrt{\log 10}} \cdot \left(\frac{1}{\sqrt{\log 10}} \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)\right)double f(double re, double im) {
double r382930 = re;
double r382931 = r382930 * r382930;
double r382932 = im;
double r382933 = r382932 * r382932;
double r382934 = r382931 + r382933;
double r382935 = sqrt(r382934);
double r382936 = log(r382935);
double r382937 = 10.0;
double r382938 = log(r382937);
double r382939 = r382936 / r382938;
return r382939;
}
double f(double re, double im) {
double r382940 = 1.0;
double r382941 = 10.0;
double r382942 = log(r382941);
double r382943 = sqrt(r382942);
double r382944 = r382940 / r382943;
double r382945 = re;
double r382946 = im;
double r382947 = hypot(r382945, r382946);
double r382948 = log(r382947);
double r382949 = r382944 * r382948;
double r382950 = r382944 * r382949;
return r382950;
}



Bits error versus re



Bits error versus im
Results
Initial program 31.0
Simplified0.6
rmApplied add-sqr-sqrt0.6
Applied *-un-lft-identity0.6
Applied times-frac0.6
rmApplied div-inv0.4
Applied associate-*r*0.4
rmApplied *-un-lft-identity0.4
Applied associate-*r*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019128 +o rules:numerics
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))