Skip to content

Python-based interface with georeferenced terrain and insolation maps of planetary surfaces, in support of global navigation planning.

License

Notifications You must be signed in to change notification settings

utiasSTARS/gplanetary-nav

Repository files navigation

gplanetary-nav

Python-based interface with georeferenced terrain and insolation maps of planetary surfaces, in support of global navigation planning.

If this library is useful to your work, awesome! Please cite it accordingly.

Author: Olivier Lamarre
Affiliation: STARS Laboratory, University of Toronto

Overview

This library provides basic functionalities for queries involving terrain and insolation maps in support of global navigation planning on planetary surfaces.

Optimal grid-based path planning on maps of Jezero Crater, Mars
Shortest path
Estimated solar power generation time series in Cabeus Crater, Moon
Shortest path

Functionalities currently implemented:

  • Load and visualize terrain maps of a planetary surface (elevation, slope, aspect, terrain type, etc.) and solar irradiance maps corresponding to different timestamps.
  • Create your own random terrain maps, if needed.
  • Generate planning graphs at the same spatial resolution as the terrain/insolation maps (1 vertex for every map pixel) and encode relevant mobility information in every edge (rover pitch/roll, edge length, traverse duration, energy consumption, and more).
  • Graph-based optimal path planning. Objective functions include:
    • Physically shortest path;
    • Fastest path (possibility to implement custom rover velocity model);
    • Lowest energy expenditure path (possibility to implement custom rover mobility power consumption model).
  • Given a simplified solar power model (which assumes a solar array on a pan/tilt mechanism, maintaining perfect alignment with sunlight), estimate instantaneous solar power generation and solar energy generated over a time interval.

Package setup / installation

This project is developed using Python 3.7 and conda (Miniconda3 tested). Although not required, using mamba significantly speeds up the installation process and requires much less memory (if you are using it, replace conda with mamba in the commands below).

Once conda is installed, clone the repository on your machine. Create the conda environment and install the core dependencies. By default, the environment name is gplanetary-nav. You can provide your own environment name by passing a -n <env-name> argument:

conda env create -f environment.core.yaml

To use jupyter notebooks (such as those from the quick start guide), update the environment with additional dependencies:

conda env update -f environment.local.yaml

Activate the environment:

conda activate gplanetary-nav # replace with your env name if needed

Getting started

See the repository's wiki for a step-by-step usage guide. We show examples involving simple datasets of specific sites on the Lunar and Martian surfaces. We also explain how to format your own dataset to make it compatible with the library.

Repository structure

The source code of the library is located in gplanetary_nav/. All other top-level directories or files are used for project setup or development purposes:

  • config/ : repository configuration (directory paths and logging).

  • data/ : default directory where data products are saved. All files in this directory are git-ignored.

  • docs/: all documentation-related content (images/figures, tutorial jupyter notebooks, etc.)

  • logs/ : default location where all logs are created. They are all ignored by git & can be safely deleted anytime. Logging configuration is located in the config directory.

License

MIT License

Citation

O. Lamarre, S. Malhotra, J. Kelly, Recovery Policies for Safe Exploration of Lunar Permanently Shadowed Regions by a Solar-Powered Rover, Acta Astronautica (submitted 2023).

bibtex:

@unpublished{lamarre2023recovery,
  author = {Olivier Lamarre and Shantanu Malhotra and Jonathan Kelly},
  title  = {Recovery Policies for Safe Exploration of Lunar Permanently Shadowed Regions by a Solar-Powered Rover},
  note   = {Acta Astronautica (submitted)},
  year   = {2023},
}

About

Python-based interface with georeferenced terrain and insolation maps of planetary surfaces, in support of global navigation planning.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages