\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(\left(\sqrt[3]{\left(\left(a \cdot a\right) \cdot \left(a + 1\right) + \left(b \cdot b\right) \cdot \left(1 - 3 \cdot a\right)\right) \cdot 4} \cdot \sqrt[3]{\left(\left(a \cdot a\right) \cdot \left(a + 1\right) + \left(b \cdot b\right) \cdot \left(1 - 3 \cdot a\right)\right) \cdot 4}\right) \cdot \sqrt[3]{\left(\left(a \cdot a\right) \cdot \left(a + 1\right) + \left(b \cdot b\right) \cdot \left(1 - 3 \cdot a\right)\right) \cdot 4} + {\left(a \cdot a + b \cdot b\right)}^{2}\right) - 1double f(double a, double b) {
double r7371224 = a;
double r7371225 = r7371224 * r7371224;
double r7371226 = b;
double r7371227 = r7371226 * r7371226;
double r7371228 = r7371225 + r7371227;
double r7371229 = 2.0;
double r7371230 = pow(r7371228, r7371229);
double r7371231 = 4.0;
double r7371232 = 1.0;
double r7371233 = r7371232 + r7371224;
double r7371234 = r7371225 * r7371233;
double r7371235 = 3.0;
double r7371236 = r7371235 * r7371224;
double r7371237 = r7371232 - r7371236;
double r7371238 = r7371227 * r7371237;
double r7371239 = r7371234 + r7371238;
double r7371240 = r7371231 * r7371239;
double r7371241 = r7371230 + r7371240;
double r7371242 = r7371241 - r7371232;
return r7371242;
}
double f(double a, double b) {
double r7371243 = a;
double r7371244 = r7371243 * r7371243;
double r7371245 = 1.0;
double r7371246 = r7371243 + r7371245;
double r7371247 = r7371244 * r7371246;
double r7371248 = b;
double r7371249 = r7371248 * r7371248;
double r7371250 = 3.0;
double r7371251 = r7371250 * r7371243;
double r7371252 = r7371245 - r7371251;
double r7371253 = r7371249 * r7371252;
double r7371254 = r7371247 + r7371253;
double r7371255 = 4.0;
double r7371256 = r7371254 * r7371255;
double r7371257 = cbrt(r7371256);
double r7371258 = r7371257 * r7371257;
double r7371259 = r7371258 * r7371257;
double r7371260 = r7371244 + r7371249;
double r7371261 = 2.0;
double r7371262 = pow(r7371260, r7371261);
double r7371263 = r7371259 + r7371262;
double r7371264 = r7371263 - r7371245;
return r7371264;
}



Bits error versus a



Bits error versus b
Results
Initial program 0.2
rmApplied add-cube-cbrt0.2
Final simplification0.2
herbie shell --seed 2019172
(FPCore (a b)
:name "Bouland and Aaronson, Equation (25)"
(- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (+ 1.0 a)) (* (* b b) (- 1.0 (* 3.0 a)))))) 1.0))