-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathsimulationManager_increasing.py
executable file
·87 lines (72 loc) · 3.23 KB
/
simulationManager_increasing.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
82
83
84
85
86
87
# comment/uncomment for different experiment
import pygame
time_period = 100
simTime = 1200
class SimulationManager:
def __init__(self, road, trafficGenerator, updateFrame):
self.road = road
self.trafficGenerator = trafficGenerator
self.updateFrame = updateFrame
self.acc = 0
self.timeFactor = 20.0
self.prevTimeFactor = 1.0
self.running = True
self.stepsMade = 0
def update(self, dt): #updates the traffic input and the car-road interplay
self.acc += dt * self.timeFactor
limit = 0
if self.acc >= self.updateFrame:
self.acc = self.acc % (self.updateFrame + 0)
# self.makeStep_constant_density() #comment this for increasing density
self.makeStep_increasing_density() #uncomment this for increasing density
# self.endSimulation() #uncomment for steady state
self.endSim_fd() #comment for increasing density
def makeSteps(self, steps): #makes multiple steps
# for x in range(steps): self.makeStep_constant_density() #comment this for increasing density
for x in range(steps): self.makeStep_increasing_density() #uncomment this for increasing density
def makeStep_constant_density(self): #for constant density
if self.stepsMade == 0:
self.trafficGenerator.generate(self.road) #generates traffic
self.road.update();
self.stepsMade += 1
def makeStep_increasing_density(self): #for increasing density
if self.stepsMade == 0:
self.trafficGenerator.generate(self.road) #generates traffic
if self.stepsMade >= time_period and (self.stepsMade % time_period) == 1 : #increases density every 100 updates
self.trafficGenerator.generate(self.road)
self.road.update();
self.stepsMade += 1
def processKey(self, key):
{
pygame.K_ESCAPE: self.__exit,
pygame.K_SPACE: self.__pauseSwitch,
pygame.K_m: self.__speedUp,
pygame.K_n: self.__speedDown,
pygame.K_s: self.__oneStepForward,
pygame.K_d: self.__manyStepsForward(100)
}.get(key, lambda: print("Unknown key"))()
def isStopped(self):
return self.timeFactor == 0
def __exit(self):
self.running = False
def __pauseSwitch(self):
self.timeFactor, self.prevTimeFactor = self.prevTimeFactor, self.timeFactor
def __speedUp(self):
self.timeFactor = min(8.0, self.timeFactor*2)
def __speedDown(self):
self.timeFactor = max(1/8, self.timeFactor/2)
def __oneStepForward(self):
if self.isStopped():
# self.makeStep_constant_density() #comment this for increasing density
self.makeStep_increasing_density() #uncomment this for increasing density
else: print("Can't make step: simulation is running")
def __manyStepsForward(self, steps):
def manySteps():
self.makeSteps(steps)
return manySteps
def endSimulation(self):
if (self.road.updates == simTime):
self.running = False
def endSim_fd(self):
if self.road.carCount() == 300:
self.running = False