forked from sbpl/sbpl
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.txt
173 lines (119 loc) · 6.34 KB
/
README.txt
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
I. Building, Installing, and Using SBPL
SBPL is available as a standalone software library. SBPL itself has no
dependencies other than the C/C++ standard library.
These build and install instructions are primarily for Linux. For other
operating systems, CMake can generate the platform-specific build and project
files necessary for building SBPL.
Versions of ROS older than Fuerte may contain packages that depend on a ROS
package version of SBPL. The recommended method to install SBPL is to install
it as a standard system library. However, if you wish to use the old ROS
package version of SBPL, you may follow these instructions.
1. Building and Installing SBPL from source
1.1 Build SBPL
SBPL uses git as its version control system. From the directory where
you want the SBPL source to reside, clone the latest source from
https://github.com/sbpl/sbpl:
git clone https://github.com/sbpl/sbpl.git
In the source directory, build the SBPL library using standard
CMake build conventions:
mkdir build
cd build
cmake ..
make
1.2 Install SBPL
Install the built library and headers onto your local system
(usually into /usr/local):
sudo make install
2. Installing SBPL from pre-built binary package
A pre-built Debian package exists on Linux for ROS distributions
Fuerte and newer. To install the Debian, run:
sudo apt-get install ros-distro-sbpl
where distro is the name of your ROS distribution. This will install
the SBPL library and associated development headers alongside other
ROS components (in /opt/ros/distro on Ubuntu distributions). A
pkg-config file is also included to allow you to locate the SBPL
library components in your build system.
3. Build your (ROS) package with SBPL as a dependency (CMake)
In the CMakeLists.txt for your (ROS) package, the following lines are
needed to find the installed SBPL files:
find_package(PkgConfig REQUIRED)
pkg_check_modules(SBPL REQUIRED sbpl)
include_directories(${SBPL_INCLUDE_DIRS})
link_directories(${SBPL_LIBRARY_DIRS})
Then, after you've declared your binaries, you need to link them
against SBPL with the following line:
target_link_libraries(your-binary-here ${SBPL_LIBRARIES})
4. Installing and Using SBPL as a ROS package
The ROS package version of SBPL was deprecated with the release of ROS
Fuerte. However, packages in ROS Electric may still require the ROS
package version of SBPL.
4.1 Install SBPL
4.1.1 Source install
SBPL uses git as its version control system. From the
directory where you want the SBPL source to reside, clone the
latest source from https://github.com/sbpl/sbpl:
git clone https://github.com/sbpl/sbpl.git
In the source directory, checkout the electric branch of the
repository to revert to the old ROS package version:
git checkout -b electric
Ensure that SBPL is on your ROS_PACKAGE_PATH and type:
rosmake sbpl
4.1.2 Binary install
SBPL is also available as a pre-built Debian in ROS Electric.
To instal the Debian, run:
sudo apt-get install ros-electric-arm-navigation
4.2 Build your ROS package with SBPL as a depency (rosbuild)
In the manifest.xml for your package, you need to add the
following line to declare the SBPL package as a dependency:
<depend package="sbpl"/>
II. Usage
Examples for how to use SBPL are in src/test/main.cpp. Please follow the
examples carefully. The library contains a number of planning problem
examples, stored as ascii files. These files (with extension .cfg) should
be passed in as arguments into the main function in main.cpp. The files
can be found in env_examples directory.
Command-line usage for the test_sbpl program can be viewed by passing '-h'
as argument to the executable.
Examples:
The following can be run from the directory containing test_sbpl,
which we assume is a build directory in the root of this project.
$ ./test_sbpl ../env_examples/nav3d/env1.cfg
Environment: xytheta; Planner: arastar; Search direction: backward
Initializing ARAPlanner...
start planning...
done planning
size of solution=16
solution size=0
Solution is found
$ ./test_sbpl --env=2d ../env_examples/nav2d/env1.cfg #2d is needed here in order to use 2d config
Environment: 2d; Planner: arastar; Search direction: backward
Initializing ARAPlanner...
start planning...
done planning
size of solution=22
Solution is found
$ ./test_sbpl --env=robarm --search-dir=forward --planner=rstar ../env_examples/robarm/env1_6d.cfg
Environment: robarm; Planner: rstar; Search direction: forward
Initializing RSTARPlanner...
start planning...
done planning
size of solution=44
Solution is found
Motion primitives files can be found in sbpl/matlab/mprim directory.
Finally, few visualization scripts can be found in
sbpl/matlab/visualization. In particular, plot_3Dpath.m function can be
used to visualize the path found by xytheta lattice planner. This
functions takes in .cfg file that specified environment and sol.txt file
that was generated within main.cpp by xythetalattice planners.
Note: If you compile the library with the ROS symbol defined, all text
output will be redirected to ROS logging constructions. Without the ROS
symbol defined, SBPL will print messages to stdout and test_sbpl will
generate a solution file, sol.txt, as well as a debugging information
file, debug.txt
III. Links
These instructions and more tutorials can be found at www.sbpl.net
For more information and documentation on SBPL visit:
http://www.ros.org/wiki/sbpl
For more information and documentation on using the x,y,theta environment
available in ROS visit:
http://www.ros.org/wiki/sbpl_lattice_planner