Skip to content

Commit

Permalink
Imported upstream version '1.1.1' of 'upstream'
Browse files Browse the repository at this point in the history
  • Loading branch information
jlblancoc committed Aug 23, 2024
1 parent 2d8d149 commit 79d6629
Show file tree
Hide file tree
Showing 48 changed files with 381 additions and 58 deletions.
226 changes: 226 additions & 0 deletions docs/source/dataset-conversions.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,226 @@
.. _dataset-conversions:

======================
Dataset conversions
======================

This page gives instructions on how to convert robotics datasets between
ROS 1 and ROS 2 bag files or live messages, MRPT's cross-platform RawLog format, and
the custom formats of popular robotics and computer vision datasets.

.. contents::
:depth: 1
:local:
:backlinks: none


1. Dataset formats
---------------------------------
Robotics datasets comprises **sequences** of raw sensory data as captured by
a mobile robot, a vehicle, or just a hand-held device, as it moves.

Each robotic framework or library has defined its own formats over time:

- **ROS 1** introduced `rosbags <https://wiki.ros.org/Bags>`_ (~2007) as a binary serialization
storage for heterogeneous ROS messages.
- **ROS 2** (~2014) improved rosbags, which now can use different storage implementations (sqlite3, mcap),
and are more efficient and flexible than older versions.
- `MRPT <https://github.com/MRPT/mrpt>`_, on which MOLA is internally based on,
defined its own serialized dataset format (~2005) named
`RawLogs <https://docs.mrpt.org/reference/latest/class_mrpt_obs_CRawlog.html>`_, which is ensured
to be portable across operative systems, backwards compatible across MRPT versions,
and processor architecture independent.

.. note::
Apart of these *standardized formats*, many robotic datasets have their own custom
data layout (e.g. one binary file for each 3D LiDAR scan or image).
MOLA makes easy reading them by providing *adapter modules* that can read the most
popular datasets (see :ref:`list <supported_sensors>`) through unified C++ APIs
(:ref:`doxid-classmola_1_1_offline_dataset_source`)
or :ref:`re-publishing them to ROS <mola-dataset-to-ros>`.

|
2. rosbag ⇒ rawlog
----------------------------
To convert a ROS bag into a RawLog, you need two items:
- The program ``rosbag2rawlog``,
- And a configuration file specifying what ROS messages should be converted.

There are two versions of ``rosbag2rawlog`` and the correct one must be installed
depending on whether you need to convert **ROS 1 or ROS 2 bags**:

.. tab-set::

.. tab-item:: ROS 2 bags
:selected:

``rosbag2rawlog`` for **ROS 2 bags**. It is shipped with the ROS package `mrpt_rawlog <https://github.com/mrpt-ros-pkg/mrpt_navigation/tree/ros2/mrpt_rawlog>`_
so it can be installed with:

.. code-block:: bash
sudo apt install ros-${ROS_DISTRO}-mrpt-rawlog
.. tab-item:: ROS 1 bags
:selected:

``rosbag2rawlog`` for **ROS 1 bags** belongs to upstream MRPT, and it is generated only *if*
ROS 1 is detected at cmake configuration time. You can either build MRPT from sources after activating
your ROS 1 environment, or install the Ubuntu package ``mrpt-apps``, which already ships ``rosbag2rawlog``
for Ubuntu versions <=22.04 (In Ubuntu 24.04, ROS 1 packages were removed upstream).
To ensure having the latest version, consider installing it from `the PPA <https://launchpad.net/~joseluisblancoc/+archive/ubuntu/mrpt-stable>`_.

|
Once you have ``rosbag2rawlog`` installed it can be invoked like:

.. dropdown:: rosbag2rawlog CLI arguments
:open:

.. code-block:: bash
$ rosbag2rawlog --help
USAGE:
rosbag2rawlog [-b <base_link>] [-w] -c <config.yml> -o
<dataset_out.rawlog> [--] [--version] [-h] <log.bag> ...
Where:
-b <base_link>, --base-link <base_link>
Reference /tf frame for the robot frame (Default: 'base_link')
-w, --overwrite
Force overwrite target file without prompting.
-c <config.yml>, --config <config.yml>
(required) Config yaml file (*.yml)
-o <dataset_out.rawlog>, --output <dataset_out.rawlog>
(required) Output dataset (*.rawlog)
--, --ignore_rest
Ignores the rest of the labeled arguments following this flag.
--version
Displays version information and exits.
-h, --help
Displays usage information and exits.
<log.bag> (accepted multiple times)
(required) Input bag files (required) (*.bag)
For example:

.. code-block:: bash
$ rosbag2rawlog -c config.yaml -o output.rawlog input.mcap
With the ``config.yaml`` file created as explained below.


2.1. YAML config file format
==============================
``rosbag2rawlog`` needs an input configuration file to determine **what ROS messages** in the bag are to be **imported**.
The rest will be discarded, after emitting a warning to the terminal.

.. dropdown:: Example: basic Ouster LiDAR import
:open:

.. code-block:: yaml
# Config file for rosbag2rawlog. It must contain a top-level "sensors" node
sensors:
# Then, one node per sensor to convert. This name will be used as
# sensorLabel in MRPT observations.
lidar:
# Type: C++ class name (see mrpt::obs)
type: 'CObservationPointCloud'
topic: '/ouster/points'
# If uncommented, /tf data will be ignored for this sensor pose:
#fixed_sensor_pose: "0 0 0 0 0 0" # 'x y z yaw_deg pitch_deg roll_deg''
.. dropdown:: Example: Newer College Dataset import

.. code-block:: yaml
# Config file for rosbag2rawlog. It must contain a top-level "sensors" node
sensors:
# Then, one node per sensor to convert. This name will be used as
# sensorLabel in MRPT observations.
lidar:
# Type: C++ class name (see mrpt::obs)
type: 'CObservationPointCloud'
# Parameters for this particular type of sensor.
# Topic to subscribe for the pointcloud:
topic: '/os_cloud_node/points'
fixed_sensor_pose: "0 0 0 0 0 0" # 'x y z yaw_deg pitch_deg roll_deg''
cam0:
type: 'CObservationImage'
image_topic: '/alphasense_driver_ros/cam0/compressed'
fixed_sensor_pose: "0 0 0 0 0 0" # 'x y z yaw_deg pitch_deg roll_deg''
.. dropdown:: Example: LiDAR + wheels odometry from /odom

.. code-block:: yaml
# Config file for rosbag2rawlog. It must contain a top-level "sensors" node
sensors:
# Then, one node per sensor to convert. This name will be used as
# sensorLabel in MRPT observations.
lidar:
# Type: C++ class name (see mrpt::obs)
type: 'CObservationPointCloud'
topic: '/ouster/points'
# If uncommented, /tf data will be ignored for this sensor pose:
#fixed_sensor_pose: "0 0 0 0 0 0" # 'x y z yaw_deg pitch_deg roll_deg''
odom:
type: 'CObservationOdometry'
topic: '/odom'
.. dropdown:: Example: LiDAR + wheels odometry from /tf

.. code-block:: yaml
# Config file for rosbag2rawlog. It must contain a top-level "sensors" node
sensors:
# Then, one node per sensor to convert. This name will be used as
# sensorLabel in MRPT observations.
lidar:
# Type: C++ class name (see mrpt::obs)
type: 'CObservationPointCloud'
topic: '/ouster/points'
# If uncommented, /tf data will be ignored for this sensor pose:
#fixed_sensor_pose: "0 0 0 0 0 0" # 'x y z yaw_deg pitch_deg roll_deg''
# If provided, odometry observations will be generated from /tf messages
# from `odom_frame_id` to `base_link` (frame_id can be changed via cli arguments):
odom_from_tf:
sensor_label: 'odom' # mandatory entry
#odom_frame_id: '/odom'
|

3. rawlog ⇒ ROS
----------------------------
For ROS 1 and ROS 2.

Write me!


|

.. _mola-dataset-to-ros:

4. MOLA data set module ⇒ ROS
------------------------------
Write me!
93 changes: 59 additions & 34 deletions docs/source/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ MOLA
mola_architecture
tutorials
supported-sensors
dataset-conversions
modules
doxygen-index
bibliography
Expand All @@ -69,52 +70,73 @@ Get started:
.. humble badges ------
.. |badgeHdev| image:: https://build.ros2.org/job/Hdev__mola__ubuntu_jammy_amd64/badge/icon
:scale: 100%
:align: middle
:target: https://build.ros2.org/job/Hdev__mola__ubuntu_jammy_amd64/

.. |badgeHrel| image:: https://img.shields.io/ros/v/humble/mola
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola

.. iron badges ------
.. |badgeHrel_LO| image:: https://img.shields.io/ros/v/humble/mola_lidar_odometry
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola_lidar_odometry

.. |badgeIdev| image:: https://build.ros2.org/job/Idev__mola__ubuntu_jammy_amd64/badge/icon
.. |badgeHrel_MP| image:: https://img.shields.io/ros/v/humble/mp2p_icp
:scale: 100%
:align: middle
:target: https://build.ros2.org/job/Idev__mola__ubuntu_jammy_amd64/
:target: https://index.ros.org/search/?term=mp2p_icp

.. iron badges ------
.. |badgeIrel| image:: https://img.shields.io/ros/v/iron/mola
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola

.. jazzy badges ------
.. |badgeIrel_LO| image:: https://img.shields.io/ros/v/iron/mola_lidar_odometry
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola_lidar_odometry

.. |badgeJdev| image:: https://build.ros2.org/job/Jdev__mola__ubuntu_noble_amd64/badge/icon
.. |badgeIrel_MP| image:: https://img.shields.io/ros/v/iron/mp2p_icp
:scale: 100%
:align: middle
:target: https://build.ros2.org/job/Jdev__mola__ubuntu_noble_amd64/
:target: https://index.ros.org/search/?term=mp2p_icp

.. jazzy badges ------
.. |badgeJrel| image:: https://img.shields.io/ros/v/jazzy/mola
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola

.. rolling badges ------
.. |badgeJrel_LO| image:: https://img.shields.io/ros/v/jazzy/mola_lidar_odometry
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola_lidar_odometry

.. |badgeRdev| image:: https://build.ros2.org/job/Rdev__mola__ubuntu_noble_amd64/badge/icon
.. |badgeJrel_MP| image:: https://img.shields.io/ros/v/jazzy/mp2p_icp
:scale: 100%
:align: middle
:target: https://build.ros2.org/job/Rdev__mola__ubuntu_noble_amd64/
:target: https://index.ros.org/search/?term=mp2p_icp


.. rolling badges ------
.. |badgeRrel| image:: https://img.shields.io/ros/v/rolling/mola
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola

.. |badgeRrel_LO| image:: https://img.shields.io/ros/v/rolling/mola_lidar_odometry
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mola_lidar_odometry

.. |badgeRrel_MP| image:: https://img.shields.io/ros/v/rolling/mp2p_icp
:scale: 100%
:align: middle
:target: https://index.ros.org/search/?term=mp2p_icp


.. _installing:

Expand All @@ -134,15 +156,14 @@ How to install all MOLA modules:

.. code-block:: bash
# Install core MOLA modules:
sudo apt install ros-$ROS_DISTRO-mola
# Install core MOLA modules and 3D LiDAR odometry:
sudo apt install ros-$ROS_DISTRO-mola ros-$ROS_DISTRO-mola-lidar-odometry
# Install the MOLA LIDAR odometry package:
# sudo apt install ros-$ROS_DISTRO-mola-lidar-odometry
# As of Jul 2024, this package is not available from apt yet!
# Please see instructions below to clone and build it from sources
# As of Aug 2024, lidar_odometry is not available for all ROS distros yet!
# If the apt command above fails, please remove the "mola-lidar-odometry" part
# and see instructions below to clone and build the missing module from sources
# Install example small datasets to run demos/unit tests:
# (OPTIONAL) Install example small datasets to run demos/unit tests:
sudo apt install ros-$ROS_DISTRO-mola-test-datasets
Check if all new nodes and apps are visible:
Expand All @@ -153,19 +174,23 @@ How to install all MOLA modules:
# If a GUI app is opened, it means installation was successful.
mm-viewer
These are the versions available from ROS build farms:

+-------------------------+-----------------------------+------------------------------------+
| ROS distribution | Development build status | Last release (available via apt) |
+=========================+=============================+====================================+
| ROS 2 Humble (u22.04) | |badgeHdev| | |badgeHrel| |
+-------------------------+-----------------------------+------------------------------------+
| ROS 2 Iron (u22.04) | |badgeIdev| | |badgeIrel| |
+-------------------------+-----------------------------+------------------------------------+
| ROS 2 Jazzy (u24.04) | |badgeJdev| | |badgeJrel| |
+-------------------------+-----------------------------+------------------------------------+
| ROS 2 Rolling (u24.04) | |badgeRdev| | |badgeRrel| |
+-------------------------+-----------------------------+------------------------------------+
# You can also test the mola LO cli interface:
mola-lidar-odometry-cli --help
These are the **versions available** from ROS build farms for each main MOLA component:

+-------------------------+---------------+---------------------+---------------------+
| ROS distribution | MOLA | mola_lidar_odometry | mp2p_icp |
+=========================+===============+=====================+=====================+
| ROS 2 Humble (u22.04) | |badgeHrel| | |badgeHrel_LO| | |badgeHrel_MP| |
+-------------------------+---------------+---------------------+---------------------+
| ROS 2 Iron (u22.04) | |badgeIrel| | |badgeIrel_LO| | |badgeIrel_MP| |
+-------------------------+---------------+---------------------+---------------------+
| ROS 2 Jazzy (u24.04) | |badgeJrel| | |badgeJrel_LO| | |badgeJrel_MP| |
+-------------------------+---------------+---------------------+---------------------+
| ROS 2 Rolling (u24.04) | |badgeRrel| | |badgeRrel_LO| | |badgeRrel_MP| |
+-------------------------+---------------+---------------------+---------------------+


.. dropdown:: Build from sources
Expand Down
3 changes: 3 additions & 0 deletions kitti_metrics_eval/CHANGELOG.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ Changelog for package kitti_metrics_eval
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^


1.1.1 (2024-08-23)
------------------

1.1.0 (2024-08-18)
------------------
* Merge pull request `#62 <https://github.com/MOLAorg/mola/issues/62>`_ from MOLAorg/docs-fixes
Expand Down
Loading

0 comments on commit 79d6629

Please sign in to comment.