forked from openxc/openxc-vehicle-simulator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdynamics_model.py
197 lines (162 loc) · 6.31 KB
/
dynamics_model.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
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
import threading
import time
import math
from flask import jsonify
import datetime
import json
from data import speed_calc
from data import gear_calc
from data import gear_int_calc
from data import torque_calc
from data import engine_speed_calc
from data import fuel_consumed_calc
from data import odometer_calc
from data import fuel_level_calc
from data import heading_calc
from data import lat_calc
from data import lon_calc
class DynamicsModel(object):
def __init__(self):
self._initialize_data()
t = threading.Thread(target=self.physics_loop, name="Thread-Physics")
t.setDaemon(True)
t.start()
print("Dynamics Model initialized")
def _initialize_data(self):
self.calculations = []
self.calculations.append(speed_calc.SpeedCalc())
self.calculations.append(gear_calc.GearCalc())
self.calculations.append(gear_int_calc.GearIntCalc())
self.calculations.append(torque_calc.TorqueCalc())
self.calculations.append(engine_speed_calc.EngineSpeedCalc())
self.calculations.append(fuel_consumed_calc.FuelConsumedCalc())
self.calculations.append(odometer_calc.OdometerCalc())
self.calculations.append(fuel_level_calc.FuelLevelCalc())
self.calculations.append(heading_calc.HeadingCalc())
self.calculations.append(lat_calc.LatCalc())
self.calculations.append(lon_calc.LonCalc())
self.snapshot = {}
for data in self.calculations:
self.snapshot[data.name] = data.get()
self.delay_100Hz = datetime.timedelta(0,0,10000)
self.next_iterate = datetime.datetime.now() + self.delay_100Hz
self.zero_timedelta = datetime.timedelta(0,0,0)
self.accelerator = 0.0
self.brake = 0.0
self.steering_wheel_angle = 0.0
self.parking_brake_status = False
self.engine_running = True
self.ignition_data = 'run'
self.gear_lever = 'drive'
self.manual_trans_status = False
self.snapshot['accelerator_pedal_position'] = self.accelerator
self.snapshot['brake'] = self.brake
self.snapshot['steering_wheel_angle'] = self.steering_wheel_angle
self.snapshot['parking_brake_status'] = self.parking_brake_status
self.snapshot['engine_running'] = self.engine_running
self.snapshot['ignition_status'] = self.ignition_data
self.snapshot['brake_pedal_status'] = self.brake_pedal_status
self.snapshot['gear_lever_position'] = self.gear_lever
self.snapshot['manual_trans'] = self.manual_trans_status
self.stopped = False
def physics_loop(self):
while True:
if not self.stopped:
time_til_calc = self.next_iterate - datetime.datetime.now()
if time_til_calc > self.zero_timedelta:
time.sleep(time_til_calc.microseconds / 1000000.0)
#Assuming less than a second.
self.next_iterate = self.next_iterate + self.delay_100Hz
new_snapshot = {}
for data in self.calculations:
data.iterate(self.snapshot)
new_snapshot[data.name] = data.get()
# Store the latest user input...
new_snapshot['accelerator_pedal_position'] = self.accelerator
new_snapshot['brake'] = self.brake
new_snapshot['steering_wheel_angle'] = self.steering_wheel_angle
new_snapshot['parking_brake_status'] = self.parking_brake_status
new_snapshot['engine_running'] = self.engine_running
new_snapshot['ignition_status'] = self.ignition_data
new_snapshot['brake_pedal_status'] = self.brake_pedal_status
new_snapshot['gear_lever_position'] = self.gear_lever
new_snapshot['manual_trans'] = self.manual_trans_status
self.snapshot = new_snapshot
# Properties ---------------------
@property
def torque(self):
return self.snapshot['torque_at_transmission']
@property
def engine_speed(self):
return self.snapshot['engine_speed']
@property
def vehicle_speed(self):
return math.fabs(self.snapshot['vehicle_speed'])
@property
def brake_pedal_status(self):
return self.brake > 0.0
@property
def fuel_consumed(self):
return self.snapshot['fuel_consumed_since_restart']
@property
def odometer(self):
return self.snapshot['odometer']
@property
def fuel_level(self):
return self.snapshot['fuel_level']
@property
def lat(self):
return self.snapshot['latitude']
@property
def lon(self):
return self.snapshot['longitude']
@property
def data(self):
return json.dumps(self.snapshot)
@property
def ignition_status(self):
return self.ignition_data
@ignition_status.setter
def ignition_status(self, value):
self.ignition_data = value
if value == 'start':
self.engine_running = True
elif value == 'off':
self.engine_running = False
elif value == 'accessory':
self.engine_running = False
@property
def gear_lever_position(self):
return self.gear_lever
@gear_lever_position.setter
def gear_lever_position(self, value):
self.gear_lever = value
@property
def transmission_gear_position(self):
return self.snapshot['transmission_gear_position']
@property
def latitude(self):
return self.snapshot['latitude']
@latitude.setter
def latitude(self, value):
for data in self.calculations:
if data.name == 'latitude':
data.data = value
@property
def longitude(self):
return self.snapshot['longitude']
@longitude.setter
def longitude(self, value):
for data in self.calculations:
if data.name == 'longitude':
data.data = value
def upshift(self):
if self.manual_trans_status:
for data in self.calculations:
if data.name == "transmission_gear_int":
data.shift_up()
def downshift(self):
if self.manual_trans_status:
for data in self.calculations:
if data.name == "transmission_gear_int":
data.shift_down()