2020-09-25 05:24:22 +08:00
|
|
|
close all
|
|
|
|
clear
|
|
|
|
|
|
|
|
%% Setup and Parameters
|
|
|
|
x0 = [-5; -5; 0; 0];
|
|
|
|
time_total = 20.0;
|
|
|
|
dt = 0.2;
|
|
|
|
P = 100*eye(4);
|
|
|
|
Q = 10*eye(4);
|
|
|
|
R = eye(2);
|
|
|
|
N = 8;
|
|
|
|
umin = [-1; -1];
|
|
|
|
umax = [1; 1];
|
|
|
|
xmin = [-5; -5; -5; -5];
|
|
|
|
xmax = [5; 5; 5; 5];
|
|
|
|
|
|
|
|
%% Discrete-time double integrator 2D
|
|
|
|
system.dt = dt;
|
|
|
|
system.A = [1 0 dt 0;
|
|
|
|
0 1 0 dt;
|
|
|
|
0 0 1 0;
|
|
|
|
0 0 0 1];
|
|
|
|
system.B = [0.5*dt^2 0;
|
|
|
|
0 0.5*dt^2;
|
|
|
|
dt 0;
|
|
|
|
0 dt];
|
|
|
|
system.xl = xmin;
|
|
|
|
system.xu = xmax;
|
|
|
|
system.ul = umin;
|
|
|
|
system.uu = umax;
|
|
|
|
|
|
|
|
%% MPC-CBF parameters
|
|
|
|
params.Q = Q;
|
|
|
|
params.R = R;
|
|
|
|
params.P = P;
|
|
|
|
params.N = N;
|
|
|
|
params.gamma = 0.5;
|
|
|
|
|
|
|
|
%% Obstacle
|
|
|
|
obs.pos = [-2; -2.25];
|
|
|
|
obs.r = 1.5;
|
|
|
|
|
|
|
|
%% Simulate MPC-CBF
|
|
|
|
params.N = 5;
|
|
|
|
params.gamma = 0.25;
|
|
|
|
controller_mpc_cbf_1 = MPC_CBF(x0, system, params);
|
|
|
|
controller_mpc_cbf_1.obs = obs;
|
|
|
|
controller_mpc_cbf_1.sim(time_total);
|
|
|
|
|
|
|
|
%% Simulate MPC-CBF with lower gamma
|
|
|
|
params.gamma = 0.20;
|
|
|
|
controller_mpc_cbf_2 = MPC_CBF(x0, system, params);
|
|
|
|
controller_mpc_cbf_2.obs = obs;
|
|
|
|
controller_mpc_cbf_2.sim(time_total);
|
|
|
|
|
|
|
|
params.gamma = 0.15;
|
|
|
|
controller_mpc_cbf_3 = MPC_CBF(x0, system, params);
|
|
|
|
controller_mpc_cbf_3.obs = obs;
|
|
|
|
controller_mpc_cbf_3.sim(time_total);
|
|
|
|
|
|
|
|
%% Simulate MPC-DC
|
2021-02-09 05:37:30 +08:00
|
|
|
|
|
|
|
% The problem is infeasible at N=5
|
|
|
|
% params.N = 5;
|
|
|
|
% controller_mpc_dc_0 = MPC_DC(x0, system, params);
|
|
|
|
% controller_mpc_dc_0.obs = obs;
|
|
|
|
% controller_mpc_dc_0.sim(time_total);
|
|
|
|
|
2020-09-25 05:24:22 +08:00
|
|
|
params.N = 7;
|
|
|
|
controller_mpc_dc_1 = MPC_DC(x0, system, params);
|
|
|
|
controller_mpc_dc_1.obs = obs;
|
|
|
|
controller_mpc_dc_1.sim(time_total);
|
|
|
|
|
|
|
|
params.N = 15;
|
|
|
|
controller_mpc_dc_2 = MPC_DC(x0, system, params);
|
|
|
|
controller_mpc_dc_2.obs = obs;
|
|
|
|
controller_mpc_dc_2.sim(time_total);
|
|
|
|
|
|
|
|
%%
|
|
|
|
params.N = 30;
|
|
|
|
controller_mpc_dc_3 = MPC_DC(x0, system, params);
|
|
|
|
controller_mpc_dc_3.obs = obs;
|
|
|
|
controller_mpc_dc_3.sim(time_total);
|
|
|
|
|
|
|
|
%% Visualization benchmark
|
|
|
|
figure('Renderer', 'painters', 'Position', [0 0 400 400]);
|
|
|
|
set(gca,'LooseInset',get(gca,'TightInset'));
|
|
|
|
hold on
|
|
|
|
plot(controller_mpc_cbf_3.xlog(1,:), controller_mpc_cbf_3.xlog(2,:),...
|
|
|
|
'-', 'Color', [0, 0.4470, 0.7410], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
plot(controller_mpc_cbf_2.xlog(1,:), controller_mpc_cbf_2.xlog(2,:),...
|
|
|
|
'-', 'Color', [0.8500, 0.3250, 0.0980], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
plot(controller_mpc_cbf_1.xlog(1,:), controller_mpc_cbf_1.xlog(2,:),...
|
|
|
|
'-', 'Color', [0.9290, 0.6940, 0.1250], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
plot(controller_mpc_dc_1.xlog(1,:), controller_mpc_dc_1.xlog(2,:),...
|
|
|
|
'--', 'Color', [0.4940, 0.1840, 0.5560], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
plot(controller_mpc_dc_2.xlog(1,:), controller_mpc_dc_2.xlog(2,:),...
|
|
|
|
'--', 'Color', [0.4660, 0.6740, 0.1880], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
plot(controller_mpc_dc_3.xlog(1,:), controller_mpc_dc_3.xlog(2,:),...
|
|
|
|
'--', 'Color', [0.3010, 0.7450, 0.9330], 'LineWidth', 1.0, 'MarkerSize', 4);
|
|
|
|
% plot obstacle
|
|
|
|
pos = obs.pos;
|
|
|
|
r = obs.r;
|
|
|
|
th = linspace(0,2*pi*100);
|
|
|
|
x = cos(th) ; y = sin(th) ;
|
|
|
|
plot(pos(1) + r*x, pos(2) + r*y, 'Color', [0.8500, 0.3250, 0.0980],...
|
|
|
|
'LineWidth', 2);
|
|
|
|
plot(pos(1), pos(2), 'Color', [0.8500, 0.3250, 0.0980],...
|
|
|
|
'MarkerSize', 5, 'LineWidth', 2);
|
|
|
|
% plot target position
|
|
|
|
plot(x0(1), x0(2), 'db', 'LineWidth', 1);
|
|
|
|
plot(0.0, 0.0, 'dr', 'LineWidth', 1);
|
|
|
|
h=get(gca,'Children');
|
|
|
|
h_legend = legend(h([end, end-1, end-2, end-3, end-4, end-5]),...
|
|
|
|
{'MPC-CBF ($N = 5, \gamma = 0.15$)', 'MPC-CBF ($N = 5, \gamma = 0.20$)',...
|
|
|
|
'MPC-CBF ($N = 5, \gamma = 0.25$)', 'MPC-DC ($N = 7$)', 'MPC-DC ($N = 15$)',...
|
|
|
|
'MPC-DC ($N = 30$)'}, 'Location', 'SouthEast');
|
|
|
|
set(h_legend, 'Interpreter','latex', 'FontSize', 10);
|
|
|
|
set(gca,'LineWidth', 0.2, 'FontSize', 15);
|
|
|
|
grid on
|
|
|
|
xlabel('$x (m)$','interpreter','latex','FontSize',20);
|
|
|
|
ylabel('$y (m)$','interpreter','latex','FontSize',20);
|
|
|
|
xticks(-5:0);
|
|
|
|
yticks(-5:0);
|
|
|
|
xlim([-5,0.2]);
|
|
|
|
ylim([-5,0.2]);
|
|
|
|
print(gcf,'figures/benchmark-horizon.eps', '-depsc');
|
|
|
|
print(gcf,'figures/benchmark-horizon.png', '-dpng', '-r800');
|
|
|
|
|
|
|
|
%% Computational time benchmark
|
|
|
|
figure('Renderer', 'painters', 'Position', [0 0 800 400]);
|
|
|
|
xlabel('Computational time (s)', 'interpreter', 'latex', 'FontSize', 16);
|
|
|
|
ylabel('Percentage', 'interpreter', 'latex', 'FontSize', 16);
|
|
|
|
hold on
|
|
|
|
% [N_mpc_3, edges_mpc_3] = histcounts(controller_mpc_cbf_3.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
% plot(edges_mpc_3(1:end-1), N_mpc_3, '-', 'Color', [0, 0.4470, 0.7410], 'LineWidth', 1);
|
|
|
|
% [N_mpc_2, edges_mpc_2] = histcounts(controller_mpc_cbf_2.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
% plot(edges_mpc_2(1:end-1), N_mpc_2, '-', 'Color', [0.8500, 0.3250, 0.0980], 'LineWidth', 1);
|
|
|
|
[N_mpc_1, edges_mpc_1] = histcounts(controller_mpc_cbf_1.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
plot(edges_mpc_1(1:end-1), N_mpc_1, '-', 'Color', [0.9290, 0.6940, 0.1250], 'LineWidth', 1);
|
|
|
|
[N_dc_1, edges_dc_1] = histcounts(controller_mpc_dc_1.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
plot(edges_dc_1(1:end-1), N_dc_1, '--', 'Color', [0.4940, 0.1840, 0.5560], 'LineWidth', 1);
|
|
|
|
[N_dc_2, edges_dc_2] = histcounts(controller_mpc_dc_2.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
plot(edges_dc_2(1:end-1), N_dc_2, '--', 'Color', [0.4660, 0.6740, 0.1880], 'LineWidth', 1);
|
|
|
|
[N_dc_3, edges_dc_3] = histcounts(controller_mpc_dc_3.solvertime, 10, 'Normalization', 'probability');
|
|
|
|
plot(edges_dc_3(1:end-1), N_dc_3, '--', 'Color', [0.3010, 0.7450, 0.9330], 'LineWidth', 1);
|
|
|
|
h=get(gca,'Children');
|
|
|
|
h_legend = legend(h([end, end-1, end-2, end-3]),...
|
|
|
|
{'MPC-CBF ($N = 5, \gamma = 0.25$)',...
|
|
|
|
'MPC-DC ($N = 7$)',...
|
|
|
|
'MPC-DC ($N = 15$)',...
|
|
|
|
'MPC-DC ($N = 30$)'}, 'Location', 'NorthEast');
|
|
|
|
set(h_legend, 'Interpreter','latex');
|
|
|
|
set(gca,'LineWidth', 0.2, 'FontSize', 15);
|
|
|
|
print(gcf,'figures/benchmark-horizon-computational-time.eps', '-depsc');
|
|
|
|
print(gcf,'figures/benchmark-horizon-computational-time.png', '-dpng', '-r800');
|
|
|
|
%% Computational time table
|
|
|
|
fprintf('Computational time for MPC-CBF3: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_cbf_3.solvertime),...
|
|
|
|
std(controller_mpc_cbf_3.solvertime),...
|
|
|
|
min(controller_mpc_cbf_3.solvertime),...
|
|
|
|
max(controller_mpc_cbf_3.solvertime),...
|
|
|
|
controller_mpc_cbf_3.u_cost,...
|
|
|
|
min(controller_mpc_cbf_3.distlog)]);
|
|
|
|
|
|
|
|
fprintf('Computational time for MPC-CBF2: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_cbf_2.solvertime),...
|
|
|
|
std(controller_mpc_cbf_2.solvertime),...
|
|
|
|
min(controller_mpc_cbf_2.solvertime),...
|
|
|
|
max(controller_mpc_cbf_2.solvertime),...
|
|
|
|
controller_mpc_cbf_2.u_cost,...
|
|
|
|
min(controller_mpc_cbf_2.distlog)]);
|
|
|
|
|
|
|
|
fprintf('Computational time for MPC-CBF1: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_cbf_1.solvertime),...
|
|
|
|
std(controller_mpc_cbf_1.solvertime),...
|
|
|
|
min(controller_mpc_cbf_1.solvertime),...
|
|
|
|
max(controller_mpc_cbf_1.solvertime),...
|
|
|
|
controller_mpc_cbf_1.u_cost,...
|
|
|
|
min(controller_mpc_cbf_1.distlog)]);
|
|
|
|
|
2021-02-09 05:37:30 +08:00
|
|
|
% fprintf('Computational time for MPC-DC0: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
% [mean(controller_mpc_dc_0.solvertime),...
|
|
|
|
% std(controller_mpc_dc_0.solvertime),...
|
|
|
|
% min(controller_mpc_dc_0.solvertime),...
|
|
|
|
% max(controller_mpc_dc_0.solvertime),...
|
|
|
|
% controller_mpc_dc_0.u_cost,...
|
|
|
|
% min(controller_mpc_dc_0.distlog)]);
|
|
|
|
|
2020-09-25 05:24:22 +08:00
|
|
|
fprintf('Computational time for MPC-DC1: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_dc_1.solvertime),...
|
|
|
|
std(controller_mpc_dc_1.solvertime),...
|
|
|
|
min(controller_mpc_dc_1.solvertime),...
|
|
|
|
max(controller_mpc_dc_1.solvertime),...
|
|
|
|
controller_mpc_dc_1.u_cost,...
|
|
|
|
min(controller_mpc_dc_1.distlog)]);
|
|
|
|
|
|
|
|
fprintf('Computational time for MPC-DC2: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_dc_2.solvertime),...
|
|
|
|
std(controller_mpc_dc_2.solvertime),...
|
|
|
|
min(controller_mpc_dc_2.solvertime),...
|
|
|
|
max(controller_mpc_dc_2.solvertime),...
|
|
|
|
controller_mpc_dc_2.u_cost,...
|
|
|
|
min(controller_mpc_dc_2.distlog)]);
|
|
|
|
|
|
|
|
fprintf('Computational time for MPC-DC3: mean %.3f, std %.3f, min %.3f, max %.3f, input cost %.3f, min dist %f\n',...
|
|
|
|
[mean(controller_mpc_dc_3.solvertime),...
|
|
|
|
std(controller_mpc_dc_3.solvertime),...
|
|
|
|
min(controller_mpc_dc_3.solvertime),...
|
|
|
|
max(controller_mpc_dc_3.solvertime),...
|
|
|
|
controller_mpc_dc_3.u_cost,...
|
|
|
|
min(controller_mpc_dc_3.distlog)]);
|