\frac{p}{\sqrt{\left(4 \cdot p\right) \cdot p + r \cdot r} \cdot \sqrt{0.5 \cdot \left(1 + \frac{r}{\sqrt{\left(4 \cdot p\right) \cdot p + r \cdot r}}\right)}}\frac{p}{\sqrt{\left(4 \cdot p\right) \cdot p + r \cdot r} \cdot \sqrt{0.5 \cdot \left(1 + \frac{r}{\sqrt{\left(4 \cdot p\right) \cdot p + r \cdot r}}\right)}}double code(double p, double r) {
return ((double) (p / ((double) (((double) sqrt(((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (r * r)))))) * ((double) sqrt(((double) (0.5 * ((double) (1.0 + ((double) (r / ((double) sqrt(((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (r * r))))))))))))))))));
}
double code(double p, double r) {
return ((double) (p / ((double) (((double) sqrt(((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (r * r)))))) * ((double) sqrt(((double) (0.5 * ((double) (1.0 + ((double) (r / ((double) sqrt(((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (r * r))))))))))))))))));
}



Bits error versus p



Bits error versus r
Results
Initial program 36.3
Final simplification36.3
herbie shell --seed 2020152
(FPCore (p r)
:name "(/ p (* (sqrt (+ (* (* 4 p) p) (* r r))) (sqrt (* 0.5 (+ 1 (/ r (sqrt (+ (* (* 4 p) p) (* r r)))))))))"
:precision binary64
(/ p (* (sqrt (+ (* (* 4.0 p) p) (* r r))) (sqrt (* 0.5 (+ 1.0 (/ r (sqrt (+ (* (* 4.0 p) p) (* r r))))))))))