x \cdot \sqrt{y \cdot y - z \cdot z}\begin{array}{l}
\mathbf{if}\;y \leq -5.421599144526907 \cdot 10^{-227}:\\
\;\;\;\;x \cdot \left(-y\right)\\
\mathbf{else}:\\
\;\;\;\;y \cdot x\\
\end{array}(FPCore (x y z) :precision binary64 (* x (sqrt (- (* y y) (* z z)))))
(FPCore (x y z) :precision binary64 (if (<= y -5.421599144526907e-227) (* x (- y)) (* y x)))
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.421599144526907e-227) {
tmp = x * -y;
} else {
tmp = y * x;
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 25.0 |
|---|---|
| Target | 0.6 |
| Herbie | 1.0 |
if y < -5.4215991445269071e-227Initial program 25.1
Taylor expanded around -inf 0.6
Simplified0.6
if -5.4215991445269071e-227 < y Initial program 24.9
Taylor expanded around inf 1.3
Final simplification1.0
herbie shell --seed 2020219
(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)))))