double code(double A, double B, double C, double F) {
return -sqrt(((2.0 * ((pow(B, 2.0) - ((4.0 * A) * C)) * F)) * ((A + C) - sqrt((pow((A - C), 2.0) + pow(B, 2.0)))))) / (pow(B, 2.0) - ((4.0 * A) * C));
}
↓
double code(double A, double B, double C, double F) {
double t_0 = fma(B, B, (A * (C * -4.0)));
double t_1 = hypot(B, (A - C));
double tmp;
if (C <= 8.5e-288) {
tmp = -sqrt((2.0 * ((F * t_0) * (C + (A - t_1))))) / t_0;
} else if (C <= 7.2e+53) {
tmp = (sqrt((F * (A + (C - t_1)))) * -sqrt((2.0 * t_0))) / t_0;
} else {
tmp = -(sqrt((t_0 * ((A + (A + (0.5 * (((pow(-A, 2.0) - (A * A)) - (B * B)) / C)))) * (2.0 * F)))) / t_0);
}
return tmp;
}
function code(A, B, C, F)
return Float64(Float64(-sqrt(Float64(Float64(2.0 * Float64(Float64((B ^ 2.0) - Float64(Float64(4.0 * A) * C)) * F)) * Float64(Float64(A + C) - sqrt(Float64((Float64(A - C) ^ 2.0) + (B ^ 2.0))))))) / Float64((B ^ 2.0) - Float64(Float64(4.0 * A) * C)))
end
↓
function code(A, B, C, F)
t_0 = fma(B, B, Float64(A * Float64(C * -4.0)))
t_1 = hypot(B, Float64(A - C))
tmp = 0.0
if (C <= 8.5e-288)
tmp = Float64(Float64(-sqrt(Float64(2.0 * Float64(Float64(F * t_0) * Float64(C + Float64(A - t_1)))))) / t_0);
elseif (C <= 7.2e+53)
tmp = Float64(Float64(sqrt(Float64(F * Float64(A + Float64(C - t_1)))) * Float64(-sqrt(Float64(2.0 * t_0)))) / t_0);
else
tmp = Float64(-Float64(sqrt(Float64(t_0 * Float64(Float64(A + Float64(A + Float64(0.5 * Float64(Float64(Float64((Float64(-A) ^ 2.0) - Float64(A * A)) - Float64(B * B)) / C)))) * Float64(2.0 * F)))) / t_0));
end
return tmp
end
code[A_, B_, C_, F_] := N[((-N[Sqrt[N[(N[(2.0 * N[(N[(N[Power[B, 2.0], $MachinePrecision] - N[(N[(4.0 * A), $MachinePrecision] * C), $MachinePrecision]), $MachinePrecision] * F), $MachinePrecision]), $MachinePrecision] * N[(N[(A + C), $MachinePrecision] - N[Sqrt[N[(N[Power[N[(A - C), $MachinePrecision], 2.0], $MachinePrecision] + N[Power[B, 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]) / N[(N[Power[B, 2.0], $MachinePrecision] - N[(N[(4.0 * A), $MachinePrecision] * C), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
↓
code[A_, B_, C_, F_] := Block[{t$95$0 = N[(B * B + N[(A * N[(C * -4.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sqrt[B ^ 2 + N[(A - C), $MachinePrecision] ^ 2], $MachinePrecision]}, If[LessEqual[C, 8.5e-288], N[((-N[Sqrt[N[(2.0 * N[(N[(F * t$95$0), $MachinePrecision] * N[(C + N[(A - t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]) / t$95$0), $MachinePrecision], If[LessEqual[C, 7.2e+53], N[(N[(N[Sqrt[N[(F * N[(A + N[(C - t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * (-N[Sqrt[N[(2.0 * t$95$0), $MachinePrecision]], $MachinePrecision])), $MachinePrecision] / t$95$0), $MachinePrecision], (-N[(N[Sqrt[N[(t$95$0 * N[(N[(A + N[(A + N[(0.5 * N[(N[(N[(N[Power[(-A), 2.0], $MachinePrecision] - N[(A * A), $MachinePrecision]), $MachinePrecision] - N[(B * B), $MachinePrecision]), $MachinePrecision] / C), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(2.0 * F), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / t$95$0), $MachinePrecision])]]]]