double f(double a, double b) {
double r42107833 = a;
double r42107834 = r42107833 * r42107833;
double r42107835 = b;
double r42107836 = r42107835 * r42107835;
double r42107837 = r42107834 + r42107836;
double r42107838 = 2.0;
double r42107839 = pow(r42107837, r42107838);
double r42107840 = 4.0;
double r42107841 = r42107840 * r42107836;
double r42107842 = r42107839 + r42107841;
double r42107843 = 1.0;
double r42107844 = r42107842 - r42107843;
return r42107844;
}
double f(double a, double b) {
double r42107845 = 4.0;
double r42107846 = b;
double r42107847 = r42107846 * r42107846;
double r42107848 = r42107845 * r42107847;
double r42107849 = a;
double r42107850 = r42107849 * r42107849;
double r42107851 = r42107847 + r42107850;
double r42107852 = sqrt(r42107851);
double r42107853 = pow(r42107852, r42107845);
double r42107854 = r42107848 + r42107853;
double r42107855 = 1.0;
double r42107856 = r42107854 - r42107855;
return r42107856;
}
\left({\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(b \cdot b\right)\right) - 1\left(4 \cdot \left(b \cdot b\right) + {\left(\sqrt{b \cdot b + a \cdot a}\right)}^{4}\right) - 1


Bits error versus a



Bits error versus b
Initial program 0.2
Simplified0.2
rmApplied add-sqr-sqrt0.2
Applied associate-*l*0.1
rmApplied add-sqr-sqrt0.1
Applied cube-unmult0.1
Applied pow10.1
Applied pow-prod-up0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019102
(FPCore (a b)
:name "Bouland and Aaronson, Equation (26)"
(- (+ (pow (+ (* a a) (* b b)) 2) (* 4 (* b b))) 1))