-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathRRT.m
117 lines (107 loc) · 5.11 KB
/
RRT.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% INTRODUCTION %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% RRT, the Rapidly-Exploring Random Trees is a ramdomized method of
% exploring within dimensions. This method can effectively generate a path
% to reach any point within certain limited steps due to its random
% characteristics.
% This method is proprosed by LaValle, Steven M. in
% October 1998, in his technical report to Computer Science Department of
% Iowa State University as "Rapidly-exploring random trees: A new tool for
% path planning"
% Today, multiple variation of RRT method is widely applied with path
% planning problem among UAVs for ground based, aerial, and marinetime
% vehicles.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% REFERENCES %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% <>Steven M. LaValle "Rapidly-Exploring Random Trees: A New Tool for Path
% Planning" 1998, tech. rpt C.S.Dept, Iowa State U
% <>Sertac Karaman and Emilio Frazzoli "Sampling-based algorithms for
% optimal motion planning",2011, The International Journal of Robotics
% Research
% <>Yoshiaki Kuwata, Gaston A. Fiore, Justin Teo, Emilio Frazzoli, and
% Jonathan P. How, "Motion Planning for Urban Driving using RRT"
% <>https://en.wikipedia.org/wiki/Rapidly-exploring_random_tree
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ALGORITHM %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% For the sake of simplicity, I will discuss the algorithm only with 2-D
% planes. The problem is, given a starting point and limited boundre, how
% do we reach everypoint within the area systematically?
% The method itself is very simple, only repeative iteration of
% are 4 steps.
% 1. generate a random point, i.e, a "vertex"
% 2. find the closest vertex from the existing list
% 3. connect an "edge" from the closest existing vertex to the new vertex
% 4. append the newly generated vertex and edge to the known list
% As the iteration goes, it looks like a tree consists of edges is growing
% within the boundry and thus named so.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% PROGRAM %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% All the parameters are commented throughly and setup within the progrm,
% please see main program below.
% Basically, you need to define a rectangle area for program to grow RRT.
% It is done by defining the height, width, and center of the area. Also,
% you need to define the starting point where the RRT starts to grow. Noted
% that this starting point is not limited to within the area, but the
% second generated vertex will bring the first edge right back inside the
% boundry anyway.
%
% Output:
% <>Figure of the RRT result
% <>vertecies: An array of Vertecies' coordinates,
% sorted by the generated order
% <>edges: starting and ending of each edges, note edges(i) corresponds
% to vertecies(i+1), because vertecies(1) is the original point
% <>ind_nearest: index to the nearest point. vertecies(ind_nearest(i))
% is the closetest vertex to vertecies(i+1)
%
% NOTICE:
% please consider numercial error when defining boundries and area. There
% are still limitations with MATLAB. Generally I can garantee anything
% within order of plus minus 4.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Author: Ewing Kang
% Date: 2016.2.28
% contact: f039281310 [at] yahoo.com.tw
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Copyright (c) 2016 Ewing Kang %
% Distributed under GPLv3 license %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
close(findobj('type','figure','name','RRT basic'));
close(findobj('type','figure','name','RRT growing'));
% define the area and boundry
height = 10;
width = 10;
center = [0, 0];
% define the starting point and iterations
origin = [9,6];
iterations = 100;
offset = center - [width, height]./2;
vertecies = origin;
vert_count = 1;
edges.x = zeros(iterations,2);
edges.y = zeros(iterations,2);
ind_nearest = zeros(iterations,1);
edge_count = 0;
% figure('name', 'RRT growing'); % originally for real-time animation
tic;
for i=1:iterations
% random point generation
x_rand = width*rand() + offset(1);
y_rand = height*rand() + offset(2);
% connect to nearest point
ind_nearest(i) = dsearchn(vertecies, [x_rand, y_rand]);
% edge_rand = [x_rand, y_rand ; vertecies(ind_nearest(i),:)];
% check availablility
% connect and add to list
vertecies(vert_count+1,:) = [x_rand, y_rand];
vert_count = vert_count + 1;
edges.x(edge_count+1,:) = [vertecies(ind_nearest(i),1), x_rand];
edges.y(edge_count+1,:) = [vertecies(ind_nearest(i),2), y_rand];
edge_count = edge_count + 1;
% plot animation here is undoable probably due to MATLAB running
% optimization...
% scatter(x_rand, y_rand, 10,'filled'); hold on;
% plot([vertecies(ind_nearest,1); x_rand], [vertecies(ind_nearest,2); y_rand]); hold on;
end
toc;
clear i x_rand y_rand edge_rand
figure('name', 'RRT basic');
scatter(origin(1), origin(2), 45, '*','r','LineWidth',1); hold on;
scatter(vertecies(:,1), vertecies(:,2), 10,linspace(1,10,length(vertecies(:,1))),'filled'); hold on;
plot(edges.x', edges.y');