double f(double a, double b) {
double r29320728 = a;
double r29320729 = r29320728 * r29320728;
double r29320730 = b;
double r29320731 = r29320730 * r29320730;
double r29320732 = r29320729 + r29320731;
double r29320733 = 2.0;
double r29320734 = pow(r29320732, r29320733);
double r29320735 = 4.0;
double r29320736 = 1.0;
double r29320737 = r29320736 + r29320728;
double r29320738 = r29320729 * r29320737;
double r29320739 = 3.0;
double r29320740 = r29320739 * r29320728;
double r29320741 = r29320736 - r29320740;
double r29320742 = r29320731 * r29320741;
double r29320743 = r29320738 + r29320742;
double r29320744 = r29320735 * r29320743;
double r29320745 = r29320734 + r29320744;
double r29320746 = r29320745 - r29320736;
return r29320746;
}
double f(double a, double b) {
double r29320747 = 4.0;
double r29320748 = a;
double r29320749 = r29320748 * r29320748;
double r29320750 = 1.0;
double r29320751 = r29320750 + r29320748;
double r29320752 = r29320749 * r29320751;
double r29320753 = b;
double r29320754 = r29320753 * r29320753;
double r29320755 = 3.0;
double r29320756 = r29320748 * r29320755;
double r29320757 = r29320750 - r29320756;
double r29320758 = r29320754 * r29320757;
double r29320759 = r29320752 + r29320758;
double r29320760 = r29320747 * r29320759;
double r29320761 = 2.0;
double r29320762 = r29320749 * r29320761;
double r29320763 = fma(r29320753, r29320753, r29320762);
double r29320764 = r29320763 * r29320753;
double r29320765 = pow(r29320748, r29320747);
double r29320766 = fma(r29320753, r29320764, r29320765);
double r29320767 = r29320760 + r29320766;
double r29320768 = r29320767 - r29320750;
return r29320768;
}
\left({\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 + a\right) + \left(b \cdot b\right) \cdot \left(1 - 3 \cdot a\right)\right)\right) - 1\left(4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 + a\right) + \left(b \cdot b\right) \cdot \left(1 - a \cdot 3\right)\right) + (b \cdot \left((b \cdot b + \left(\left(a \cdot a\right) \cdot 2\right))_* \cdot b\right) + \left({a}^{4}\right))_*\right) - 1


Bits error versus a



Bits error versus b
Initial program 0.2
Taylor expanded around 0 0.0
Simplified0.2
rmApplied pow10.2
Applied pow-plus0.2
Applied pow10.2
Applied pow10.2
Applied pow-prod-up0.2
Applied pow-prod-up0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019102 +o rules:numerics
(FPCore (a b)
:name "Bouland and Aaronson, Equation (25)"
(- (+ (pow (+ (* a a) (* b b)) 2) (* 4 (+ (* (* a a) (+ 1 a)) (* (* b b) (- 1 (* 3 a)))))) 1))