Average Error: 27.3 → 27.3
Time: 1.1s
Precision: binary64
\[\frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}\]
\[\frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}\]
\frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}
\frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}
double code(double p, double q, double r) {
	return ((double) (p / ((double) sqrt(((double) (0.5 * ((double) (((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (((double) (q - r)) * ((double) (q - r)))))) + ((double) (((double) (q - r)) * q))))))))));
}
double code(double p, double q, double r) {
	return ((double) (p / ((double) sqrt(((double) (0.5 * ((double) (((double) (((double) (((double) (4.0 * p)) * p)) + ((double) (((double) (q - r)) * ((double) (q - r)))))) + ((double) (((double) (q - r)) * q))))))))));
}

Error

Bits error versus p

Bits error versus q

Bits error versus r

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 27.3

    \[\frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}\]
  2. Final simplification27.3

    \[\leadsto \frac{p}{\sqrt{0.5 \cdot \left(\left(\left(4 \cdot p\right) \cdot p + \left(q - r\right) \cdot \left(q - r\right)\right) + \left(q - r\right) \cdot q\right)}}\]

Reproduce

herbie shell --seed 2020153 
(FPCore (p q r)
  :name "(/ p (sqrt (* 0.5 (+ (+ (* (* 4 p) p) (* (- q r) (- q r))) (* (- q r) q)))))"
  :precision binary64
  (/ p (sqrt (* 0.5 (+ (+ (* (* 4.0 p) p) (* (- q r) (- q r))) (* (- q r) q))))))