\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(4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 - a\right) + \left(3 + a\right) \cdot \left(b \cdot b\right)\right) + \left({a}^{4} + \left(b \cdot \left(b \cdot b + \left(a \cdot a\right) \cdot 2\right)\right) \cdot b\right)\right) - 1double f(double a, double b) {
double r9618458 = a;
double r9618459 = r9618458 * r9618458;
double r9618460 = b;
double r9618461 = r9618460 * r9618460;
double r9618462 = r9618459 + r9618461;
double r9618463 = 2.0;
double r9618464 = pow(r9618462, r9618463);
double r9618465 = 4.0;
double r9618466 = 1.0;
double r9618467 = r9618466 - r9618458;
double r9618468 = r9618459 * r9618467;
double r9618469 = 3.0;
double r9618470 = r9618469 + r9618458;
double r9618471 = r9618461 * r9618470;
double r9618472 = r9618468 + r9618471;
double r9618473 = r9618465 * r9618472;
double r9618474 = r9618464 + r9618473;
double r9618475 = r9618474 - r9618466;
return r9618475;
}
double f(double a, double b) {
double r9618476 = 4.0;
double r9618477 = a;
double r9618478 = r9618477 * r9618477;
double r9618479 = 1.0;
double r9618480 = r9618479 - r9618477;
double r9618481 = r9618478 * r9618480;
double r9618482 = 3.0;
double r9618483 = r9618482 + r9618477;
double r9618484 = b;
double r9618485 = r9618484 * r9618484;
double r9618486 = r9618483 * r9618485;
double r9618487 = r9618481 + r9618486;
double r9618488 = r9618476 * r9618487;
double r9618489 = pow(r9618477, r9618476);
double r9618490 = 2.0;
double r9618491 = r9618478 * r9618490;
double r9618492 = r9618485 + r9618491;
double r9618493 = r9618484 * r9618492;
double r9618494 = r9618493 * r9618484;
double r9618495 = r9618489 + r9618494;
double r9618496 = r9618488 + r9618495;
double r9618497 = r9618496 - r9618479;
return r9618497;
}



Bits error versus a



Bits error versus b
Results
Initial program 0.2
Taylor expanded around 0 0.0
Simplified0.2
rmApplied pow10.2
Applied pow10.2
Applied pow-prod-up0.2
Applied pow10.2
Applied pow10.2
Applied pow-prod-up0.2
Applied pow-sqr0.1
Simplified0.1
rmApplied associate-*l*0.1
Final simplification0.1
herbie shell --seed 2019143
(FPCore (a b)
:name "Bouland and Aaronson, Equation (24)"
(- (+ (pow (+ (* a a) (* b b)) 2) (* 4 (+ (* (* a a) (- 1 a)) (* (* b b) (+ 3 a))))) 1))