x \cdot \sqrt{y \cdot y - z \cdot z}\begin{array}{l}
\mathbf{if}\;y \leq -4.559127035437363 \cdot 10^{-218}:\\
\;\;\;\;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 -4.559127035437363e-218) (* 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 <= -4.559127035437363e-218) {
tmp = x * -y;
} else {
tmp = y * x;
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 24.9 |
|---|---|
| Target | 0.5 |
| Herbie | 1.1 |
if y < -4.55912703543736309e-218Initial program 24.9
Taylor expanded around -inf 0.5
Simplified0.5
if -4.55912703543736309e-218 < y Initial program 24.9
Taylor expanded around inf 1.6
Final simplification1.1
herbie shell --seed 2021090
(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)))))