-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimulation.py
executable file
·81 lines (68 loc) · 2.42 KB
/
simulation.py
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
#!/usr/bin/env python3
from params import Parameters
from scene import Scene
from visualisation import VisualScene
import argparse
class Simulation:
"""
The simulation class controls all the components of the simulation.
It converts the input flags to configuration options and augments them to the configuration file.
It initializes the important objects and makes sure that all the event methods (step, on_exit, on_finish) are run.
"""
def __init__(self, scene_file=None, params=None):
"""
Create a new simulation.
"""
self.on_step_functions = []
# All the effects added in the simulation. keys are strings of the effect name, values are the effect objects
if not params:
self.params = Parameters()
else:
self.params = params
if scene_file:
self.params.scene_file = scene_file
self.scene = Scene()
def _prepare(self):
"""
Register parameters and modules
:return: None
"""
self.scene.total_ants += self.params.num_ants
self.on_step_functions.append(self.scene.step)
self.vis = VisualScene(self.scene)
self.on_step_functions.append(self.vis.loop)
self.vis.step_callback = self.step
self.vis.finish_callback = lambda: None
def start(self):
"""
Start the simulation. When the simulation is finished, self.vis.start() returns,
and cleanup is handled through self.finish()
:return: None
"""
self._prepare()
self.scene.prepare(self.params)
self.vis.prepare(self.params)
self.vis.start()
def step(self):
"""
Increase time and
run all the event listener methods that run on each time step
:return:
"""
self.scene.time += self.params.dt
self.scene.counter += 1
[step() for step in self.on_step_functions]
def set_params(self, params):
"""
Set the parameters with the given object.
:param params: Parameter object
:return: None
"""
self.params = params
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Run an ant colony network')
parser.add_argument('-n','--nodes', type=int, help='Number of nodes in the network', default=20)
args = parser.parse_args()
sim = Simulation()
sim.params.num_nodes = args.nodes
sim.start()