\left(\frac{\pi}{2} \cdot \frac{1}{b \cdot b - a \cdot a}\right) \cdot \left(\frac{1}{a} - \frac{1}{b}\right)\frac{\frac{\left(\pi \cdot 1\right) \cdot \left(\frac{1}{a} - \frac{1}{b}\right)}{b + a}}{2 \cdot \left(b - a\right)}double f(double a, double b) {
double r64322 = atan2(1.0, 0.0);
double r64323 = 2.0;
double r64324 = r64322 / r64323;
double r64325 = 1.0;
double r64326 = b;
double r64327 = r64326 * r64326;
double r64328 = a;
double r64329 = r64328 * r64328;
double r64330 = r64327 - r64329;
double r64331 = r64325 / r64330;
double r64332 = r64324 * r64331;
double r64333 = r64325 / r64328;
double r64334 = r64325 / r64326;
double r64335 = r64333 - r64334;
double r64336 = r64332 * r64335;
return r64336;
}
double f(double a, double b) {
double r64337 = atan2(1.0, 0.0);
double r64338 = 1.0;
double r64339 = r64337 * r64338;
double r64340 = a;
double r64341 = r64338 / r64340;
double r64342 = b;
double r64343 = r64338 / r64342;
double r64344 = r64341 - r64343;
double r64345 = r64339 * r64344;
double r64346 = r64342 + r64340;
double r64347 = r64345 / r64346;
double r64348 = 2.0;
double r64349 = r64342 - r64340;
double r64350 = r64348 * r64349;
double r64351 = r64347 / r64350;
return r64351;
}



Bits error versus a



Bits error versus b
Results
Initial program 14.5
rmApplied difference-of-squares9.7
Applied associate-/r*9.2
rmApplied frac-times9.2
Applied associate-*l/0.3
rmApplied associate-*r/0.3
Applied associate-*l/0.3
Final simplification0.3
herbie shell --seed 2020057 +o rules:numerics
(FPCore (a b)
:name "NMSE Section 6.1 mentioned, B"
:precision binary64
(* (* (/ PI 2) (/ 1 (- (* b b) (* a a)))) (- (/ 1 a) (/ 1 b))))