forked from laurabreiman/science-of-cooking
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sample.js
46 lines (39 loc) · 1.53 KB
/
sample.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
/*
calculate: function that takes in data about the meat that is cooking and restructures
it into graphable data arrays and values that are then displayed to the screen
with the function graphSteak
*/
var calculate=function(data,steak,meatType,first,totalTime){
//sets the parameters for the iterations of the diffusion equations.
//parameters are initially set to a timestep of 1 second and a spacestep of 1mm,
//but these can be increased with minimal error if calculation time is too great
var timestep = 1;
var spacestep = 1;
while(totalTime/timestep > 10000){
timestep += 9; //adjust the timestep so that no more than 9999 calculations are done
}
if(timestep > 39){ //39 is basically the maximum timestep for acceptable accuracy (below 1° error)
timestep = 39;
}
var myheatsolver = HeatSolver(steak,timestep,spacestep);
var Thedata=myheatsolver.sixty_graph_arrays_duration(data);
if(meatType=='False'){
var sampledata=Thedata.temps;
}
else{
var sampledata=Thedata.allMaxTemps.slice(1,Thedata.allMaxTemps.length);
console.log(sampledata);
for(var i=0;i<sampledata.length;i++)
{
sampledata[i]=sampledata[i].slice(1,sampledata[i].length-1);
}
}
var flame=Thedata.points;
var timestep=1/Thedata.step;
var maxTemps=Thedata.maxTemps;
if(first){
drawFinished(meatType,maxTemps,data,steak[0],0);
drawFinished(meatType,maxTemps,data,steak[0],1);
}
graphSteak(sampledata,flame,timestep,meatType,maxTemps);
}