\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(\left(1 - 3 \cdot a\right) \cdot \left(b \cdot b\right) + \left(a \cdot a\right) \cdot \left(a + 1\right)\right) \cdot 4 + \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 r8900654 = a;
double r8900655 = r8900654 * r8900654;
double r8900656 = b;
double r8900657 = r8900656 * r8900656;
double r8900658 = r8900655 + r8900657;
double r8900659 = 2.0;
double r8900660 = pow(r8900658, r8900659);
double r8900661 = 4.0;
double r8900662 = 1.0;
double r8900663 = r8900662 + r8900654;
double r8900664 = r8900655 * r8900663;
double r8900665 = 3.0;
double r8900666 = r8900665 * r8900654;
double r8900667 = r8900662 - r8900666;
double r8900668 = r8900657 * r8900667;
double r8900669 = r8900664 + r8900668;
double r8900670 = r8900661 * r8900669;
double r8900671 = r8900660 + r8900670;
double r8900672 = r8900671 - r8900662;
return r8900672;
}
double f(double a, double b) {
double r8900673 = 1.0;
double r8900674 = 3.0;
double r8900675 = a;
double r8900676 = r8900674 * r8900675;
double r8900677 = r8900673 - r8900676;
double r8900678 = b;
double r8900679 = r8900678 * r8900678;
double r8900680 = r8900677 * r8900679;
double r8900681 = r8900675 * r8900675;
double r8900682 = r8900675 + r8900673;
double r8900683 = r8900681 * r8900682;
double r8900684 = r8900680 + r8900683;
double r8900685 = 4.0;
double r8900686 = r8900684 * r8900685;
double r8900687 = pow(r8900675, r8900685);
double r8900688 = 2.0;
double r8900689 = r8900681 * r8900688;
double r8900690 = r8900679 + r8900689;
double r8900691 = r8900678 * r8900690;
double r8900692 = r8900691 * r8900678;
double r8900693 = r8900687 + r8900692;
double r8900694 = r8900686 + r8900693;
double r8900695 = r8900694 - r8900673;
return r8900695;
}



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-prod-up0.1
Simplified0.1
rmApplied associate-*l*0.1
Final simplification0.1
herbie shell --seed 2019164
(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))