\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right) \cdot \log base + \tan^{-1}_* \frac{im}{re} \cdot 0.0}{\log base \cdot \log base + 0.0 \cdot 0.0}\frac{1}{\mathsf{hypot}\left(\log base, 0.0\right)} \cdot \frac{\mathsf{fma}\left(\log \left(\mathsf{hypot}\left(re, im\right)\right), \log base, \tan^{-1}_* \frac{im}{re} \cdot 0.0\right)}{\mathsf{hypot}\left(0.0, \log base\right)}double f(double re, double im, double base) {
double r111974 = re;
double r111975 = r111974 * r111974;
double r111976 = im;
double r111977 = r111976 * r111976;
double r111978 = r111975 + r111977;
double r111979 = sqrt(r111978);
double r111980 = log(r111979);
double r111981 = base;
double r111982 = log(r111981);
double r111983 = r111980 * r111982;
double r111984 = atan2(r111976, r111974);
double r111985 = 0.0;
double r111986 = r111984 * r111985;
double r111987 = r111983 + r111986;
double r111988 = r111982 * r111982;
double r111989 = r111985 * r111985;
double r111990 = r111988 + r111989;
double r111991 = r111987 / r111990;
return r111991;
}
double f(double re, double im, double base) {
double r111992 = 1.0;
double r111993 = base;
double r111994 = log(r111993);
double r111995 = 0.0;
double r111996 = hypot(r111994, r111995);
double r111997 = r111992 / r111996;
double r111998 = re;
double r111999 = im;
double r112000 = hypot(r111998, r111999);
double r112001 = log(r112000);
double r112002 = atan2(r111999, r111998);
double r112003 = r112002 * r111995;
double r112004 = fma(r112001, r111994, r112003);
double r112005 = hypot(r111995, r111994);
double r112006 = r112004 / r112005;
double r112007 = r111997 * r112006;
return r112007;
}



Bits error versus re



Bits error versus im



Bits error versus base
Initial program 31.0
Simplified0.5
rmApplied add-sqr-sqrt0.5
Applied associate-/r*0.4
Simplified0.4
rmApplied add-sqr-sqrt0.4
Applied sqrt-prod0.7
Applied add-sqr-sqrt1.0
Applied *-un-lft-identity1.0
Applied times-frac1.0
Applied times-frac1.0
Simplified0.7
Simplified0.5
Final simplification0.5
herbie shell --seed 2019303 +o rules:numerics
(FPCore (re im base)
:name "math.log/2 on complex, real part"
:precision binary64
(/ (+ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (atan2 im re) 0.0)) (+ (* (log base) (log base)) (* 0.0 0.0))))