\[ \begin{array}{c}[x, y, z] = \mathsf{sort}([x, y, z])\\ \end{array} \]
Math FPCore C Fortran Java Python Julia MATLAB Wolfram TeX \[2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}
\]
↓
\[\begin{array}{l}
\mathbf{if}\;y \leq 0:\\
\;\;\;\;2 \cdot \sqrt{\left(y + z\right) \cdot x}\\
\mathbf{else}:\\
\;\;\;\;2 \cdot \left(\sqrt{y + x} \cdot \sqrt{z}\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 0.0)
(* 2.0 (sqrt (* (+ y z) x)))
(* 2.0 (* (sqrt (+ y x)) (sqrt z))))) 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 <= 0.0) {
tmp = 2.0 * sqrt(((y + z) * x));
} else {
tmp = 2.0 * (sqrt((y + x)) * sqrt(z));
}
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 <= 0.0d0) then
tmp = 2.0d0 * sqrt(((y + z) * x))
else
tmp = 2.0d0 * (sqrt((y + x)) * sqrt(z))
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 <= 0.0) {
tmp = 2.0 * Math.sqrt(((y + z) * x));
} else {
tmp = 2.0 * (Math.sqrt((y + x)) * Math.sqrt(z));
}
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 <= 0.0:
tmp = 2.0 * math.sqrt(((y + z) * x))
else:
tmp = 2.0 * (math.sqrt((y + x)) * math.sqrt(z))
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 <= 0.0)
tmp = Float64(2.0 * sqrt(Float64(Float64(y + z) * x)));
else
tmp = Float64(2.0 * Float64(sqrt(Float64(y + x)) * sqrt(z)));
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 <= 0.0)
tmp = 2.0 * sqrt(((y + z) * x));
else
tmp = 2.0 * (sqrt((y + x)) * sqrt(z));
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, 0.0], N[(2.0 * N[Sqrt[N[(N[(y + z), $MachinePrecision] * x), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(2.0 * N[(N[Sqrt[N[(y + x), $MachinePrecision]], $MachinePrecision] * N[Sqrt[z], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}
↓
\begin{array}{l}
\mathbf{if}\;y \leq 0:\\
\;\;\;\;2 \cdot \sqrt{\left(y + z\right) \cdot x}\\
\mathbf{else}:\\
\;\;\;\;2 \cdot \left(\sqrt{y + x} \cdot \sqrt{z}\right)\\
\end{array}