\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(3 + a\right)\right)\right) - 1\left(\sqrt[3]{{\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(3 + a\right)\right)} \cdot \sqrt[3]{{\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(3 + a\right)\right)}\right) \cdot \sqrt[3]{{\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(3 + a\right)\right)} - 1double f(double a, double b) {
double r242994 = a;
double r242995 = r242994 * r242994;
double r242996 = b;
double r242997 = r242996 * r242996;
double r242998 = r242995 + r242997;
double r242999 = 2.0;
double r243000 = pow(r242998, r242999);
double r243001 = 4.0;
double r243002 = 1.0;
double r243003 = r243002 - r242994;
double r243004 = r242995 * r243003;
double r243005 = 3.0;
double r243006 = r243005 + r242994;
double r243007 = r242997 * r243006;
double r243008 = r243004 + r243007;
double r243009 = r243001 * r243008;
double r243010 = r243000 + r243009;
double r243011 = r243010 - r243002;
return r243011;
}
double f(double a, double b) {
double r243012 = a;
double r243013 = r243012 * r243012;
double r243014 = b;
double r243015 = r243014 * r243014;
double r243016 = r243013 + r243015;
double r243017 = 2.0;
double r243018 = pow(r243016, r243017);
double r243019 = 4.0;
double r243020 = 1.0;
double r243021 = r243020 - r243012;
double r243022 = r243013 * r243021;
double r243023 = 3.0;
double r243024 = r243023 + r243012;
double r243025 = r243015 * r243024;
double r243026 = r243022 + r243025;
double r243027 = r243019 * r243026;
double r243028 = r243018 + r243027;
double r243029 = cbrt(r243028);
double r243030 = r243029 * r243029;
double r243031 = r243030 * r243029;
double r243032 = r243031 - r243020;
return r243032;
}



Bits error versus a



Bits error versus b
Results
Initial program 0.2
rmApplied add-cube-cbrt0.5
Final simplification0.5
herbie shell --seed 2020001
(FPCore (a b)
:name "Bouland and Aaronson, Equation (24)"
:precision binary64
(- (+ (pow (+ (* a a) (* b b)) 2) (* 4 (+ (* (* a a) (- 1 a)) (* (* b b) (+ 3 a))))) 1))