\sqrt{\left(a + c\right) \cdot \left(a + c\right) - \left(a \cdot c + b \cdot b\right)}\sqrt{\left(a + c\right) \cdot \left(a + c\right) - \left(a \cdot c + b \cdot b\right)}double code(double a, double c, double b) {
return ((double) sqrt(((double) (((double) (((double) (a + c)) * ((double) (a + c)))) - ((double) (((double) (a * c)) + ((double) (b * b))))))));
}
double code(double a, double c, double b) {
return ((double) sqrt(((double) (((double) (((double) (a + c)) * ((double) (a + c)))) - ((double) (((double) (a * c)) + ((double) (b * b))))))));
}



Bits error versus a



Bits error versus c



Bits error versus b
Results
Initial program 38.0
Final simplification38.0
herbie shell --seed 2020153
(FPCore (a c b)
:name "(sqrt (- (* (+ a c) (+ a c)) (+ (* a c) (* b b))))"
:precision binary64
(sqrt (- (* (+ a c) (+ a c)) (+ (* a c) (* b b)))))