\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}\sqrt{\frac{1}{\sqrt{\log 10}}} \cdot \left(\left(\left(\frac{1}{\sqrt{\log 10}} \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)\right) \cdot \sqrt{\sqrt{\frac{1}{\sqrt{\log 10}}}}\right) \cdot \sqrt{\sqrt{\frac{1}{\sqrt{\log 10}}}}\right)double f(double re, double im) {
double r1034161 = re;
double r1034162 = r1034161 * r1034161;
double r1034163 = im;
double r1034164 = r1034163 * r1034163;
double r1034165 = r1034162 + r1034164;
double r1034166 = sqrt(r1034165);
double r1034167 = log(r1034166);
double r1034168 = 10.0;
double r1034169 = log(r1034168);
double r1034170 = r1034167 / r1034169;
return r1034170;
}
double f(double re, double im) {
double r1034171 = 1.0;
double r1034172 = 10.0;
double r1034173 = log(r1034172);
double r1034174 = sqrt(r1034173);
double r1034175 = r1034171 / r1034174;
double r1034176 = sqrt(r1034175);
double r1034177 = re;
double r1034178 = im;
double r1034179 = hypot(r1034177, r1034178);
double r1034180 = log(r1034179);
double r1034181 = r1034175 * r1034180;
double r1034182 = sqrt(r1034176);
double r1034183 = r1034181 * r1034182;
double r1034184 = r1034183 * r1034182;
double r1034185 = r1034176 * r1034184;
return r1034185;
}



Bits error versus re



Bits error versus im
Results
Initial program 32.3
Simplified0.6
rmApplied add-sqr-sqrt0.6
Applied pow10.6
Applied log-pow0.6
Applied times-frac0.6
rmApplied div-inv0.4
rmApplied add-sqr-sqrt0.4
Applied associate-*l*0.5
rmApplied add-sqr-sqrt0.5
Applied sqrt-prod0.6
Applied associate-*l*0.5
Final simplification0.5
herbie shell --seed 2019169 +o rules:numerics
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))