\sqrt{\left(x \cdot x + y \cdot y\right) + z \cdot z}\begin{array}{l}
\mathbf{if}\;y \leq -1.142587537217585 \cdot 10^{+41}:\\
\;\;\;\;-y\\
\mathbf{elif}\;y \leq 8.085929679523052 \cdot 10^{+109}:\\
\;\;\;\;\sqrt{\left(x \cdot x + y \cdot y\right) + z \cdot z}\\
\mathbf{else}:\\
\;\;\;\;y\\
\end{array}(FPCore (x y z) :precision binary64 (sqrt (+ (+ (* x x) (* y y)) (* z z))))
(FPCore (x y z)
:precision binary64
(if (<= y -1.142587537217585e+41)
(- y)
(if (<= y 8.085929679523052e+109)
(sqrt (+ (+ (* x x) (* y y)) (* z z)))
y)))double code(double x, double y, double z) {
return sqrt(((x * x) + (y * y)) + (z * z));
}
double code(double x, double y, double z) {
double tmp;
if (y <= -1.142587537217585e+41) {
tmp = -y;
} else if (y <= 8.085929679523052e+109) {
tmp = sqrt(((x * x) + (y * y)) + (z * z));
} else {
tmp = y;
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 37.5 |
|---|---|
| Target | 25.3 |
| Herbie | 25.8 |
if y < -1.142587537217585e41Initial program 48.5
Taylor expanded around -inf 23.4
if -1.142587537217585e41 < y < 8.085929679523052e109Initial program 28.7
if 8.085929679523052e109 < y Initial program 56.7
Taylor expanded around inf 17.8
Final simplification25.8
herbie shell --seed 2021023
(FPCore (x y z)
:name "FRP.Yampa.Vector3:vector3Rho from Yampa-0.10.2"
:precision binary64
:herbie-target
(if (< z -6.396479394109776e+136) (- z) (if (< z 7.320293694404182e+117) (sqrt (+ (+ (* z z) (* x x)) (* y y))) z))
(sqrt (+ (+ (* x x) (* y y)) (* z z))))