\left(\frac{\pi}{2} \cdot \frac{1}{b \cdot b - a \cdot a}\right) \cdot \left(\frac{1}{a} - \frac{1}{b}\right)\frac{\left(\frac{1}{a} - \frac{1}{b}\right) \cdot \left(\frac{\pi}{2} \cdot 1\right)}{b + a} \cdot \frac{1}{b - a}double f(double a, double b) {
double r50184 = atan2(1.0, 0.0);
double r50185 = 2.0;
double r50186 = r50184 / r50185;
double r50187 = 1.0;
double r50188 = b;
double r50189 = r50188 * r50188;
double r50190 = a;
double r50191 = r50190 * r50190;
double r50192 = r50189 - r50191;
double r50193 = r50187 / r50192;
double r50194 = r50186 * r50193;
double r50195 = r50187 / r50190;
double r50196 = r50187 / r50188;
double r50197 = r50195 - r50196;
double r50198 = r50194 * r50197;
return r50198;
}
double f(double a, double b) {
double r50199 = 1.0;
double r50200 = a;
double r50201 = r50199 / r50200;
double r50202 = b;
double r50203 = r50199 / r50202;
double r50204 = r50201 - r50203;
double r50205 = atan2(1.0, 0.0);
double r50206 = 2.0;
double r50207 = r50205 / r50206;
double r50208 = r50207 * r50199;
double r50209 = r50204 * r50208;
double r50210 = r50202 + r50200;
double r50211 = r50209 / r50210;
double r50212 = 1.0;
double r50213 = r50202 - r50200;
double r50214 = r50212 / r50213;
double r50215 = r50211 * r50214;
return r50215;
}



Bits error versus a



Bits error versus b
Results
Initial program 15.0
rmApplied difference-of-squares10.3
Applied add-sqr-sqrt10.3
Applied times-frac9.8
Applied associate-*r*9.8
rmApplied associate-*r/9.8
Applied associate-*l/0.3
Simplified0.3
rmApplied div-inv0.3
Final simplification0.3
herbie shell --seed 2020046
(FPCore (a b)
:name "NMSE Section 6.1 mentioned, B"
:precision binary64
(* (* (/ PI 2) (/ 1 (- (* b b) (* a a)))) (- (/ 1 a) (/ 1 b))))