mpc_python_learn/mpc_demo/mpc_demo_nosim.py

185 lines
5.4 KiB
Python
Raw Normal View History

2020-01-13 20:25:26 +08:00
#! /usr/bin/env python
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import animation
from utils import compute_path_from_wp
from cvxpy_mpc import optimize
import sys
import time
2020-01-14 21:37:28 +08:00
# Robot Starting position
2020-01-13 22:33:29 +08:00
SIM_START_X=0
SIM_START_Y=2
SIM_START_H=0
# Classes
2020-01-13 20:25:26 +08:00
class MPC():
def __init__(self):
# State for the robot mathematical model [x,y,heading]
2020-01-13 22:33:29 +08:00
self.state = [SIM_START_X, SIM_START_Y, SIM_START_H]
2020-01-13 20:25:26 +08:00
# Sim step
self.dt = 0.25
# starting guess output
N = 5 #number of state variables
M = 2 #number of control variables
T = 20 #Prediction Horizon
self.opt_u = np.zeros((M,T))
self.opt_u[0,:] = 1 #m/s
self.opt_u[1,:] = np.radians(0) #rad/s
# Interpolated Path to follow given waypoints
2020-03-04 20:32:29 +08:00
self.path = compute_path_from_wp([0,10,12,2,4,14],[0,0,2,10,12,12])
2020-01-13 20:25:26 +08:00
2020-01-13 22:33:29 +08:00
# Sim help vars
self.sim_time=0
self.x_history=[]
self.y_history=[]
2020-01-14 21:37:28 +08:00
self.h_history=[]
2020-01-13 22:33:29 +08:00
self.v_history=[]
self.w_history=[]
2020-01-13 20:25:26 +08:00
#Initialise plot
plt.style.use("ggplot")
self.fig = plt.figure()
plt.ion()
plt.show()
def run(self):
'''
'''
while 1:
if self.state is not None:
2020-03-04 20:32:29 +08:00
if np.sqrt((self.state[0]-self.path[0,-1])**2+(self.state[1]-self.path[1,-1])**2)<1:
print("Success! Goal Reached")
return
2020-01-13 20:25:26 +08:00
#optimization loop
start=time.time()
self.opt_u = optimize(self.state,
self.opt_u,
self.path)
2020-03-04 20:32:29 +08:00
# print("CVXPY Optimization Time: {:.4f}s".format(time.time()-start))
2020-01-13 20:25:26 +08:00
self.update_sim(self.opt_u[0,1],self.opt_u[1,1])
self.plot_sim()
def update_sim(self,lin_v,ang_v):
'''
Updates state.
:param lin_v: float
:param ang_v: float
'''
self.state[0] = self.state[0] +lin_v*np.cos(self.state[2])*self.dt
self.state[1] = self.state[1] +lin_v*np.sin(self.state[2])*self.dt
self.state[2] = self.state[2] +ang_v*self.dt
def plot_sim(self):
2020-01-13 22:33:29 +08:00
self.sim_time = self.sim_time+self.dt
self.x_history.append(self.state[0])
self.y_history.append(self.state[1])
2020-01-14 21:37:28 +08:00
self.h_history.append(self.state[2])
2020-01-13 22:33:29 +08:00
self.v_history.append(self.opt_u[0,1])
self.w_history.append(self.opt_u[1,1])
2020-01-13 20:25:26 +08:00
plt.clf()
2020-01-13 22:33:29 +08:00
grid = plt.GridSpec(2, 3)
2020-01-13 20:25:26 +08:00
2020-01-14 21:37:28 +08:00
plt.subplot(grid[0:2, 0:2])
plt.title("MPC Simulation \n" + "Simulation elapsed time {}s".format(self.sim_time))
2020-01-13 22:33:29 +08:00
2020-03-04 20:32:29 +08:00
plt.plot(self.path[0,:],self.path[1,:], c='tab:orange',
marker=".",
label="reference track")
plt.plot(self.x_history, self.y_history, c='tab:blue',
marker=".",
alpha=0.5,
label="vehicle trajectory")
# plt.plot(self.x_history[-1], self.y_history[-1], c='tab:blue',
# marker=".",
# markersize=12,
# label="vehicle position")
# plt.arrow(self.x_history[-1],
# self.y_history[-1],
# np.cos(self.h_history[-1]),
# np.sin(self.h_history[-1]),
# color='tab:blue',
# width=0.2,
# head_length=0.5,
# label="heading")
plot_car(self.x_history[-1], self.y_history[-1], self.h_history[-1])
2020-01-13 22:33:29 +08:00
plt.ylabel('map y')
2020-03-04 20:32:29 +08:00
plt.yticks(np.arange(min(self.path[1,:])-1., max(self.path[1,:]+1.)+1, 1.0))
2020-01-13 22:33:29 +08:00
plt.xlabel('map x')
2020-03-04 20:32:29 +08:00
plt.xticks(np.arange(min(self.path[0,:])-1., max(self.path[0,:]+1.)+1, 1.0))
#plt.legend()
2020-01-13 22:33:29 +08:00
plt.subplot(grid[0, 2])
2020-01-14 21:37:28 +08:00
#plt.title("Linear Velocity {} m/s".format(self.v_history[-1]))
2020-01-13 22:33:29 +08:00
plt.plot(self.v_history,c='tab:orange')
2020-03-04 20:32:29 +08:00
locs, _ = plt.xticks()
plt.xticks(locs[1:], locs[1:]*self.dt)
2020-01-13 22:33:29 +08:00
plt.ylabel('v(t) [m/s]')
2020-03-04 20:32:29 +08:00
plt.xlabel('t [s]')
2020-01-13 22:33:29 +08:00
plt.subplot(grid[1, 2])
2020-01-14 21:37:28 +08:00
#plt.title("Angular Velocity {} m/s".format(self.w_history[-1]))
2020-01-13 22:33:29 +08:00
plt.plot(np.degrees(self.w_history),c='tab:orange')
plt.ylabel('w(t) [deg/s]')
2020-03-04 20:32:29 +08:00
locs, _ = plt.xticks()
plt.xticks(locs[1:], locs[1:]*self.dt)
plt.xlabel('t [s]')
2020-01-13 22:33:29 +08:00
plt.tight_layout()
2020-01-13 20:25:26 +08:00
plt.draw()
plt.pause(0.1)
2020-03-04 20:32:29 +08:00
def plot_car(x, y, yaw):
LENGTH = 1.0 # [m]
WIDTH = 0.5 # [m]
OFFSET = LENGTH/2 # [m]
outline = np.array([[-OFFSET, (LENGTH - OFFSET), (LENGTH - OFFSET), -OFFSET, -OFFSET],
[WIDTH / 2, WIDTH / 2, - WIDTH / 2, -WIDTH / 2, WIDTH / 2]])
Rotm = np.array([[np.cos(yaw), np.sin(yaw)],
[-np.sin(yaw), np.cos(yaw)]])
outline = (outline.T.dot(Rotm)).T
outline[0, :] += x
outline[1, :] += y
plt.plot(np.array(outline[0, :]).flatten(), np.array(outline[1, :]).flatten(), 'tab:blue')
2020-01-13 20:25:26 +08:00
def do_sim():
sim=MPC()
try:
sim.run()
except Exception as e:
sys.exit(e)
if __name__ == '__main__':
do_sim()