-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathmain.js
81 lines (56 loc) · 1.29 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
let time = 0;
let wave = [];
let MAX_POINTS = 1000;
let slider;
function setup() {
createCanvas(1500, 700);
slider = createSlider(1, 1000, 1, 1);
slider.value('1');
}
function draw() {
let radCircle = 30;
let radDot = 3;
background(0);
strokeWeight(3);
translate(200, 300);
stroke(255);
noFill();
let sum = new Complex({ re: 0, im: 0 });
for (let i = 1; i <= slider.value(); i += 1) {
let n = i;
// let n = i * 2 + 1;
// let n = i;
let prevSum = sum;
// let rad = radCircle * 2 * ( (-1) ** (n + 1) ) / n ;
// let rad = radCircle * 4 / n;
let rad = radCircle * 4 / n;
noFill();
stroke(255, 100);
ellipse(prevSum.re, prevSum.im, rad * 2);
let temp = new Complex({
arg: n * time,
abs: rad
});
sum = sum.add( temp );
stroke(255);
// fill(255);
line(prevSum.re, prevSum.im, sum.re, sum.im);
ellipse(sum.re, sum.im, radDot);
}
wave.unshift(sum.im);
let diff = 600;
translate(diff, 0);
line(sum.re - diff, sum.im, 0, wave[0]);
beginShape();
noFill();
stroke( color(34, 99, 237) );
for (let i = 0, maxi = wave.length; i < maxi; i += 1) {
vertex(i * 2, wave[i]);
}
endShape();
translate(-diff, 0);
time += 0.03;
if ( wave.length > MAX_POINTS ) {
wave.pop();
}
}