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)\begin{array}{l}
\mathbf{if}\;y.re \le -1.6507641711952303 \cdot 10^{52}:\\
\;\;\;\;e^{\log \left({\left(\mathsf{hypot}\left(x.re, x.im\right)\right)}^{y.re} \cdot \cos \left(\mathsf{fma}\left(\log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), y.im, \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\right)\right) - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im}\\
\mathbf{else}:\\
\;\;\;\;\frac{{\left(\mathsf{hypot}\left(x.re, x.im\right)\right)}^{y.re} \cdot \mathsf{log1p}\left(\sqrt[3]{\log \left(e^{\mathsf{log1p}\left(\mathsf{expm1}\left({\left(\mathsf{expm1}\left(\cos \left(\mathsf{fma}\left(\log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), y.im, \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)\right)\right)\right)}^{3}\right)\right)}\right)}\right)}{e^{\tan^{-1}_* \frac{x.im}{x.re} \cdot y.im}}\\
\end{array}double f(double x_re, double x_im, double y_re, double y_im) {
double r26725 = x_re;
double r26726 = r26725 * r26725;
double r26727 = x_im;
double r26728 = r26727 * r26727;
double r26729 = r26726 + r26728;
double r26730 = sqrt(r26729);
double r26731 = log(r26730);
double r26732 = y_re;
double r26733 = r26731 * r26732;
double r26734 = atan2(r26727, r26725);
double r26735 = y_im;
double r26736 = r26734 * r26735;
double r26737 = r26733 - r26736;
double r26738 = exp(r26737);
double r26739 = r26731 * r26735;
double r26740 = r26734 * r26732;
double r26741 = r26739 + r26740;
double r26742 = cos(r26741);
double r26743 = r26738 * r26742;
return r26743;
}
double f(double x_re, double x_im, double y_re, double y_im) {
double r26744 = y_re;
double r26745 = -1.6507641711952303e+52;
bool r26746 = r26744 <= r26745;
double r26747 = x_re;
double r26748 = x_im;
double r26749 = hypot(r26747, r26748);
double r26750 = pow(r26749, r26744);
double r26751 = log(r26749);
double r26752 = y_im;
double r26753 = atan2(r26748, r26747);
double r26754 = r26753 * r26744;
double r26755 = fma(r26751, r26752, r26754);
double r26756 = cos(r26755);
double r26757 = r26750 * r26756;
double r26758 = log(r26757);
double r26759 = r26753 * r26752;
double r26760 = r26758 - r26759;
double r26761 = exp(r26760);
double r26762 = expm1(r26756);
double r26763 = 3.0;
double r26764 = pow(r26762, r26763);
double r26765 = expm1(r26764);
double r26766 = log1p(r26765);
double r26767 = exp(r26766);
double r26768 = log(r26767);
double r26769 = cbrt(r26768);
double r26770 = log1p(r26769);
double r26771 = r26750 * r26770;
double r26772 = exp(r26759);
double r26773 = r26771 / r26772;
double r26774 = r26746 ? r26761 : r26773;
return r26774;
}



Bits error versus x.re



Bits error versus x.im



Bits error versus y.re



Bits error versus y.im
if y.re < -1.6507641711952303e+52Initial program 37.8
Simplified10.9
rmApplied add-exp-log35.4
Applied add-exp-log35.4
Applied pow-exp35.4
Applied prod-exp35.4
Applied div-exp30.5
Simplified2.2
if -1.6507641711952303e+52 < y.re Initial program 32.6
Simplified8.4
rmApplied log1p-expm1-u8.4
rmApplied add-cbrt-cube8.4
Simplified8.4
rmApplied add-log-exp8.4
rmApplied log1p-expm1-u8.4
Final simplification7.0
herbie shell --seed 2020046 +o rules:numerics
(FPCore (x.re x.im y.re y.im)
:name "powComplex, real part"
:precision binary64
(* (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)))))