\frac{\cos th}{\sqrt{2}} \cdot \left(a1 \cdot a1\right) + \frac{\cos th}{\sqrt{2}} \cdot \left(a2 \cdot a2\right)\frac{1}{\sqrt[3]{\sqrt[3]{\sqrt{2}}} \cdot \sqrt[3]{\sqrt[3]{\sqrt{2}}}} \cdot \frac{\frac{\cos th}{\sqrt[3]{\sqrt{2}}} \cdot \frac{\mathsf{fma}\left(a1, a1, a2 \cdot a2\right)}{\sqrt[3]{\sqrt{2}}}}{\sqrt[3]{\sqrt[3]{\sqrt{2}}}}double f(double a1, double a2, double th) {
double r118714 = th;
double r118715 = cos(r118714);
double r118716 = 2.0;
double r118717 = sqrt(r118716);
double r118718 = r118715 / r118717;
double r118719 = a1;
double r118720 = r118719 * r118719;
double r118721 = r118718 * r118720;
double r118722 = a2;
double r118723 = r118722 * r118722;
double r118724 = r118718 * r118723;
double r118725 = r118721 + r118724;
return r118725;
}
double f(double a1, double a2, double th) {
double r118726 = 1.0;
double r118727 = 2.0;
double r118728 = sqrt(r118727);
double r118729 = cbrt(r118728);
double r118730 = cbrt(r118729);
double r118731 = r118730 * r118730;
double r118732 = r118726 / r118731;
double r118733 = th;
double r118734 = cos(r118733);
double r118735 = r118734 / r118729;
double r118736 = a1;
double r118737 = a2;
double r118738 = r118737 * r118737;
double r118739 = fma(r118736, r118736, r118738);
double r118740 = r118739 / r118729;
double r118741 = r118735 * r118740;
double r118742 = r118741 / r118730;
double r118743 = r118732 * r118742;
return r118743;
}



Bits error versus a1



Bits error versus a2



Bits error versus th
Initial program 0.5
Simplified0.5
rmApplied add-cube-cbrt0.5
Applied associate-/r*0.5
rmApplied add-cube-cbrt0.5
Applied *-un-lft-identity0.5
Applied times-frac0.5
rmApplied times-frac0.5
Final simplification0.5
herbie shell --seed 2019347 +o rules:numerics
(FPCore (a1 a2 th)
:name "Migdal et al, Equation (64)"
:precision binary64
(+ (* (/ (cos th) (sqrt 2)) (* a1 a1)) (* (/ (cos th) (sqrt 2)) (* a2 a2))))