\sqrt{x \cdot x + y \cdot y}\begin{array}{l}
\mathbf{if}\;x \le -9.340803523077166 \cdot 10^{+139}:\\
\;\;\;\;-x\\
\mathbf{elif}\;x \le -4.786656859853452 \cdot 10^{-266}:\\
\;\;\;\;\sqrt{x \cdot x + y \cdot y}\\
\mathbf{elif}\;x \le -2.7978321376001454 \cdot 10^{-306}:\\
\;\;\;\;y\\
\mathbf{elif}\;x \le 1.2882041961296455 \cdot 10^{+92}:\\
\;\;\;\;\sqrt{x \cdot x + y \cdot y}\\
\mathbf{else}:\\
\;\;\;\;x\\
\end{array}double code(double x, double y) {
return ((double) sqrt(((double) (((double) (x * x)) + ((double) (y * y))))));
}
double code(double x, double y) {
double VAR;
if ((x <= -9.340803523077166e+139)) {
VAR = ((double) -(x));
} else {
double VAR_1;
if ((x <= -4.786656859853452e-266)) {
VAR_1 = ((double) sqrt(((double) (((double) (x * x)) + ((double) (y * y))))));
} else {
double VAR_2;
if ((x <= -2.7978321376001454e-306)) {
VAR_2 = y;
} else {
double VAR_3;
if ((x <= 1.2882041961296455e+92)) {
VAR_3 = ((double) sqrt(((double) (((double) (x * x)) + ((double) (y * y))))));
} else {
VAR_3 = x;
}
VAR_2 = VAR_3;
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y
Results
| Original | 31.6 |
|---|---|
| Target | 17.8 |
| Herbie | 17.9 |
if x < -9.3408035230771657e139Initial program 60.5
Taylor expanded around -inf 8.4
Simplified8.4
if -9.3408035230771657e139 < x < -4.7866568598534521e-266 or -2.79783213760014545e-306 < x < 1.28820419612964551e92Initial program 20.8
if -4.7866568598534521e-266 < x < -2.79783213760014545e-306Initial program 31.2
Taylor expanded around 0 31.5
if 1.28820419612964551e92 < x Initial program 50.9
Taylor expanded around inf 11.5
Final simplification17.9
herbie shell --seed 2020184
(FPCore (x y)
:name "Data.Octree.Internal:octantDistance from Octree-0.5.4.2"
:precision binary64
:herbie-target
(if (< x -1.1236950826599826e+145) (- x) (if (< x 1.116557621183362e+93) (sqrt (+ (* x x) (* y y))) x))
(sqrt (+ (* x x) (* y y))))