This repository has been archived by the owner on Sep 30, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.m
87 lines (65 loc) · 1.7 KB
/
main.m
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
clc
clear
close all
addpath('lib')
% Select state space
ss = stateSpaceSE2;
% Build state validator
sv = validatorOccupancyMap(ss);
load workspace\mapsStatic.mat
% Add map to state validator
sv.Map = mapMaze_2;
sv.ValidationDistance = 0.1;
ss.StateBounds = [sv.Map.XWorldLimits; sv.Map.YWorldLimits; [-pi pi]];
% Build planner using ss and sv
planner = planPQRRTStar(ss, sv);
planner.MaxConnectionDistance = 10;
planner.MaxIterations = 1e4;
% Continue planning after reaching goal
planner.ContinueAfterGoalReached = false;
% Time limit for planning
% planner.MaxTime = 10;
% for map2D_1
% start = [40, 40, 0];
% goal = [70, 40, 0];
% for map2D_2
% start = [30, 45, 0];
% goal = [80, 45, 0];
% for map2D_3
% start = [20, 10, 0];
% goal = [80, 90, 0];
% for map2D_4
% start = [20, 90, 0];
% goal = [80, 80, 0];
% for mapMaze_1
% start = [30, 70, 0];
% goal = [60, 30, 0];
% for mapMaze_2
start = [10, 10, 0];
goal = [90, 90, 0];
% for mapMaze_3
% start = [60, 60, 0];
% goal = [10, 70, 0];
% for mapMaze_4
% start = [10, 10, 0];
% goal = [10, 110, 0];
% Planning step
[pthObj, solnInfo] = plan(planner, start, goal);
% 2D Plot of generated nodes and final path
f1 = figure;
f1.Position = [400 200 600 500];
hold on
show(sv.Map)
% plot(solnInfo.TreeData(:, 1), solnInfo.TreeData(:, 2), '.-')
plot(pthObj.States(:, 1), pthObj.States(:, 2), 'r-', 'LineWidth', 2)
plot(start(1), start(2), 'ko')
plot(goal(1), goal(2), 'ko')
title("PQ-RRT* | Map")
hold off
bezierOutput = bezierCurveSmoothing(pthObj);
f2 = figure;
f1.Position = [400 200 600 500];
hold on
show(sv.Map)
plot(bezierOutput.bx, bezierOutput.by, 'r-', 'LineWidth', 2)
hold off