Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/utiasSTARS/enav-planetary-dataset

Energy-Aware Planetary Navigation Dataset
https://github.com/utiasSTARS/enav-planetary-dataset

Last synced: 2 months ago
JSON representation

Energy-Aware Planetary Navigation Dataset

Awesome Lists containing this project

README

        

# enav-planetary-dataset

Energy-aware navigation dataset for planetary rovers, collected at the Canadian Space Agency's Mars Emulation Terrain. This dataset amounts to more than 1,200 metres of driving and includes:

* Driving power consumption, solar irradiance on the rover's top plane and clear-sky direct irradiance estimates;
* Panoramic stereo color imagery and high-resolution forward-facing single-channel imagery;
* Tri-axial inertial measurements (acceleration & angular velocities);
* Individual wheel encoder data and corresponding 2D odometry estimates;
* Ground-truth GPS-based position and enhanced pose estimation from IMU, GPS and visual data fusion;
* Sun vector orientation relative to the rover's pose estimates;
* Geo-referenced maps of the environment (RGB mosaic, elevation/slope/aspect models).

![rover_main](media/rover_main.jpg)

**Authors**: Olivier Lamarre, Oliver Limoyo, Filip Marić, Dr. Jonathan Kelly
**Affiliation**: [Space and Terrestrial Autonomous Robotic Systems (STARS) Laboratory](www.starslab.ca), University of Toronto
**Maintainer**: Olivier Lamarre ([email](mailto:[email protected]))

This dataset is described in details in our paper [*The Canadian Planetary Emulation Terrain Energy-Aware Rover Navigation Dataset*](https://journals.sagepub.com/doi/10.1177/0278364920908922), which was accepted for publication in The International Journal of Robotics Research. Please [cite our work accordingly](#citation).

## Overview

The data can be downloaded from the dataset's official [web page](http://www.starslab.ca/enav-planetary-dataset/), which contains the data both in human-readable and rosbag format. This repository provides tools to interact with the rosbag files.

Data fetching and plotting alone in generic Python formats can be accomplished using our custom fetching script (which wraps the rosbag module). Advanced data visualization and interaction is enabled using our lightweight ROS package (tested with ROS Kinetic on Ubuntu 16.04):

![enav_ros](https://media.giphy.com/media/YlBFpSSD9qxbCCCpyp/giphy.gif)

Lastly, this dataset also includes four different aerial maps of the test environment at a resolution of 0.2 meters per pixel: color, elevation, slope magnitude and slope orientation maps. Every map is georeferenced and is available in a `.tif` format. Tools to load them in Python or import them in ROS as a single [grid_map](https://github.com/ANYbotics/grid_map) message are also included:

![enav_maps](https://media.giphy.com/media/j4w8J6OvbReBvQyqn0/giphy.gif)

## Pre-requisites

1. ROS installation ([ROS Kinetic](http://wiki.ros.org/kinetic/Installation/Ubuntu) tested);
2. Python 3 (version 3.7 tested). We recommend using a Python environment manager like [pyenv](https://github.com/pyenv/pyenv);

## Installation

1. Clone this repository (including the submodules) in the `src` directory of your catkin workspace:

```sh
cd ~/catkin_ws/src
git clone --recurse-submodules https://github.com/utiasSTARS/enav-planetary-dataset.git
```

2. In a Python 3 environment, the required Python 3 modules can be installed using pip and our [requirements file](#):
`pip install -r requirements.txt`

3. Install the required dependencies ([husky_msgs](http://wiki.ros.org/husky_msgs), [robot_localization](http://wiki.ros.org/robot_localization and [grid_map](https://github.com/ANYbotics/grid_map)) ROS packages):

```sh
sudo apt-get update
sudo apt-get install ros-kinetic-husky-msgs ros-kinetic-robot-localization ros-kinetic-grid-map
```

4. Build the enav_ros package:

```sh
cd ~/catkin_ws

# If you are using catkin build:
catkin build enav_ros
source ~/catkin_ws/setup.bash

# Alternatively, using catkin_make:
catkin_make --pkg enav_ros
source ~/catkin_ws/setup.bash
```

## Documentation

Documentation on how to fetch & plot the data collected by the rover or how to show our aerial maps (along with sample Python scripts) can be found in the [enav_utilities](enav_utilities) subdirectory. Similarly, instructions related to data visualization using our lightweight ROS package can be found in the [enav_ros](enav_ros) subdirectory.

## Citation
```
@article{lamarre2020canadian,
author = {Lamarre, Olivier and Limoyo, Oliver and Mari{\'c}, Filip and Kelly, Jonathan},
title = {{The Canadian Planetary Emulation Terrain Energy-Aware Rover Navigation Dataset}},
journal = {The International Journal of Robotics Research},
year = {2020},
doi = {10.1177/0278364920908922},
URL = {https://doi.org/10.1177/0278364920908922},
publisher={SAGE Publications Sage UK: London, England}
}
```