26int solve3(
double *coeff,
double *roots)
30 double p, q,
disc, b_over_3a, c_over_a, d_over_a;
31 double r, theta, temp,
alpha, beta;
33 a = coeff[3], b = coeff[2], c = coeff[1], d = coeff[0];
35 return solve2(coeff, roots);
36 b_over_3a = b / (3 * a);
40 p = b_over_3a * b_over_3a;
41 q = 2 * b_over_3a * p - b_over_3a * c_over_a + d_over_a;
43 disc = q * q + 4 * p * p * p;
46 r = .5 * sqrt(-
disc + q * q);
47 theta = atan2(sqrt(-
disc), -q);
49 roots[0] = temp * cos(theta / 3);
50 roots[1] = temp * cos((theta +
M_PI +
M_PI) / 3);
51 roots[2] = temp * cos((theta -
M_PI -
M_PI) / 3);
56 roots[0] = cbrt(
alpha) + cbrt(beta);
60 roots[1] = roots[2] = -.5 * roots[0], rootn = 3;
63 for (i = 0; i < rootn; i++)
64 roots[i] -= b_over_3a;