rtk_mapper
is a ROS 2 package which provides a GUI interface to help with
viewing and recording landmark positions using a
RTK-enabled GNSS receiver (such as). The
specific use-case for this application is
Formula Student AI.
The package contains two ROS nodes:
mapper
: a GUI utility to help map tracksviewer
: a GUI utility to quickly view tracks stored in a CSV file
This package requires ROS 2 Galactic and on the following third-party Python packages:
First, clone this repository into your ROS workspace:
$ mkdir -p ~/dev_ws/src
$ cd ~/dev_ws/src
$ git clone [email protected]:siliconlad/rtk_mapper.git
Next, define the $EUFS_MASTER
environment variable to point to your ROS workspace:
$ export EUFS_MASTER=$HOME/dev_ws
Finally, we need a map
directory in $EUFS_MASTER
. This is where mapper
saves all maps:
$ mkdir -p $EUFS_MASTER/map
mapper
works by reacting to different keyboard inputs to create a map composed of markers. Markers can be
one of the following types and represent different concepts:
BLUE
: represents a blue coneYELLOW
: represents a yellow coneORANGE
: represents a orange coneBIG_ORANGE
: represents a big orange coneCAR_START
: represents the rough starting position of the car
The first 4 marker types are self-explanatory. They allow the captured location to be associated with a cone color.
CAR_START
is used to help transform the GPS coordinates of each map into a 'normalized map'. In a normalized map, the
GPS coordinates are first transformed into
UTM coordinates. Then each marker
is translated so that CAR_START
is at (0,0)
. Finally, a rotation is applied so that the BIG_ORANGE
cones
(specifically the average position of the 4 closest BIG_ORANGE
cones to CAR_START
) indicating the start/finish line
lies along the x
-axis. This format is useful because coordinates are in meters and the car starts pointing along
the x-direction
(assuming a straight between CAR_START
and the start/finish line, which is reasonable I think).
mapper
operates in two modes:
- Normal mode: Normal mode is the mode you will be using most of the time. With this mode, you can add new markers to the map and delete the last recorded marker to correct a mistake.
- Update mode: Update mode is used to modify a map. In this mode you can select a cone by pressing
TAB
. You can then delete the selected cone, or update its position. You cannot add new markers in this mode.
When the program is quit, two CSV files are saved to $EUFS_MASTER/map
(see CSV File Formats section).
Assuming you have the necessary packages installed, to running mapper
is very simple. Simply build, source
and run:
$ cd $EUFS_MASTER
$ colcon build
$ . install/setup.bash
$ ros2 run rtk_mapper mapper
At this point, a GUI should show up with an empty matplotlib figure.
The complete list of keys and their meaning in the two different modes are as follows:
Key | Mod | Normal Mode Description | Update Mode Description |
---|---|---|---|
b |
- | select BLUE marker type | select BLUE marker type |
y |
- | select YELLOW marker type | select YELLOW marker type |
o |
- | select ORANGE marker type | select ORANGE marker type |
o |
SHIFT |
select BIG_ORANGE marker type | select BIG_ORANGE marker type |
c |
- | select CAR_START marker type | select CAR_START marker type |
d |
- | delete last added marker | delete selected marker |
u |
- | enter update mode | exit update mode |
TAB |
- | - | select prev marker |
TAB |
SHIFT |
- | select next marker |
q |
- | save and quit | save and quit |
SPACE |
- | capture NavSatFix messages |
capture NavSatFix messages |
The mapper
node subscribes to the /fix
topic. It must have
type sensor_msgs/msg/NavSatFix
.
mapper
has the following parameters:
Name | Type | Description |
---|---|---|
debug | bool |
Enable debug logging |
map | string |
Path to a csv file whose contents are loaded into rtk_mapper |
threshold | float |
Variance threshold above which a warning is given. Useful to quickly tell if recorded position is accurate enough. |
viewer
is a simple program which takes a path to a CSV file and plots it in the GUI. No operations can be performed
on the map. This is a read only mode of the map.
viewer
has the following parameters:
Name | Type | Description |
---|---|---|
map | string |
Path to a csv file whose contents are plotted in the GUI. |
The two nodes in this package operate on the following CSV file formats.
The first is a raw, unprocessed CSV file of the following structure:
Name | Description |
---|---|
type |
marker type |
latitude |
GPS latitude |
longitude |
GPS longitude |
latitude_var |
Latitude variance |
longitude_var |
Longitude variance |
covariance |
latitude-longitude covariance |
The second is a CSV file of the 'normalized map' described in the introduction. The format is what is used in
eufs_sim
, and hence can be loaded directly into it.
Name | Description |
---|---|
tag |
marker type |
x |
x position |
y |
y position |
direction |
angle from x-axis |
x_variance |
variance in x direction |
y_variance |
variance in y direction |
xy_covariance |
covariance of x and y |