x \cdot \sqrt{y \cdot y - z \cdot z}
\begin{array}{l}
\mathbf{if}\;y \leq 5.49680804289364 \cdot 10^{-305}:\\
\;\;\;\;x \cdot \left(-y\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(\sqrt{y + z} \cdot \sqrt{y - z}\right)\\
\end{array}
(FPCore (x y z) :precision binary64 (* x (sqrt (- (* y y) (* z z)))))
(FPCore (x y z) :precision binary64 (if (<= y 5.49680804289364e-305) (* x (- y)) (* x (* (sqrt (+ y z)) (sqrt (- y z))))))
double code(double x, double y, double z) {
return x * sqrt((y * y) - (z * z));
}
double code(double x, double y, double z) {
double tmp;
if (y <= 5.49680804289364e-305) {
tmp = x * -y;
} else {
tmp = x * (sqrt(y + z) * sqrt(y - z));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 25.5 |
|---|---|
| Target | 0.5 |
| Herbie | 0.5 |
if y < 5.4968080428936404e-305Initial program 25.7
Taylor expanded in y around -inf 0.6
Simplified0.6
if 5.4968080428936404e-305 < y Initial program 25.2
Applied difference-of-squares_binary6425.2
Applied sqrt-prod_binary640.4
Final simplification0.5
herbie shell --seed 2021275
(FPCore (x y z)
:name "Diagrams.TwoD.Apollonian:initialConfig from diagrams-contrib-1.3.0.5, B"
:precision binary64
:herbie-target
(if (< y 2.5816096488251695e-278) (- (* x y)) (* x (* (sqrt (+ y z)) (sqrt (- y z)))))
(* x (sqrt (- (* y y) (* z z)))))