\left(x.re \cdot x.re - x.im \cdot x.im\right) \cdot x.re - \left(x.re \cdot x.im + x.im \cdot x.re\right) \cdot x.im
\mathsf{fma}\left(x.im + x.re, \left(x.re - x.im\right) \cdot x.re, \left(\left(-x.im\right) \cdot x.re + \left(-x.im\right) \cdot x.re\right) \cdot x.im\right)double f(double x_re, double x_im) {
double r7288799 = x_re;
double r7288800 = r7288799 * r7288799;
double r7288801 = x_im;
double r7288802 = r7288801 * r7288801;
double r7288803 = r7288800 - r7288802;
double r7288804 = r7288803 * r7288799;
double r7288805 = r7288799 * r7288801;
double r7288806 = r7288801 * r7288799;
double r7288807 = r7288805 + r7288806;
double r7288808 = r7288807 * r7288801;
double r7288809 = r7288804 - r7288808;
return r7288809;
}
double f(double x_re, double x_im) {
double r7288810 = x_im;
double r7288811 = x_re;
double r7288812 = r7288810 + r7288811;
double r7288813 = r7288811 - r7288810;
double r7288814 = r7288813 * r7288811;
double r7288815 = -r7288810;
double r7288816 = r7288815 * r7288811;
double r7288817 = r7288816 + r7288816;
double r7288818 = r7288817 * r7288810;
double r7288819 = fma(r7288812, r7288814, r7288818);
return r7288819;
}




Bits error versus x.re




Bits error versus x.im
| Original | 7.0 |
|---|---|
| Target | 0.3 |
| Herbie | 0.2 |
Initial program 7.0
rmApplied difference-of-squares7.0
Applied associate-*l*0.3
rmApplied fma-neg0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019149 +o rules:numerics
(FPCore (x.re x.im)
:name "math.cube on complex, real part"
:herbie-target
(+ (* (* x.re x.re) (- x.re x.im)) (* (* x.re x.im) (- x.re (* 3 x.im))))
(- (* (- (* x.re x.re) (* x.im x.im)) x.re) (* (+ (* x.re x.im) (* x.im x.re)) x.im)))