\left(x.re \cdot x.re - x.im \cdot x.im\right) \cdot x.im + \left(x.re \cdot x.im + x.im \cdot x.re\right) \cdot x.re
\mathsf{fma}\left(x.im + x.re, \left(x.re - x.im\right) \cdot x.im, \left(x.re \cdot x.im + x.re \cdot x.im\right) \cdot x.re\right)double f(double x_re, double x_im) {
double r9011523 = x_re;
double r9011524 = r9011523 * r9011523;
double r9011525 = x_im;
double r9011526 = r9011525 * r9011525;
double r9011527 = r9011524 - r9011526;
double r9011528 = r9011527 * r9011525;
double r9011529 = r9011523 * r9011525;
double r9011530 = r9011525 * r9011523;
double r9011531 = r9011529 + r9011530;
double r9011532 = r9011531 * r9011523;
double r9011533 = r9011528 + r9011532;
return r9011533;
}
double f(double x_re, double x_im) {
double r9011534 = x_im;
double r9011535 = x_re;
double r9011536 = r9011534 + r9011535;
double r9011537 = r9011535 - r9011534;
double r9011538 = r9011537 * r9011534;
double r9011539 = r9011535 * r9011534;
double r9011540 = r9011539 + r9011539;
double r9011541 = r9011540 * r9011535;
double r9011542 = fma(r9011536, r9011538, r9011541);
return r9011542;
}




Bits error versus x.re




Bits error versus x.im
| Original | 7.4 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 7.4
rmApplied difference-of-squares7.4
Applied associate-*l*0.2
rmApplied fma-def0.2
Final simplification0.2
herbie shell --seed 2019170 +o rules:numerics
(FPCore (x.re x.im)
:name "math.cube on complex, imaginary part"
:herbie-target
(+ (* (* x.re x.im) (* 2.0 x.re)) (* (* x.im (- x.re x.im)) (+ x.re x.im)))
(+ (* (- (* x.re x.re) (* x.im x.im)) x.im) (* (+ (* x.re x.im) (* x.im x.re)) x.re)))