x \cdot \sqrt{y \cdot y - z \cdot z}
\begin{array}{l}
\mathbf{if}\;y \leq 2.206379454757968 \cdot 10^{-302}:\\
\;\;\;\;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 2.206379454757968e-302) (* 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 <= 2.206379454757968e-302) {
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.9 |
|---|---|
| Target | 0.6 |
| Herbie | 0.5 |
if y < 2.206379454757968e-302Initial program 24.3
Taylor expanded in y around -inf 0.6
Simplified0.6
if 2.206379454757968e-302 < y Initial program 25.5
Applied difference-of-squares_binary6425.5
Applied sqrt-prod_binary640.4
Final simplification0.5
herbie shell --seed 2022067
(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)))))