x \cdot \sqrt{y \cdot y - z \cdot z}
\begin{array}{l}
\mathbf{if}\;y \leq 4.105738868846895 \cdot 10^{-300}:\\
\;\;\;\;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 4.105738868846895e-300) (* 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 <= 4.105738868846895e-300) {
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 | 24.5 |
|---|---|
| Target | 0.5 |
| Herbie | 0.5 |
if y < 4.1057388688468948e-300Initial program 25.0
Taylor expanded in y around -inf 0.6
Simplified0.6
if 4.1057388688468948e-300 < y Initial program 24.0
Applied difference-of-squares_binary6424.0
Applied sqrt-prod_binary640.4
Final simplification0.5
herbie shell --seed 2021340
(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)))))