\frac{p \cdot q}{\sqrt{p \cdot p + \left(q - r\right) \cdot \left(\left(q - r\right) + \sqrt{p \cdot p + \left(q - r\right) \cdot \left(q - r\right)}\right)}}\frac{p \cdot q}{\sqrt{p \cdot p + \left(q - r\right) \cdot \left(\left(q - r\right) + \sqrt{p \cdot p + \left(q - r\right) \cdot \left(q - r\right)}\right)}}double code(double p, double q, double r) {
return ((double) (((double) (p * q)) / ((double) sqrt(((double) (((double) (p * p)) + ((double) (((double) (q - r)) * ((double) (((double) (q - r)) + ((double) sqrt(((double) (((double) (p * p)) + ((double) (((double) (q - r)) * ((double) (q - r))))))))))))))))));
}
double code(double p, double q, double r) {
return ((double) (((double) (p * q)) / ((double) sqrt(((double) (((double) (p * p)) + ((double) (((double) (q - r)) * ((double) (((double) (q - r)) + ((double) sqrt(((double) (((double) (p * p)) + ((double) (((double) (q - r)) * ((double) (q - r))))))))))))))))));
}



Bits error versus p



Bits error versus q



Bits error versus r
Results
Initial program 43.2
Final simplification43.2
herbie shell --seed 2020153
(FPCore (p q r)
:name "(/ (* p q) (sqrt (+ (* p p) (* (- q r) (+ (- q r) (sqrt (+ (* p p) (* (- q r) (- q r)))))))))"
:precision binary64
(/ (* p q) (sqrt (+ (* p p) (* (- q r) (+ (- q r) (sqrt (+ (* p p) (* (- q r) (- q r))))))))))