\[ \begin{array}{c}[x, y, z] = \mathsf{sort}([x, y, z])\\ \end{array} \]
\[2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}
\]
↓
\[\begin{array}{l}
\mathbf{if}\;y \leq -1.35 \cdot 10^{+154}:\\
\;\;\;\;2 \cdot {\left(e^{0.25 \cdot \left(\log \left(\left(-z\right) - y\right) - \log \left(\frac{-1}{x}\right)\right)}\right)}^{2}\\
\mathbf{elif}\;y \leq -6.6 \cdot 10^{+40}:\\
\;\;\;\;2 \cdot \frac{\sqrt{\left(y + z\right) \cdot \left(y - z\right)}}{\sqrt{\frac{y - z}{x}}}\\
\mathbf{elif}\;y \leq 1.2 \cdot 10^{-280}:\\
\;\;\;\;2 \cdot \sqrt{\frac{x}{\frac{1}{y + z}} + y \cdot z}\\
\mathbf{else}:\\
\;\;\;\;2 \cdot \left(\sqrt{z} \cdot \sqrt{y}\right)\\
\end{array}
\]
(FPCore (x y z)
:precision binary64
(* 2.0 (sqrt (+ (+ (* x y) (* x z)) (* y z)))))
↓
(FPCore (x y z)
:precision binary64
(if (<= y -1.35e+154)
(* 2.0 (pow (exp (* 0.25 (- (log (- (- z) y)) (log (/ -1.0 x))))) 2.0))
(if (<= y -6.6e+40)
(* 2.0 (/ (sqrt (* (+ y z) (- y z))) (sqrt (/ (- y z) x))))
(if (<= y 1.2e-280)
(* 2.0 (sqrt (+ (/ x (/ 1.0 (+ y z))) (* y z))))
(* 2.0 (* (sqrt z) (sqrt y)))))))double code(double x, double y, double z) {
return 2.0 * sqrt((((x * y) + (x * z)) + (y * z)));
}
↓
double code(double x, double y, double z) {
double tmp;
if (y <= -1.35e+154) {
tmp = 2.0 * pow(exp((0.25 * (log((-z - y)) - log((-1.0 / x))))), 2.0);
} else if (y <= -6.6e+40) {
tmp = 2.0 * (sqrt(((y + z) * (y - z))) / sqrt(((y - z) / x)));
} else if (y <= 1.2e-280) {
tmp = 2.0 * sqrt(((x / (1.0 / (y + z))) + (y * z)));
} else {
tmp = 2.0 * (sqrt(z) * sqrt(y));
}
return tmp;
}
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
code = 2.0d0 * sqrt((((x * y) + (x * z)) + (y * z)))
end function
↓
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8) :: tmp
if (y <= (-1.35d+154)) then
tmp = 2.0d0 * (exp((0.25d0 * (log((-z - y)) - log(((-1.0d0) / x))))) ** 2.0d0)
else if (y <= (-6.6d+40)) then
tmp = 2.0d0 * (sqrt(((y + z) * (y - z))) / sqrt(((y - z) / x)))
else if (y <= 1.2d-280) then
tmp = 2.0d0 * sqrt(((x / (1.0d0 / (y + z))) + (y * z)))
else
tmp = 2.0d0 * (sqrt(z) * sqrt(y))
end if
code = tmp
end function
public static double code(double x, double y, double z) {
return 2.0 * Math.sqrt((((x * y) + (x * z)) + (y * z)));
}
↓
public static double code(double x, double y, double z) {
double tmp;
if (y <= -1.35e+154) {
tmp = 2.0 * Math.pow(Math.exp((0.25 * (Math.log((-z - y)) - Math.log((-1.0 / x))))), 2.0);
} else if (y <= -6.6e+40) {
tmp = 2.0 * (Math.sqrt(((y + z) * (y - z))) / Math.sqrt(((y - z) / x)));
} else if (y <= 1.2e-280) {
tmp = 2.0 * Math.sqrt(((x / (1.0 / (y + z))) + (y * z)));
} else {
tmp = 2.0 * (Math.sqrt(z) * Math.sqrt(y));
}
return tmp;
}
def code(x, y, z):
return 2.0 * math.sqrt((((x * y) + (x * z)) + (y * z)))
↓
def code(x, y, z):
tmp = 0
if y <= -1.35e+154:
tmp = 2.0 * math.pow(math.exp((0.25 * (math.log((-z - y)) - math.log((-1.0 / x))))), 2.0)
elif y <= -6.6e+40:
tmp = 2.0 * (math.sqrt(((y + z) * (y - z))) / math.sqrt(((y - z) / x)))
elif y <= 1.2e-280:
tmp = 2.0 * math.sqrt(((x / (1.0 / (y + z))) + (y * z)))
else:
tmp = 2.0 * (math.sqrt(z) * math.sqrt(y))
return tmp
function code(x, y, z)
return Float64(2.0 * sqrt(Float64(Float64(Float64(x * y) + Float64(x * z)) + Float64(y * z))))
end
↓
function code(x, y, z)
tmp = 0.0
if (y <= -1.35e+154)
tmp = Float64(2.0 * (exp(Float64(0.25 * Float64(log(Float64(Float64(-z) - y)) - log(Float64(-1.0 / x))))) ^ 2.0));
elseif (y <= -6.6e+40)
tmp = Float64(2.0 * Float64(sqrt(Float64(Float64(y + z) * Float64(y - z))) / sqrt(Float64(Float64(y - z) / x))));
elseif (y <= 1.2e-280)
tmp = Float64(2.0 * sqrt(Float64(Float64(x / Float64(1.0 / Float64(y + z))) + Float64(y * z))));
else
tmp = Float64(2.0 * Float64(sqrt(z) * sqrt(y)));
end
return tmp
end
function tmp = code(x, y, z)
tmp = 2.0 * sqrt((((x * y) + (x * z)) + (y * z)));
end
↓
function tmp_2 = code(x, y, z)
tmp = 0.0;
if (y <= -1.35e+154)
tmp = 2.0 * (exp((0.25 * (log((-z - y)) - log((-1.0 / x))))) ^ 2.0);
elseif (y <= -6.6e+40)
tmp = 2.0 * (sqrt(((y + z) * (y - z))) / sqrt(((y - z) / x)));
elseif (y <= 1.2e-280)
tmp = 2.0 * sqrt(((x / (1.0 / (y + z))) + (y * z)));
else
tmp = 2.0 * (sqrt(z) * sqrt(y));
end
tmp_2 = tmp;
end
code[x_, y_, z_] := N[(2.0 * N[Sqrt[N[(N[(N[(x * y), $MachinePrecision] + N[(x * z), $MachinePrecision]), $MachinePrecision] + N[(y * z), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
↓
code[x_, y_, z_] := If[LessEqual[y, -1.35e+154], N[(2.0 * N[Power[N[Exp[N[(0.25 * N[(N[Log[N[((-z) - y), $MachinePrecision]], $MachinePrecision] - N[Log[N[(-1.0 / x), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], If[LessEqual[y, -6.6e+40], N[(2.0 * N[(N[Sqrt[N[(N[(y + z), $MachinePrecision] * N[(y - z), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / N[Sqrt[N[(N[(y - z), $MachinePrecision] / x), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[y, 1.2e-280], N[(2.0 * N[Sqrt[N[(N[(x / N[(1.0 / N[(y + z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(y * z), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(2.0 * N[(N[Sqrt[z], $MachinePrecision] * N[Sqrt[y], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]
2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}
↓
\begin{array}{l}
\mathbf{if}\;y \leq -1.35 \cdot 10^{+154}:\\
\;\;\;\;2 \cdot {\left(e^{0.25 \cdot \left(\log \left(\left(-z\right) - y\right) - \log \left(\frac{-1}{x}\right)\right)}\right)}^{2}\\
\mathbf{elif}\;y \leq -6.6 \cdot 10^{+40}:\\
\;\;\;\;2 \cdot \frac{\sqrt{\left(y + z\right) \cdot \left(y - z\right)}}{\sqrt{\frac{y - z}{x}}}\\
\mathbf{elif}\;y \leq 1.2 \cdot 10^{-280}:\\
\;\;\;\;2 \cdot \sqrt{\frac{x}{\frac{1}{y + z}} + y \cdot z}\\
\mathbf{else}:\\
\;\;\;\;2 \cdot \left(\sqrt{z} \cdot \sqrt{y}\right)\\
\end{array}