- NotificationsYou must be signed in to change notification settings 
- Fork780
Python package for the evaluation of odometry and SLAM
License
MichaelGrupp/evo
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
Python package for the evaluation of odometry and SLAM
| Linux / macOS / Windows / ROS / ROS2 | 
|---|
This package provides executables and a small library for handling, evaluating and comparing the trajectory output of odometry and SLAM algorithms.
Supported trajectory formats:
- 'TUM' trajectory files
- 'KITTI' pose files
- 'EuRoC MAV' (.csv groundtruth and TUM trajectory file)
- ROS and ROS2 bagfile withgeometry_msgs/PoseStamped,geometry_msgs/TransformStamped,geometry_msgs/PoseWithCovarianceStamped,geometry_msgs/PointStampedornav_msgs/Odometrytopics orTF messages
Seehere for more infos about the formats.




evo has several advantages over other public benchmarking tools:
- common tools for different formats
- algorithmic options for association, alignment, scale adjustment for monocular SLAM etc.
- flexible options for output,plotting,visualization or export (e.g. LaTeX plots or Excel tables)
- a powerful, configurable CLI that can cover many use cases
- modularcoreandtoolslibraries for custom extensions
- faster than other established Python-based tools (see here)
What it's not: a 1-to-1 re-implementation of a particular evaluation protocol tailored to a specific dataset.
Installation is easy-peasy if you're familiar with this:https://xkcd.com/1987/#
The latest version of evo supportsPython 3.10+.You might also want to use avirtual environment.
If you just want to use the executables of the latest release version, the easiest way is to run:
pip install evo
This will download the package and its dependencies fromPyPI and install or upgrade them. If you want, you can subscribe to new releases viahttps://libraries.io/pypi/evo.
To upgrade to a newer version:pip install --upgrade evo
Run this in the repository's base folder:
pip install --editable.Tab completion is supported via theargcomplete package. Runactivate-global-python-argcomplete after the installation to use it.
Python packages
evo has some required dependencies that areautomatically resolved during installation with pip.See thepyproject.toml file for all details.
PyQt6 (optional)
PyQt6 will give you the enhanced GUI for plot figures from the "qtagg" matplotlib backend (otherwise: "TkAgg"). If PyQt6 is already installed when installing this package, it will be used as a default (seeevo_config show). To change the plot backend afterwards, runevo_config set plot_backend qtagg.
If you run into issues with installing tkinter, trying PyQt6 is a good idea.
ROS (optional)
Some ROS-related features require a ROS installation, seehere. We are testing this package with ROS Kilted.
Reading ROS bag files works also without a ROS installation thanks to the greatrosbags package that is installed together with evo. This allows you also to read ROS 1 & 2 bags even if you don't have one of those ROS distros installed. (except for reading
/tftopics, because there we need the buffer implementation from ROS)
contextily (optional)
contextily is required foradding map tiles to plots of geo-referenced data.
Rerun (optional)
You can log data also to thererun viewer. See the relatedWiki page for more details.
After installation with pip, the following executables can be called globally from your command-line:
Metrics:
- evo_ape- absolute pose error
- evo_rpe- relative pose error
Tools:
- evo_traj- tool for analyzing, plotting or exporting one or more trajectories
- evo_res- tool for comparing one or multiple result files from- evo_apeor- evo_rpe
- evo_config- tool for global settings and config file manipulation
Call the commands with--help to see the options, e.g.evo_ape --help. Tab-completion of command line parameters is available on UNIX-like systems.
More documentationCheck out theWiki on GitHub.
There are some example trajectories in the source folder intest/data.
Here, we plot two KITTI pose files and the ground truth usingevo_traj:
cd test/dataevo_traj kitti KITTI_00_ORB.txt KITTI_00_SPTAM.txt --ref=KITTI_00_gt.txt -p --plot_mode=xz

For example, here we calculate the absolute pose error for two trajectories from ORB-SLAM and S-PTAM usingevo_ape (KITTI_00_gt.txt is the reference (ground truth)) and plot and save the individual results to .zip files forevo_res:
First trajectory (ORB Stereo):
mkdir resultsevo_ape kitti KITTI_00_gt.txt KITTI_00_ORB.txt -va --plot --plot_mode xz --save_results results/ORB.zip

Second trajectory (S-PTAM):
evo_ape kitti KITTI_00_gt.txt KITTI_00_SPTAM.txt -va --plot --plot_mode xz --save_results results/SPTAM.zip

evo_res can be used to compare multiple result files from the metrics, i.e.:
- print infos and statistics (default)
- plot the results
- save the statistics in a table
Here, we use the results from above to generate a plot and a table:
evo_res results/*.zip -p --save_table results/table.csv




For an interactive source code documentation, open theJupyter notebookmetrics_tutorial.ipynb in thenotebooks folder of the repository. More infos on Jupyter notebooks: seehere
If you have IPython installed, you can launch an IPython shell with a custom evo profile with the commandevo_ipython.
A few "inoffical" scripts for special use-cases are collected  in thecontrib/ directory of the repository. They are inofficial in the sense that they don't ship with the package distribution and thus aren't regularly tested in continuous integration.
"😱, this piece of 💩 software doesn't do what I want!!1!1!!"
First aid:
- append-h/--helpto your command
- check theWiki
- check theprevious issues
- open anew issue
Patches are welcome, preferably as pull requests.
If you use this package for your research, a footnote with the link to this repository is appreciated:github.com/MichaelGrupp/evo.
...or, for citation with BibTeX:
@misc{grupp2017evo,  title={evo: Python package for the evaluation of odometry and SLAM.},  author={Grupp, Michael},  howpublished={\url{https://github.com/MichaelGrupp/evo}},  year={2017}}About
Python package for the evaluation of odometry and SLAM
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.