1 | show:
|
---|
2 | name:Benthic foraminifera
|
---|
3 | info:~
|
---|
4 | There are two species of Foraminiera: longitudal and coiled. The first chamber of the longitudal species has orange marks. Haploid and diploid generations alternate in both species. All chambers of the haploid generation have the same size. In the diploid generation, subsequent chambers are bigger than their predecessors.
|
---|
5 |
|
---|
6 | Nutrients are shown as tiny green cylinders. Foraminifers move towards nearest nutrients and this way they can accumulate enough energy to reproduce.
|
---|
7 |
|
---|
8 | When the "Enhance visualization" option is enabled, reticulopodia are shown as large disks and positions of nutrients are indicated by cuboids.
|
---|
9 |
|
---|
10 | More information at www.framsticks.com/foraminifera
|
---|
11 | ~
|
---|
12 | expdef:foraminifera
|
---|
13 | code:~
|
---|
14 |
|
---|
15 | global Params; //to easily transfer changes in identical properties from this show to expdef
|
---|
16 | global last_simspeed; //to display time scale when it changes significantly
|
---|
17 |
|
---|
18 | function onLoad()
|
---|
19 | {
|
---|
20 | Simulator.init();
|
---|
21 | last_simspeed=0;
|
---|
22 | GLDisplay.desiredsimspeed = 50;
|
---|
23 | GLDisplay.minfps = 10;
|
---|
24 | TrackingCam.cam_h = 15; //more side view
|
---|
25 | Params = { "feedrate" : [200,100,50], "feedtrans" : [0.05,0.125,0.25],"energy_nut" :[0.5,1.5,3.0], "stress" : [0,1], "visualize" : [0,1]};
|
---|
26 | ShowProperties.visualize=1;
|
---|
27 | }
|
---|
28 |
|
---|
29 | function timeScale()
|
---|
30 | {
|
---|
31 | //just a draft, this function and all constants in expdef need serious review
|
---|
32 | var localDriveMicronsPerStep=framsToMicrons(getMovePerStep());
|
---|
33 | var foramSpeedMmPerSec=ExpProperties.foramSpeedMmPerMin/60;
|
---|
34 | var localDriveMmPerStep=localDriveMicronsPerStep/1000;
|
---|
35 | var localDriveMmPerSec=localDriveMmPerStep*Simulator.simspeed;
|
---|
36 | return localDriveMmPerSec/foramSpeedMmPerSec;
|
---|
37 | }
|
---|
38 |
|
---|
39 | function updateBanner()
|
---|
40 | {
|
---|
41 | GLDisplay.banner="World size is %g mm." % (framsToMicrons(World.wrldsiz)/1000);
|
---|
42 | GLDisplay.banner+="\nShowing real-time x %g." % timeScale();
|
---|
43 | }
|
---|
44 |
|
---|
45 | function onShowStep()
|
---|
46 | {
|
---|
47 | if (Simulator.simspeed<last_simspeed*0.9 || Simulator.simspeed>last_simspeed*1.1) //significant change
|
---|
48 | {
|
---|
49 | updateBanner();
|
---|
50 | last_simspeed=Simulator.simspeed;
|
---|
51 | }
|
---|
52 | }
|
---|
53 |
|
---|
54 | function setShowParam(param_id)
|
---|
55 | {
|
---|
56 | ExpProperties.[param_id] = Params[param_id][ShowProperties.[param_id]];
|
---|
57 | }
|
---|
58 |
|
---|
59 | function ShowProperties_feedrate_set()
|
---|
60 | {
|
---|
61 | setShowParam("feedrate");
|
---|
62 | }
|
---|
63 |
|
---|
64 | function ShowProperties_feedtrans_set()
|
---|
65 | {
|
---|
66 | setShowParam("feedtrans");
|
---|
67 | }
|
---|
68 |
|
---|
69 | function ShowProperties_energy_nut_set()
|
---|
70 | {
|
---|
71 | setShowParam("energy_nut");
|
---|
72 | }
|
---|
73 |
|
---|
74 | function ShowProperties_stress_set()
|
---|
75 | {
|
---|
76 | setShowParam("stress");
|
---|
77 | }
|
---|
78 |
|
---|
79 | function ShowProperties_visualize_set()
|
---|
80 | {
|
---|
81 | setShowParam("visualize");
|
---|
82 | }
|
---|
83 |
|
---|
84 | ~
|
---|
85 |
|
---|
86 | property:
|
---|
87 | id:feedrate
|
---|
88 | name:Feeding rate
|
---|
89 | type:d 0 2 1 ~Low~Medium~High
|
---|
90 |
|
---|
91 | property:
|
---|
92 | id:feedtrans
|
---|
93 | name:Energy transfer
|
---|
94 | type:d 0 2 1 ~0.05~0.125~0.25
|
---|
95 |
|
---|
96 | property:
|
---|
97 | id:energy_nut
|
---|
98 | name:Nutrient energy
|
---|
99 | type:d 0 2 1 ~0.5~1.5~3
|
---|
100 |
|
---|
101 | property:
|
---|
102 | id:stress
|
---|
103 | name:Stress
|
---|
104 | type:d 0 1 1
|
---|
105 |
|
---|
106 | property:
|
---|
107 | id:visualize
|
---|
108 | name:Enhance visualization
|
---|
109 | type:d 0 1 0
|
---|