-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathrun.py
75 lines (61 loc) · 2.48 KB
/
run.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
import numpy as np
import holoocean
from tqdm import tqdm
from auv_control.estimation import InEKF
from auv_control.control import LQR
from auv_control.planning import Traj, RRT
from auv_control import State
from plotter import Plotter
from auv_control import scenario
import argparse
np.set_printoptions(suppress=True, formatter={"float_kind": f"{{:0.2f}}".format})
def main(num_seconds, show, plot, verbose, route):
# Install simulation environments
if "Ocean" not in holoocean.installed_packages():
holoocean.install("Ocean")
# Load in HoloOcean info
ts = 1 / scenario["ticks_per_sec"]
num_ticks = int(num_seconds / ts)
# Set everything up
controller = LQR()
observer = InEKF()
if route == "rrt":
planner = RRT(num_seconds)
else:
planner = Traj(route, num_seconds)
if plot:
plotter = Plotter(["True", "Estimated", "Desired"])
# Run simulation!
u = np.zeros(8)
with holoocean.make(scenario_cfg=scenario, show_viewport=show, verbose=verbose) as env:
planner.draw_traj(env, num_seconds)
for i in tqdm(range(num_ticks)):
# Tick environment
env.act("auv0", u)
sensors = env.tick()
# Pluck true state from sensors
t = sensors["t"]
true_state = State(sensors)
# Estimate State
est_state = observer.tick(sensors, ts)
# Path planner
des_state = planner.tick(t)
# Autopilot Commands
u = controller.u(est_state, des_state)
# Update visualization
if plot:
plotter.add_timestep(t, [true_state, est_state, des_state])
if i % 100 == 0:
plotter.update_plots()
if show:
if i % 10 == 0:
planner.draw_step(env, t, ts*10)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description='Run AUV simulation.')
parser.add_argument('-s', '--show', action='store_true', help='Show viewport')
parser.add_argument('-p', '--plot', action='store_true', help='Plot data')
parser.add_argument('-v', '--verbose', action='store_true', help='Print holoocean output')
parser.add_argument('-n', '--num_seconds', default=100, type=float, help='Length to run simulation for')
parser.add_argument('-r', '--route', default="rrt", type=str, help='Routing to use (e.g., "rrt", "helix", "wave", "square")')
args = parser.parse_args()
main(**vars(args))