re \cdot re - im \cdot im
\left(re + im\right) \cdot \left(re - im\right)
double f(double re, double im) {
double r304456 = re;
double r304457 = r304456 * r304456;
double r304458 = im;
double r304459 = r304458 * r304458;
double r304460 = r304457 - r304459;
return r304460;
}
double f(double re, double im) {
double r304461 = re;
double r304462 = im;
double r304463 = r304461 + r304462;
double r304464 = r304461 - r304462;
double r304465 = r304463 * r304464;
return r304465;
}



Bits error versus re



Bits error versus im
Results
Initial program 0.0
Taylor expanded around inf 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019151 +o rules:numerics
(FPCore (re im)
:name "math.square on complex, real part"
(- (* re re) (* im im)))