\left(\left(\left(x.re \cdot x.re\right) - \left(x.im \cdot x.im\right)\right) \cdot x.re\right) - \left(\left(\frac{\left(x.re \cdot x.im\right)}{\left(x.im \cdot x.re\right)}\right) \cdot x.im\right)\left(x.re + x.im\right) \cdot \left(\left(x.re - x.im\right) \cdot x.re\right) - \left(x.re \cdot x.im + x.im \cdot x.re\right) \cdot x.im
double f(double x_re, double x_im) {
double r279737 = x_re;
double r279738 = r279737 * r279737;
double r279739 = x_im;
double r279740 = r279739 * r279739;
double r279741 = r279738 - r279740;
double r279742 = r279741 * r279737;
double r279743 = r279737 * r279739;
double r279744 = r279739 * r279737;
double r279745 = r279743 + r279744;
double r279746 = r279745 * r279739;
double r279747 = r279742 - r279746;
return r279747;
}
double f(double x_re, double x_im) {
double r279748 = x_re;
double r279749 = x_im;
double r279750 = r279748 + r279749;
double r279751 = r279748 - r279749;
double r279752 = r279751 * r279748;
double r279753 = r279750 * r279752;
double r279754 = r279748 * r279749;
double r279755 = r279749 * r279748;
double r279756 = r279754 + r279755;
double r279757 = r279756 * r279749;
double r279758 = r279753 - r279757;
return r279758;
}



Bits error versus x.re



Bits error versus x.im
Initial program 0.4
rmApplied difference-of-squares0.4
Applied associate-*l*0.4
Final simplification0.4
herbie shell --seed 2019107 +o rules:numerics
(FPCore (x.re x.im)
:name "math.cube on complex, real part"
(-.p16 (*.p16 (-.p16 (*.p16 x.re x.re) (*.p16 x.im x.im)) x.re) (*.p16 (+.p16 (*.p16 x.re x.im) (*.p16 x.im x.re)) x.im)))