forked from petercorke/robotics-toolbox-matlab
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRandomPath.m
199 lines (178 loc) · 6.63 KB
/
RandomPath.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
%RandomPath Vehicle driver class
%
% Create a "driver" object capable of steering a Vehicle object through random
% waypoints within a rectangular region and at constant speed.
%
% The driver object is connected to a Vehicle object by the latter's
% add_driver() method. The driver's demand() method is invoked on every
% call to the Vehicle's step() method.
%
% Methods::
% init reset the random number generator
% demand return speed and steer angle to next waypoint
% display display the state and parameters in human readable form
% char convert to string
%
% Properties::
% goal current goal/waypoint coordinate
% veh the Vehicle object being controlled
% dim dimensions of the work space (2x1) [m]
% speed speed of travel [m/s]
% closeenough proximity to waypoint at which next is chosen [m]
%
% Example::
%
% veh = Vehicle(V);
% veh.add_driver( RandomPath(20, 2) );
%
% Notes::
% - It is possible in some cases for the vehicle to move outside the desired
% region, for instance if moving to a waypoint near the edge, the limited
% turning circle may cause the vehicle to temporarily move outside.
% - The vehicle chooses a new waypoint when it is closer than property
% closeenough to the current waypoint.
% - Uses its own random number stream so as to not influence the performance
% of other randomized algorithms such as path planning.
%
% Reference::
%
% Robotics, Vision & Control, Chap 6,
% Peter Corke,
% Springer 2011
%
% See also Vehicle.
% Copyright (C) 1993-2015, by Peter I. Corke
%
% This file is part of The Robotics Toolbox for MATLAB (RTB).
%
% RTB is free software: you can redistribute it and/or modify
% it under the terms of the GNU Lesser General Public License as published by
% the Free Software Foundation, either version 3 of the License, or
% (at your option) any later version.
%
% RTB is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU Lesser General Public License for more details.
%
% You should have received a copy of the GNU Leser General Public License
% along with RTB. If not, see <http://www.gnu.org/licenses/>.
%
% http://www.petercorke.com
% TODO
% should be a subclass of VehicleDriver
% Vehicle should be an abstract superclass
classdef RandomPath < handle
properties
goal % current goal
h_goal % graphics handle for goal
veh % the vehicle we are driving
dim
speed % speed of travel
closeenough % proximity to goal before
d_prev
randstream % random stream just for Sensors
end
methods
function driver = RandomPath(dim, varargin)
%RandomPath.RandomPath Create a driver object
%
% D = RandomPath(DIM, OPTIONS) returns a "driver" object capable of driving
% a Vehicle object through random waypoints. The waypoints are positioned
% inside a rectangular region bounded by +/- DIM in the x- and y-directions.
%
% Options::
% 'speed',S Speed along path (default 1m/s).
% 'dthresh',D Distance from goal at which next goal is chosen.
%
% See also Vehicle.
% TODO options to specify region, maybe accept a Map object?
driver.dim = dim;
opt.speed = 1;
opt.dthresh = 0.05 * dim;
opt = tb_optparse(opt, varargin);
driver.speed = opt.speed;
driver.closeenough = opt.dthresh;
drive.d_prev = Inf;
driver.randstream = RandStream.create('mt19937ar');
end
function init(driver)
%RandomPath.init Reset random number generator
%
% R.init() resets the random number generator used to create the waypoints.
% This enables the sequence of random waypoints to be repeated.
%
% See also RANDSTREAM.
driver.goal = [];
driver.randstream.reset();
end
% not used
function visualize(driver)
clf
d = driver.dim;
axis([-d d -d d]);
hold on
xlabel('x');
ylabel('y');
end
% private method, invoked from demand() to compute a new waypoint
function setgoal(driver)
r = driver.randstream.rand(2,1);
driver.goal = 0.8 * driver.dim * (r - 0.5)*2;
%fprintf('set goal: (%.1f %.1f)\n', driver.goal);
if isempty(driver.h_goal)
%driver.h_goal = plot(driver.goal(1), driver.goal(2), '*')
else
%set(driver.h_goal, 'Xdata', driver.goal(1), 'Ydata', driver.goal(2))
end
end
function [speed, steer] = demand(driver)
%RandomPath.demand Compute speed and heading to waypoint
%
% [SPEED,STEER] = R.demand() returns the speed and steer angle to
% drive the vehicle toward the next waypoint. When the vehicle is
% within R.closeenough a new waypoint is chosen.
%
% See also Vehicle.
if isempty(driver.goal)
driver.setgoal()
end
speed = driver.speed;
goal_heading = atan2(driver.goal(2)-driver.veh.x(2), ...
driver.goal(1)-driver.veh.x(1));
d_heading = angdiff(goal_heading, driver.veh.x(3));
steer = d_heading;
% if nearly at goal point, choose the next one
d = colnorm(driver.veh.x(1:2) - driver.goal);
if d < driver.closeenough
driver.setgoal();
elseif d > driver.d_prev
driver.setgoal();
end
driver.d_prev = d;
end
function display(driver)
%RandomPath.display Display driver parameters and state
%
% R.display() displays driver parameters and state in compact
% human readable form.
%
% See also RandomPath.char.
loose = strcmp( get(0, 'FormatSpacing'), 'loose');
if loose
disp(' ');
end
disp([inputname(1), ' = '])
disp( char(driver) );
end % display()
function s = char(driver)
%RandomPath.char Convert to string
%
% s = R.char() is a string showing driver parameters and state in in
% a compact human readable format.
s = 'RandomPath driver object';
s = char(s, sprintf(' current goal=(%g,%g), dimension %.1f', ...
driver.goal, driver.dim));
end
end % methods
end % classdef