double code(double a, double b, double c) {
double tmp;
if (b >= 0.0) {
tmp = (2.0 * c) / (-b - sqrt(((b * b) - ((4.0 * a) * c))));
} else {
tmp = (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
return tmp;
}
↓
double code(double a, double b, double c) {
double t_0 = (2.0 * c) / -(b + b);
double t_1 = sqrt(((b * b) - (c * (4.0 * a))));
double tmp;
if (b >= 0.0) {
tmp = (2.0 * c) / (-b - t_1);
} else {
tmp = (t_1 - b) / (2.0 * a);
}
double t_2 = tmp;
double tmp_2;
if (t_2 <= -((double) INFINITY)) {
double tmp_3;
if (b >= 0.0) {
tmp_3 = t_0;
} else {
tmp_3 = (b * -2.0) / (2.0 * a);
}
tmp_2 = tmp_3;
} else if (t_2 <= -1e-285) {
tmp_2 = t_2;
} else if (t_2 <= 0.0) {
double tmp_4;
if (b >= 0.0) {
tmp_4 = (2.0 * c) / (2.0 * fma((c / b), a, -b));
} else {
tmp_4 = ((c * (a * -2.0)) / b) / (2.0 * a);
}
tmp_2 = tmp_4;
} else if (t_2 <= 1e+264) {
tmp_2 = t_2;
} else if (b >= 0.0) {
tmp_2 = t_0;
} else {
tmp_2 = (c / b) - (b / a);
}
return tmp_2;
}
function code(a, b, c)
tmp = 0.0
if (b >= 0.0)
tmp = Float64(Float64(2.0 * c) / Float64(Float64(-b) - sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))));
else
tmp = Float64(Float64(Float64(-b) + sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a));
end
return tmp
end
↓
function code(a, b, c)
t_0 = Float64(Float64(2.0 * c) / Float64(-Float64(b + b)))
t_1 = sqrt(Float64(Float64(b * b) - Float64(c * Float64(4.0 * a))))
tmp = 0.0
if (b >= 0.0)
tmp = Float64(Float64(2.0 * c) / Float64(Float64(-b) - t_1));
else
tmp = Float64(Float64(t_1 - b) / Float64(2.0 * a));
end
t_2 = tmp
tmp_2 = 0.0
if (t_2 <= Float64(-Inf))
tmp_3 = 0.0
if (b >= 0.0)
tmp_3 = t_0;
else
tmp_3 = Float64(Float64(b * -2.0) / Float64(2.0 * a));
end
tmp_2 = tmp_3;
elseif (t_2 <= -1e-285)
tmp_2 = t_2;
elseif (t_2 <= 0.0)
tmp_4 = 0.0
if (b >= 0.0)
tmp_4 = Float64(Float64(2.0 * c) / Float64(2.0 * fma(Float64(c / b), a, Float64(-b))));
else
tmp_4 = Float64(Float64(Float64(c * Float64(a * -2.0)) / b) / Float64(2.0 * a));
end
tmp_2 = tmp_4;
elseif (t_2 <= 1e+264)
tmp_2 = t_2;
elseif (b >= 0.0)
tmp_2 = t_0;
else
tmp_2 = Float64(Float64(c / b) - Float64(b / a));
end
return tmp_2
end
code[a_, b_, c_] := If[GreaterEqual[b, 0.0], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) - N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[((-b) + N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]]
↓
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(2.0 * c), $MachinePrecision] / (-N[(b + b), $MachinePrecision])), $MachinePrecision]}, Block[{t$95$1 = N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(c * N[(4.0 * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = If[GreaterEqual[b, 0.0], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) - t$95$1), $MachinePrecision]), $MachinePrecision], N[(N[(t$95$1 - b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]]}, If[LessEqual[t$95$2, (-Infinity)], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(b * -2.0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]], If[LessEqual[t$95$2, -1e-285], t$95$2, If[LessEqual[t$95$2, 0.0], If[GreaterEqual[b, 0.0], N[(N[(2.0 * c), $MachinePrecision] / N[(2.0 * N[(N[(c / b), $MachinePrecision] * a + (-b)), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(c * N[(a * -2.0), $MachinePrecision]), $MachinePrecision] / b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]], If[LessEqual[t$95$2, 1e+264], t$95$2, If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c / b), $MachinePrecision] - N[(b / a), $MachinePrecision]), $MachinePrecision]]]]]]]]]