-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.js
More file actions
executable file
·118 lines (106 loc) · 3.55 KB
/
main.js
File metadata and controls
executable file
·118 lines (106 loc) · 3.55 KB
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
function f(objectOfInputs, t, vars, dt) {
var {g, l, mr, mb, br, cr, bb, cb} = objectOfInputs;
var [theta, dtheta] = vars;
// Calculate derivatives
var mT = mb+mr/3;
var mV = mb+mr/2;
var d2theta = -g*mV/(mT*l)*Math.cos(theta) - (br+cr*l*Math.abs(dtheta)/2)/mT*dtheta/4 - (bb + cb*l*Math.abs(dtheta))/mT * dtheta;
// Put into return value
return [dt*dtheta, dt*d2theta];
}
function prntObj(obj) {
var keys = Object.keys(obj);
var N = keys.length;
var str = " ";
for (let i =0; i<N; i++) {
str += keys[i] + " = " + obj[keys[i]] + ", "
}
return str;
}
/**
* Generate phase plot of theta dot against theta
*
* @param solution An object containing solution data.
* @return Nothing. Just generates the relevant plot.
*/
function generatePhasePlot(solution) {
// Extract solution data
var {vars} = solution;
var [theta, dtheta] = vars;
// Generate 2D plot
gen2DPlot(theta, dtheta, "phasePlot", "Phase plot of dθ/dt and θ", "θ", "dθ/dt");
}
/**
* Generate plot of theta and theta dot against time
*
* @param solution An object containing solution data.
* @return Nothing. Just generates the relevant plot.
*/
function generateTimePlot(solution) {
// Extract solution values
var {t, vars} = solution;
var theta = vars[0];
var dtheta = vars[1];
var sol = {
t: t,
vars: [theta, dtheta]
}
// Generate time plot
genMultPlot(sol, ["θ", "dθ/dt"], "timePlot", "Plot of θ and dθ/dt against time");
}
/**
* Generate two plots:
* - one of dtheta and theta against t;
* - a phase plot of dtheta against theta.
*
* @param objectOfInputs An object that contains all the problem parameters.
* @return Nothing. Just generates the plots.
*/
function generatePlots(objectOfInputs) {
// Solve problem
var solution = solveProblem(RKF45, objectOfInputs);
// Generate solution plots
generateTimePlot(solution);
generatePhasePlot(solution);
};
/**
* Generates animation.
* @return nothing.
*/
function generateAnimation(objectOfInputs=undefined, solution=undefined) {
if (objectOfInputs==undefined) {
var objectOfInputs = readInputs();
}
if (solution==undefined) {
var solution = solveProblem(RKF45, objectOfInputs);
}
animatePendulum(objectOfInputs, solution, "Single pendulum");
}
function generatePhaseAnimation(objectOfInputs=undefined, solution=undefined) {
if (objectOfInputs==undefined) {
var objectOfInputs = readInputs();
}
if (solution==undefined) {
var solution = solveProblem(RKF45, objectOfInputs);
}
animate2D(solution, {varnames: ["θ", "dθ/dt"], IdSuffix: "Phase", title: "Single pendulum: phase plot of dθ/dt against θ."});
}
function generateAnimations(objectOfInputs=undefined, solution=undefined) {
if (objectOfInputs==undefined) {
var objectOfInputs = readInputs();
}
if (solution==undefined) {
var solution = solveProblem(RKF45, objectOfInputs);
}
generateAnimation(objectOfInputs, solution);
generatePhaseAnimation(objectOfInputs, solution);
}
function generateTable(objectOfInputs=undefined, solution=undefined) {
if (objectOfInputs==undefined) {
var objectOfInputs = readInputs();
}
if (solution==undefined) {
var solution = solveProblem(RKF45, objectOfInputs);
}
fillTable(objectOfInputs, ['θ', 'dθ/dt'], solution)
}