41 curve_coef[0] = p1[dim];
42 curve_coef[1] = 0.5f * (-p0[dim] + p2[dim]);
43 curve_coef[2] = 0.5f * (2 * p0[dim] - 5 * p1[dim] + 4 * p2[dim] - p3[dim]);
44 curve_coef[3] = 0.5f * (-p0[dim] + 3 * p1[dim] - 3 * p2[dim] + p3[dim]);
46 float discroot = curve_coef[2] * curve_coef[2] - 3 * curve_coef[3] * curve_coef[1];
51 discroot =
sqrtf(discroot);
52 ta = (-curve_coef[2] - discroot) / (3 * curve_coef[3]);
53 tb = (-curve_coef[2] + discroot) / (3 * curve_coef[3]);
54 ta = (ta > 1.0f || ta < 0.0f) ? -1.0f : ta;
55 tb = (tb > 1.0f || tb < 0.0f) ? -1.0f : tb;
58 *upper =
max(p1[dim], p2[dim]);
59 *lower =
min(p1[dim], p2[dim]);
67 exa = curve_coef[3] * t3 + curve_coef[2] * t2 + curve_coef[1] * ta + curve_coef[0];
72 exb = curve_coef[3] * t3 + curve_coef[2] * t2 + curve_coef[1] * tb + curve_coef[0];
75 *upper =
max(*upper,
max(exa, exb));
76 *lower =
min(*lower,
min(exa, exb));
CCL_NAMESPACE_BEGIN void curvebounds(float *lower, float *upper, float3 *p, int dim)
#define CCL_NAMESPACE_END