e^{\log \left(\sqrt{x.re \cdot x.re + x.im \cdot x.im}\right) \cdot y.re - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot \cos \left(\log \left(\sqrt{x.re \cdot x.re + x.im \cdot x.im}\right) \cdot y.im + \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\frac{\mathsf{expm1}\left(\mathsf{log1p}\left(\sqrt[3]{\cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\right)} \cdot \left(\sqrt[3]{\cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\right)} \cdot \sqrt[3]{\cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\right)}\right)\right)\right)}{e^{\sqrt[3]{\tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot \left(\sqrt[3]{\tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot \sqrt[3]{\tan^{-1}_* \frac{x.im}{x.re} \cdot y.im}\right) - y.re \cdot \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right)}}double f(double x_re, double x_im, double y_re, double y_im) {
double r1266729 = x_re;
double r1266730 = r1266729 * r1266729;
double r1266731 = x_im;
double r1266732 = r1266731 * r1266731;
double r1266733 = r1266730 + r1266732;
double r1266734 = sqrt(r1266733);
double r1266735 = log(r1266734);
double r1266736 = y_re;
double r1266737 = r1266735 * r1266736;
double r1266738 = atan2(r1266731, r1266729);
double r1266739 = y_im;
double r1266740 = r1266738 * r1266739;
double r1266741 = r1266737 - r1266740;
double r1266742 = exp(r1266741);
double r1266743 = r1266735 * r1266739;
double r1266744 = r1266738 * r1266736;
double r1266745 = r1266743 + r1266744;
double r1266746 = cos(r1266745);
double r1266747 = r1266742 * r1266746;
return r1266747;
}
double f(double x_re, double x_im, double y_re, double y_im) {
double r1266748 = y_im;
double r1266749 = x_re;
double r1266750 = x_im;
double r1266751 = hypot(r1266749, r1266750);
double r1266752 = log(r1266751);
double r1266753 = atan2(r1266750, r1266749);
double r1266754 = y_re;
double r1266755 = r1266753 * r1266754;
double r1266756 = fma(r1266748, r1266752, r1266755);
double r1266757 = cos(r1266756);
double r1266758 = cbrt(r1266757);
double r1266759 = r1266758 * r1266758;
double r1266760 = r1266758 * r1266759;
double r1266761 = log1p(r1266760);
double r1266762 = expm1(r1266761);
double r1266763 = r1266753 * r1266748;
double r1266764 = cbrt(r1266763);
double r1266765 = r1266764 * r1266764;
double r1266766 = r1266764 * r1266765;
double r1266767 = r1266754 * r1266752;
double r1266768 = r1266766 - r1266767;
double r1266769 = exp(r1266768);
double r1266770 = r1266762 / r1266769;
return r1266770;
}



Bits error versus x.re



Bits error versus x.im



Bits error versus y.re



Bits error versus y.im
Initial program 32.4
Simplified3.3
rmApplied expm1-log1p-u3.3
rmApplied add-cube-cbrt3.4
rmApplied add-cube-cbrt3.4
Final simplification3.4
herbie shell --seed 2019164 +o rules:numerics
(FPCore (x.re x.im y.re y.im)
:name "powComplex, real part"
(* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (cos (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))))