-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdemo.m
68 lines (65 loc) · 2.64 KB
/
demo.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
% Demo Script to test POSQ controller for differential drive robots
% generates the trajectory which brings a differential drive robot
% with wheelbase B from the start pose xinit to the goal pose xgoal.
% Need to set the proper direction (dir = 1 forward direction), the
% integration time step (deltaT), the initial time (initT). Visualization
% is done by using drawrobot in librobotics
% (see http://srl.informatik.uni-freiburg.de/downloads)
% See also posqstep and posqintegr
%
% Copyright (c) 2014, Luigi Palmieri, Social Robotics Laboratory,
% University of Freiburg
% All rights reserved.
%
% Redistribution and use in source and binary forms, with or without
% modification, are permitted provided that the following conditions are
% met:
%
% 1. Redistributions of source code must retain the above copyright notice,
% this list of conditions and the following disclaimer.
%
% 2. Redistributions in binary form must reproduce the above copyright
% notice, this list of conditions and the following disclaimer in the
% documentation and/or other materials provided with the distribution.
%
% 3. Neither the name of the copyright holder nor the names of its
% contributors may be used to endorse or promote products derived from this
% software without specific prior written permission.
%
% THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
% IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
% THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
% PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
% CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
% EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
% PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
% PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
% LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
% NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
% SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
%=============================
% Define the problem to solve
%=============================
xinit=[0;0;0];
xgoal=[-3;0;2*pi];
dir=1;
deltaT=0.1
b=0.40
initT=0
%=============================
% Call Integration of the POSQ
%=============================
[xvec, speedvec, vel, inct] = posqintegr(xinit, xgoal,dir, deltaT, b,initT);
%==============
% Visualization
%==============
if(exist('drawrobot.m')>0)
figure(1),hold on,title('Robot trajectory')
for i=1:length(xvec)
drawrobot(xvec(:,i),'r',2)
drawnow
pause(0.05)
end
else
disp('drawrobot not found!!! ')
end