\sqrt{\left(\left(\left(4 \cdot b\right) \cdot b\right) \cdot M\right) \cdot M - \left(a \cdot a + b \cdot b\right) \cdot \left(b \cdot b + \left(a - d\right) \cdot \left(a - d\right)\right)}\sqrt{\left(\left(\left(4 \cdot b\right) \cdot b\right) \cdot M\right) \cdot M - \left(a \cdot a + b \cdot b\right) \cdot \left(b \cdot b + \left(a - d\right) \cdot \left(a - d\right)\right)}double code(double b, double M, double a, double d) {
return ((double) sqrt(((double) (((double) (((double) (((double) (((double) (4.0 * b)) * b)) * M)) * M)) - ((double) (((double) (((double) (a * a)) + ((double) (b * b)))) * ((double) (((double) (b * b)) + ((double) (((double) (a - d)) * ((double) (a - d))))))))))));
}
double code(double b, double M, double a, double d) {
return ((double) sqrt(((double) (((double) (((double) (((double) (((double) (4.0 * b)) * b)) * M)) * M)) - ((double) (((double) (((double) (a * a)) + ((double) (b * b)))) * ((double) (((double) (b * b)) + ((double) (((double) (a - d)) * ((double) (a - d))))))))))));
}



Bits error versus b



Bits error versus M



Bits error versus a



Bits error versus d
Results
Initial program 41.1
Final simplification41.1
herbie shell --seed 2020152
(FPCore (b M a d)
:name "(sqrt (- (* (* (* (* 4.0 b) b) M) M) (* (+ (* a a) (* b b)) (+ (* b b) (* (- a d) (- a d))))))"
:precision binary64
(sqrt (- (* (* (* (* 4.0 b) b) M) M) (* (+ (* a a) (* b b)) (+ (* b b) (* (- a d) (- a d)))))))