1 | export function basis(t1, v0, v1, v2, v3) {
|
2 | var t2 = t1 * t1, t3 = t2 * t1;
|
3 | return ((1 - 3 * t1 + 3 * t2 - t3) * v0
|
4 | + (4 - 6 * t2 + 3 * t3) * v1
|
5 | + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2
|
6 | + t3 * v3) / 6;
|
7 | }
|
8 |
|
9 | export default function(values) {
|
10 | var n = values.length - 1;
|
11 | return function(t) {
|
12 | var i = Math.min(n - 1, Math.floor(t * n)),
|
13 | v1 = values[i],
|
14 | v2 = values[i + 1],
|
15 | v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,
|
16 | v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;
|
17 | return basis((t - i / n) * n, v0, v1, v2, v3);
|
18 | };
|
19 | }
|