\frac{1}{\sqrt{\left(a - b\right) \cdot \left(a - b\right) + r \cdot r}} - \frac{1}{\sqrt{\left(a + b\right) \cdot \left(a + b\right) + r \cdot r}}\frac{1}{\sqrt{\left(a - b\right) \cdot \left(a - b\right) + r \cdot r}} - \frac{1}{\sqrt{\left(a + b\right) \cdot \left(a + b\right) + r \cdot r}}double code(double a, double b, double r) {
return ((double) (((double) (1.0 / ((double) sqrt(((double) (((double) (((double) (a - b)) * ((double) (a - b)))) + ((double) (r * r)))))))) - ((double) (1.0 / ((double) sqrt(((double) (((double) (((double) (a + b)) * ((double) (a + b)))) + ((double) (r * r))))))))));
}
double code(double a, double b, double r) {
return ((double) (((double) (1.0 / ((double) sqrt(((double) (((double) (((double) (a - b)) * ((double) (a - b)))) + ((double) (r * r)))))))) - ((double) (1.0 / ((double) sqrt(((double) (((double) (((double) (a + b)) * ((double) (a + b)))) + ((double) (r * r))))))))));
}



Bits error versus a



Bits error versus b



Bits error versus r
Results
Initial program 18.5
Final simplification18.5
herbie shell --seed 2020153
(FPCore (a b r)
:name "(- (/ 1 (sqrt (+ (* (- a b) (- a b)) (* r r)))) (/ 1 (sqrt (+ (* (+ a b) (+ a b)) (* r r)))))"
:precision binary64
(- (/ 1.0 (sqrt (+ (* (- a b) (- a b)) (* r r)))) (/ 1.0 (sqrt (+ (* (+ a b) (+ a b)) (* r r))))))