-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsim_example.py
69 lines (49 loc) · 1.9 KB
/
sim_example.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
import uavsim
import numpy as np
from uavsim.utility.trim import compute_trim
from uavsim.path_follower import PathFollower
from uavsim.messages.msg_path import MsgPath
sim_timestep = 0.01
uav_params = uavsim.UAVParams('params.yaml')
sensor_params = uavsim.SensorParams('sensor_params.yaml')
uav_dynamics = uavsim.UAVDynamics(uav_params, sensor_params, sim_timestep)
wind_sim = uavsim.WindSimulator(sim_timestep)
trim_state, trim_delta = compute_trim(uav_dynamics, 25, 0)
uav_dynamics.state = trim_state
delta = trim_delta
control_params = uavsim.ControlParams(uav_params, uav_dynamics, trim_state,
trim_delta, sim_timestep)
autopilot = uavsim.Autopilot(control_params, sim_timestep)
observer = uavsim.Observer(uav_params, sensor_params, sim_timestep)
path_follower = PathFollower()
uav_viewer = uavsim.UAVViewer()
path_viewer = uavsim.PathViewer()
path = MsgPath()
path.type = 'orbit'
path.type = 'orbit'
if path.type == 'line':
path.line_origin = np.array([[0.0, 0.0, -100.0]]).T
path.line_direction = np.array([[0.5, 1.0, 0.0]]).T
path.line_direction = path.line_direction \
/ np.linalg.norm(path.line_direction)
elif path.type == 'orbit':
path.orbit_centre = np.array([[0.0, 0.0, 100.0]]).T
path.orbit_radius = 300.0
path.orbit_direction = 'CW'
sim_time = 0.0
n_steps = int(60 / sim_timestep)
print('Starting Simulation...')
n = 0
while n < (n_steps + 1):
measurements = uav_dynamics.get_sensors()
estimated_state = observer.update(measurements)
commands = path_follower.update(path, estimated_state)
delta, commanded_state = autopilot.update(commands, estimated_state)
wind = wind_sim.update()
uav_dynamics.update(delta, wind)
path_viewer.update(uav_dynamics.true_state, path)
if n % 100 == 0:
print(f't = {sim_time:.3f}')
sim_time += sim_timestep
n += 1
print('Simulation Done...')