x \cdot \sqrt{y \cdot y - z \cdot z}
\begin{array}{l}
\mathbf{if}\;y \leq 3.382080778465714 \cdot 10^{-303}:\\
\;\;\;\;0.5 \cdot \frac{z \cdot \left(z \cdot x\right)}{y} - y \cdot x\\
\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 3.382080778465714e-303) (- (* 0.5 (/ (* z (* z x)) y)) (* y x)) (* 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 <= 3.382080778465714e-303) {
tmp = (0.5 * ((z * (z * x)) / y)) - (y * x);
} 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 | 1.2 |
if y < 3.38208077846571406e-303Initial program 24.5
Taylor expanded in y around -inf 3.5
Applied unpow2_binary643.5
Applied associate-*l*_binary641.9
if 3.38208077846571406e-303 < y Initial program 25.3
Applied difference-of-squares_binary6425.3
Applied sqrt-prod_binary640.4
Final simplification1.2
herbie shell --seed 2022077
(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)))))