\sqrt{x \cdot x + y \cdot y}\begin{array}{l}
\mathbf{if}\;y \le -3.4362841072323272 \cdot 10^{150}:\\
\;\;\;\;-1 \cdot y\\
\mathbf{elif}\;y \le -1.7874287404230692 \cdot 10^{-225}:\\
\;\;\;\;\sqrt{x \cdot x + y \cdot y}\\
\mathbf{elif}\;y \le 5.8993776144081826 \cdot 10^{-308}:\\
\;\;\;\;x\\
\mathbf{elif}\;y \le 2.4345784437110915 \cdot 10^{-199}:\\
\;\;\;\;-1 \cdot x\\
\mathbf{elif}\;y \le 1.7970794289179904 \cdot 10^{-166}:\\
\;\;\;\;x\\
\mathbf{elif}\;y \le 1.0688990210562475 \cdot 10^{-162}:\\
\;\;\;\;-1 \cdot x\\
\mathbf{elif}\;y \le 2.23402097896517821 \cdot 10^{109}:\\
\;\;\;\;\sqrt{x \cdot x + y \cdot y}\\
\mathbf{else}:\\
\;\;\;\;y\\
\end{array}double code(double x, double y) {
return sqrt(((x * x) + (y * y)));
}
double code(double x, double y) {
double temp;
if ((y <= -3.436284107232327e+150)) {
temp = (-1.0 * y);
} else {
double temp_1;
if ((y <= -1.7874287404230692e-225)) {
temp_1 = sqrt(((x * x) + (y * y)));
} else {
double temp_2;
if ((y <= 5.899377614408183e-308)) {
temp_2 = x;
} else {
double temp_3;
if ((y <= 2.4345784437110915e-199)) {
temp_3 = (-1.0 * x);
} else {
double temp_4;
if ((y <= 1.7970794289179904e-166)) {
temp_4 = x;
} else {
double temp_5;
if ((y <= 1.0688990210562475e-162)) {
temp_5 = (-1.0 * x);
} else {
double temp_6;
if ((y <= 2.2340209789651782e+109)) {
temp_6 = sqrt(((x * x) + (y * y)));
} else {
temp_6 = y;
}
temp_5 = temp_6;
}
temp_4 = temp_5;
}
temp_3 = temp_4;
}
temp_2 = temp_3;
}
temp_1 = temp_2;
}
temp = temp_1;
}
return temp;
}




Bits error versus x




Bits error versus y
Results
| Original | 31.7 |
|---|---|
| Target | 17.7 |
| Herbie | 18.1 |
if y < -3.436284107232327e+150Initial program 62.6
rmApplied flip-+64.0
Simplified64.0
Taylor expanded around -inf 8.8
if -3.436284107232327e+150 < y < -1.7874287404230692e-225 or 1.0688990210562475e-162 < y < 2.2340209789651782e+109Initial program 17.2
if -1.7874287404230692e-225 < y < 5.899377614408183e-308 or 2.4345784437110915e-199 < y < 1.7970794289179904e-166Initial program 31.5
Taylor expanded around inf 33.7
if 5.899377614408183e-308 < y < 2.4345784437110915e-199 or 1.7970794289179904e-166 < y < 1.0688990210562475e-162Initial program 31.3
Taylor expanded around -inf 35.2
if 2.2340209789651782e+109 < y Initial program 53.4
Taylor expanded around 0 9.8
Final simplification18.1
herbie shell --seed 2020060
(FPCore (x y)
:name "Data.Octree.Internal:octantDistance from Octree-0.5.4.2"
:precision binary64
:herbie-target
(if (< x -1.123695082659983e+145) (- x) (if (< x 1.116557621183362e+93) (sqrt (+ (* x x) (* y y))) x))
(sqrt (+ (* x x) (* y y))))