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)\sqrt[3]{\cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), y.re \cdot \tan^{-1}_* \frac{x.im}{x.re}\right)\right) \cdot \left(\cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), y.re \cdot \tan^{-1}_* \frac{x.im}{x.re}\right)\right) \cdot \cos \left(\mathsf{fma}\left(y.im, \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right), y.re \cdot \tan^{-1}_* \frac{x.im}{x.re}\right)\right)\right)} \cdot e^{\log \left(\mathsf{hypot}\left(x.re, x.im\right)\right) \cdot y.re - \sqrt[3]{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}} \cdot \left(\sqrt[3]{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}} \cdot \left(\sqrt[3]{\sqrt[3]{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}}} \cdot \left(\sqrt[3]{\sqrt[3]{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}}} \cdot \sqrt[3]{\sqrt[3]{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}}}\right)\right)\right)}double f(double x_re, double x_im, double y_re, double y_im) {
double r1083965 = x_re;
double r1083966 = r1083965 * r1083965;
double r1083967 = x_im;
double r1083968 = r1083967 * r1083967;
double r1083969 = r1083966 + r1083968;
double r1083970 = sqrt(r1083969);
double r1083971 = log(r1083970);
double r1083972 = y_re;
double r1083973 = r1083971 * r1083972;
double r1083974 = atan2(r1083967, r1083965);
double r1083975 = y_im;
double r1083976 = r1083974 * r1083975;
double r1083977 = r1083973 - r1083976;
double r1083978 = exp(r1083977);
double r1083979 = r1083971 * r1083975;
double r1083980 = r1083974 * r1083972;
double r1083981 = r1083979 + r1083980;
double r1083982 = cos(r1083981);
double r1083983 = r1083978 * r1083982;
return r1083983;
}
double f(double x_re, double x_im, double y_re, double y_im) {
double r1083984 = y_im;
double r1083985 = x_re;
double r1083986 = x_im;
double r1083987 = hypot(r1083985, r1083986);
double r1083988 = log(r1083987);
double r1083989 = y_re;
double r1083990 = atan2(r1083986, r1083985);
double r1083991 = r1083989 * r1083990;
double r1083992 = fma(r1083984, r1083988, r1083991);
double r1083993 = cos(r1083992);
double r1083994 = r1083993 * r1083993;
double r1083995 = r1083993 * r1083994;
double r1083996 = cbrt(r1083995);
double r1083997 = r1083988 * r1083989;
double r1083998 = r1083984 * r1083990;
double r1083999 = cbrt(r1083998);
double r1084000 = cbrt(r1083999);
double r1084001 = r1084000 * r1084000;
double r1084002 = r1084000 * r1084001;
double r1084003 = r1083999 * r1084002;
double r1084004 = r1083999 * r1084003;
double r1084005 = r1083997 - r1084004;
double r1084006 = exp(r1084005);
double r1084007 = r1083996 * r1084006;
return r1084007;
}



Bits error versus x.re



Bits error versus x.im



Bits error versus y.re



Bits error versus y.im
Initial program 32.2
Simplified3.4
rmApplied add-cube-cbrt3.4
rmApplied add-cube-cbrt3.4
rmApplied add-cbrt-cube3.4
Final simplification3.4
herbie shell --seed 2019151 +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)))))