Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 1.6.7 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | master |
| Last Updated | 2025-09-01 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS1 Noetic (u20.04) | amd64 arm64 armhf |
||
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms. It depends onmp2p_icp_map.
And these applications:
-
kitti2mm: Converts KITTI-like
.binfiles to.mmfiles. -
mm-filter: CLI tool to apply a pipeline to an input metric map (
*.mm), saving the result as another metric map file. -
mm-info: CLI tool to read a metric map (
*.mm) and describe its contents. - mm-viewer: GUI tool to visualize .mm (metric map) files.
-
mm2txt: CLI tool to export the layers of a metric map (
*.mm) as CSV/TXT. - icp-log-viewer: GUI to inspect results from ICP runs.
- icp-run: Standalone program to run ICP pipelines.
-
sm2mm: A CLI tool to convert a simple map
*.simplemap(from a SLAM mapping session) into a metric map (*.mm) via a configurable pipeline configuration file. -
sm-cli: A CLI tool to inspect, visualize, or modify simple maps
*.simplemap(from a SLAM mapping session). - txt2mm: CLI tool to convert pointclouds from CSV/TXT files to mp2p_icp mm.
Key C++ classes provided by this project (see full docs):
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, e.g. segmented, discrete extracted features. Note that filtering point clouds is intentionally left outside of the scope of this library. See MOLA for possible implementations. -
mp2p_icp::ICP_Base: A uniform API for matching those generic point clouds. - Implementations/wrappers of different ICP algorithms under such uniform API.
- The library exposes both, complete iterative ICP algorithms, and the underlying optimal transformation estimators which are run at each ICP iteration.

Changelog for package mp2p_icp
1.6.7 (2025-04-03)
- mm-georef cli app: support reading/writing georef info in YAML format
- georeferencing metadata now can be read/writen as YAML files
- clang-format: switch to column limit=100
- Update to robin-map v1.4.0
- Contributors: Jose Luis Blanco-Claraco
1.6.6 (2025-02-26)
- Docs: add page for mm-georef
- docs: Update 2025 paper citation
- print metric_map_t as string: show lat/lon coordinates in a format directly compatible with Google Map searches.
- New cli tool: mm-georef, to manipulate the geo-referencing metadata of metric map files
- Contributors: Jose Luis Blanco-Claraco
1.6.5 (2025-01-28)
- Add GitHub actions
- Add pole-detector filter
- mm-filter app: add --load-plugins flag too
- Add sanity check assert in FilterDeskew
- Contributors: Jose Luis Blanco-Claraco
1.6.4 (2024-12-18)
- merge two docs pages in one to shorten the docs TOC
- Update README.md: Mark ROS2 Iron as EOL
- Also use TBB for parallel solving point-to-plane pairings
- Contributors: Jose Luis Blanco-Claraco
1.6.3 (2024-11-11)
- icp-log-viewer: also reduce GUI refresh rate
- mm-viewer: avoid useless GUI refresh (CPU usage reduction)
- txt2mm: Add input filter xyzrgb
- mm-viewer: add a 'fit view to map' button
- New cli app rawlog-filter
- FilterCurvature: better handling scans with <=3 points in some rings
- new subcommand 'sm-cli tf'
- Contributors: Jose Luis Blanco-Claraco
1.6.2 (2024-09-14)
- Expose << and >> operators for geo-reference data structures
- Fix missing build_dep
- Contributors: Jose Luis Blanco-Claraco
1.6.1 (2024-09-11)
- Fix missing catkin buildtoo_depend for ROS1 builds
- Update RTTI macros for upcoming MRPT 2.14.0
- Contributors: Jose Luis Blanco-Claraco
1.6.0 (2024-09-08)
- Port Point2Plane matcher to use the new NN-for-planes API
- mp2p_icp_map library: add NearestPlaneCapable virtual API
- cmake: move from glob expressions to explicit lists of source files
- clarify eigenvalues order in headers
- Contributors: Jose Luis Blanco-Claraco
1.5.6 (2024-09-07)
- sm2mm cli: show map contents before writing to disk
- add another demo sm2mm file for the mola tutorials
- Add another sm2mm demo file w/o deskew for the mola mapping tutorial
- Matcher_Point2Plane: fix build error in armhf
- Fix build with embedded mola_common
- README: Add ROS badges for all architectures
- Contributors: Jose Luis Blanco-Claraco
1.5.5 (2024-08-27)
- Explicitly add tbb as dependency in package.xml
- Depend on new mrpt_lib packages (deprecate mrpt2)
- FIX: build errors in armhf arch
- Contributors: Jose Luis Blanco-Claraco
1.5.4 (2024-08-20)
- Do not use Eigen::Vector for compatibility with Eigen3 <3.4 in ROS Noetic
- Contributors: Jose Luis Blanco-Claraco
1.5.3 (2024-08-20)
- Re-add ROS1 Noetic as supported distribution
- Generator sanity check asserts: more informative error messages
- sm-cli: new command 'join' to merge simplemaps
- icp-log-viewer UI: new keybind 'I' to switch initial/final pose
- icp-log-viewer UI: add option to visualize voxelmaps empty space
- Contributors: Jose Luis Blanco-Claraco
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap |
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 2.6.0 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | develop |
| Last Updated | 2026-02-23 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Kilted @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS1 Noetic (u20.04) | |
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container and related utilities for working with point cloud data structures. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms, matchers (point-to-point, point-to-plane, point-to-line, covariance-to-covariance, adaptive), solvers (Horn, OLAE, Gauss-Newton), and quality evaluators. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms including decimation, voxelization, statistical outlier removal, edge/plane extraction, and various geometric transformations. It depends onmp2p_icp_map.
Command-Line Applications
The full repository also includes these applications (see apps/ directory):
Data Conversion Tools
-
kitti2mm: Converts KITTI dataset LIDAR binary files (
.bin) with (X,Y,Z, Intensity) data into mp2p_icp metric map files (.mm). Supports custom layer names, numeric IDs, and label strings. -
txt2mm: Converts plain-text point cloud data (TXT/CSV) into metric map (
.mm) files. Supports multiple formats: XYZ, XYZI, XYZIRT, XYZRGB, with configurable column mapping and layer names. -
sm2mm: Converts a simple map (
.simplemap) from a SLAM mapping session into a metric map (.mm) using a configurable processing pipeline. Essential for post-processing SLAM outputs into structured metric representations.
Data Export Tools
-
mm2ply: Exports metric map layers to PLY point cloud files. Supports both ASCII and binary formats, selective field export, and preserves all point attributes (coordinates, colors, intensities, etc.).
-
mm2txt: Exports metric map layers as space-delimited CSV/TXT files with header rows. Ideal for data analysis in spreadsheet applications or custom processing pipelines. Supports selective layer and field export.
-
mm2las: Exports metric maps to industry-standard LAS 1.4 format with Point Format 8 support. Includes automatic color mapping, extra dimensions for custom fields. Compatible with CloudCompare, QGIS, and ArcGIS.
Map Processing & Analysis Tools
-
mm-filter: Applies mp2p_icp_filters pipelines to metric map files. Can operate in pipeline mode (applying complete YAML-defined filter chains) or rename mode (simply renaming layers). Supports custom plugin loading.
-
mm-info: Displays a summary of metric map contents including layers, point counts, and metadata.
-
mm-georef: Extracts or injects geo-referencing information between metric map files (
.mm) and standalone georeferencing files (.georef).
Visualization Tools
-
mm-viewer: GUI application to visualize metric map (
.mm) files. Supports loading additional 3D scenes and trajectory files in TUM format. -
icp-log-viewer: Interactive GUI for debugging ICP pipelines. Visualizes ICP log files (
.icplog) with autoplay mode and detailed inspection of registration results. Essential for understanding and optimizing ICP algorithm performance.
ICP Execution Tools
- icp-run: Standalone program to execute ICP pipelines from the command line.
SimpleMaps Manipulation
-
sm-cli: Swiss-army knife for simple map (
.simplemap) manipulation. Commands include:info(analyze contents),cut(extract by keyframe index),trim(extract by bounding box),join(merge maps),level(make horizontal),tf(apply SE(3) transform),export-keyframes(save trajectories as TUM), andexport-rawlog(convert to RawLog format).
Key Features and Components
Key C++ classes provided by this project (see full documentation):
Core Data Structures
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, including support for multiple layers, segmented data, and discrete extracted features.
ICP Algorithms and Matchers
-
mp2p_icp::ICP: A uniform API for matching generic point clouds with support for:- Point-to-Point matching (various distance metrics)
- Point-to-Plane matching (planes extracted from point clouds)
- Point-to-Line matching (edges/lines extracted from point clouds)
- Covariance-to-Covariance matching (Gaussian distributions)
- Adaptive matching (automatically selects best matcher)
Solvers
- Horn’s method: Closed-form solution for point-to-point alignment
- OLAE (Optimal Linear Attitude Estimator): For attitude/rotation estimation
- Gauss-Newton: Iterative solver for complex matching scenarios
Filters and Generators
The mp2p_icp_filters library provides extensive filtering capabilities:
-
Decimation:
FilterDecimate,FilterDecimateVoxels,FilterDecimateAdaptive -
Outlier removal:
FilterSOR(Statistical Outlier Removal),FilterVoxelSOR
File truncated at 100 lines see the full file
Changelog for package mp2p_icp
2.6.0 (2026-02-16)
- Merge pull request #42 from MOLAorg/feat/filter-remove-several-point-fields FilterRemovePointCloudField now accepts multiple fields
- FilterRemovePointCloudField now accepts multiple fields
- Merge pull request #41 from MOLAorg/feat/functor-save-log-file Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Add functor_should_generate_debug_file to override the decision of whether to write .icplog files
- Merge pull request #40 from MOLAorg/feat/new-clear-remove-field-filters Add new filters: FilterClear and FilterRemovePointCloudField
- Add new filters: FilterClear and FilterRemovePointCloudField
- docs: refer to the online pipeline editor
- docs: add missing docs for FilterRenameLayer
- Contributors: Jose Luis Blanco-Claraco
2.5.0 (2026-02-04)
- Merge pull request #39 from MOLAorg/feat/permit-missing-externals sm2mm: Add optional flag --permit-missing-externals
- sm2mm: Add optional flag --permit-missing-externals
- Merge pull request #38 from MOLAorg/feat/mls-optimizations FilterMLS performance optimizations
- Merge pull request #37 from MOLAorg/feat/use-zstd Use ZStd compression by default (for MRPT>=2.15.7)
- docs: sm2mm add "--compression-method"
- Explicitly include mrpt/core/Clock.h where used
- Use ZStd compression by default (for MRPT>=2.15.7)
- Merge pull request #36 from MOLAorg/feat/mm2txt-missing-fields-dont-emit mm2txt, mm2ply: don't emit columns of zeros for missing user-given fields
- Merge pull request #35 from MOLAorg/feat/mm2txt-ignore-fields mm2txt and mm2ply: Add new option --ignore-missing-fields
- Merge pull request #34 from MOLAorg/feat/mm2txt-mm2ply-more-precision Exploit the maximum float32/float64 precision in exported txt formats
- Merge pull request #33 from MOLAorg/feat/sm2mm-new-options Feat/sm2mm-new-options
- sm2mm cli app: add new flags for downsampling options
- sm2mm: add new downsample options and refactor into update_velocity_buffer_from_obs()
- Contributors: Jose Luis Blanco-Claraco
2.4.1 (2026-01-27)
- Add more unit tests
- Update README to keep it in sync with the provided apps and libraries
- Merge pull request #29 from MOLAorg/fix/cov Fix bugs in covariance estimation for some cases
- fix covariance estimation bugs; add unit tests for cov2cov
- Update commit for mola_common
- Merge pull request #28 from MOLAorg/feat/mm-viewer-3d-layers mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- mm-viewer: add CLI flags to load overlaid 3D scenes for visualization
- Contributors: Jose Luis Blanco-Claraco
2.4.0 (2026-01-21)
- Merge pull request #27 from MOLAorg/feat/new-filter-voxel-sor
- Add new unit test for class factory
- Add new FilterVoxelSOR filter
- Merge pull request #26 from MOLAorg/feat/mm2las
- Add mm2las CLI tool
- Contributors: Jose Luis Blanco-Claraco
2.3.1 (2026-01-14)
- Merge pull request #25 from MOLAorg/feat/naive-decimate Add trivial FilterDecimate for fast downsampling without spatial awareness
- lint fixes
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap | |
| mola_imu_preintegration |
System Dependencies
Launch files
Messages
Services
Plugins
Recent questions tagged mp2p_icp at Robotics Stack Exchange
Package Summary
| Version | 1.6.7 |
| License | BSD-3-Clause |
| Build type | CATKIN |
| Use | RECOMMENDED |
Repository Summary
| Description | Multi primitive-to-primitive (MP2P) ICP algorithms in C++ |
| Checkout URI | https://github.com/MOLAorg/mp2p_icp.git |
| VCS Type | git |
| VCS Version | master |
| Last Updated | 2025-09-01 |
| Dev Status | DEVELOPED |
| Released | RELEASED |
| Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Jose-Luis Blanco-Claraco
Authors
| Distro | Build dev | Build releases | Stable version |
|---|---|---|---|
| ROS1 Noetic (u20.04) | amd64 arm64 armhf |
||
| ROS 2 Humble (u22.04) | amd64 arm64 |
||
| ROS 2 Jazzy @ u24.04 | amd64 arm64 |
||
| ROS 2 Rolling (u24.04) | amd64 arm64 |
| EOL Distro | Last release |
|---|---|
| ROS 2 Iron (u22.04) |
mp2p_icp
C++ libraries for multi primitive-to-primitive (MP2P) ICP algorithms and flexible point cloud processing pipelines. mp2p_icp is used in the mola_lidar_odometry framework:
- Main library documentation and C++ API
- License: New BSD 3-Clause (Note that each module of MOLA has its own license)
Introduction
The project provides these C++ libraries:
-
mp2p_icp_map: Provides themp2p_icp::metric_map_tgeneric metric map container. Metric map files with extension*.mmare serializations of instances of this class. -
mp2p_icp: With ICP algorithms. It depends onmp2p_icp_map. -
mp2p_icp_filters: With point cloud filtering and manipulation algorithms. It depends onmp2p_icp_map.
And these applications:
-
kitti2mm: Converts KITTI-like
.binfiles to.mmfiles. -
mm-filter: CLI tool to apply a pipeline to an input metric map (
*.mm), saving the result as another metric map file. -
mm-info: CLI tool to read a metric map (
*.mm) and describe its contents. - mm-viewer: GUI tool to visualize .mm (metric map) files.
-
mm2txt: CLI tool to export the layers of a metric map (
*.mm) as CSV/TXT. - icp-log-viewer: GUI to inspect results from ICP runs.
- icp-run: Standalone program to run ICP pipelines.
-
sm2mm: A CLI tool to convert a simple map
*.simplemap(from a SLAM mapping session) into a metric map (*.mm) via a configurable pipeline configuration file. -
sm-cli: A CLI tool to inspect, visualize, or modify simple maps
*.simplemap(from a SLAM mapping session). - txt2mm: CLI tool to convert pointclouds from CSV/TXT files to mp2p_icp mm.
Key C++ classes provided by this project (see full docs):
-
mp2p_icp::metric_map_t: A generic data type to store raw or processed point clouds, e.g. segmented, discrete extracted features. Note that filtering point clouds is intentionally left outside of the scope of this library. See MOLA for possible implementations. -
mp2p_icp::ICP_Base: A uniform API for matching those generic point clouds. - Implementations/wrappers of different ICP algorithms under such uniform API.
- The library exposes both, complete iterative ICP algorithms, and the underlying optimal transformation estimators which are run at each ICP iteration.

Changelog for package mp2p_icp
1.6.7 (2025-04-03)
- mm-georef cli app: support reading/writing georef info in YAML format
- georeferencing metadata now can be read/writen as YAML files
- clang-format: switch to column limit=100
- Update to robin-map v1.4.0
- Contributors: Jose Luis Blanco-Claraco
1.6.6 (2025-02-26)
- Docs: add page for mm-georef
- docs: Update 2025 paper citation
- print metric_map_t as string: show lat/lon coordinates in a format directly compatible with Google Map searches.
- New cli tool: mm-georef, to manipulate the geo-referencing metadata of metric map files
- Contributors: Jose Luis Blanco-Claraco
1.6.5 (2025-01-28)
- Add GitHub actions
- Add pole-detector filter
- mm-filter app: add --load-plugins flag too
- Add sanity check assert in FilterDeskew
- Contributors: Jose Luis Blanco-Claraco
1.6.4 (2024-12-18)
- merge two docs pages in one to shorten the docs TOC
- Update README.md: Mark ROS2 Iron as EOL
- Also use TBB for parallel solving point-to-plane pairings
- Contributors: Jose Luis Blanco-Claraco
1.6.3 (2024-11-11)
- icp-log-viewer: also reduce GUI refresh rate
- mm-viewer: avoid useless GUI refresh (CPU usage reduction)
- txt2mm: Add input filter xyzrgb
- mm-viewer: add a 'fit view to map' button
- New cli app rawlog-filter
- FilterCurvature: better handling scans with <=3 points in some rings
- new subcommand 'sm-cli tf'
- Contributors: Jose Luis Blanco-Claraco
1.6.2 (2024-09-14)
- Expose << and >> operators for geo-reference data structures
- Fix missing build_dep
- Contributors: Jose Luis Blanco-Claraco
1.6.1 (2024-09-11)
- Fix missing catkin buildtoo_depend for ROS1 builds
- Update RTTI macros for upcoming MRPT 2.14.0
- Contributors: Jose Luis Blanco-Claraco
1.6.0 (2024-09-08)
- Port Point2Plane matcher to use the new NN-for-planes API
- mp2p_icp_map library: add NearestPlaneCapable virtual API
- cmake: move from glob expressions to explicit lists of source files
- clarify eigenvalues order in headers
- Contributors: Jose Luis Blanco-Claraco
1.5.6 (2024-09-07)
- sm2mm cli: show map contents before writing to disk
- add another demo sm2mm file for the mola tutorials
- Add another sm2mm demo file w/o deskew for the mola mapping tutorial
- Matcher_Point2Plane: fix build error in armhf
- Fix build with embedded mola_common
- README: Add ROS badges for all architectures
- Contributors: Jose Luis Blanco-Claraco
1.5.5 (2024-08-27)
- Explicitly add tbb as dependency in package.xml
- Depend on new mrpt_lib packages (deprecate mrpt2)
- FIX: build errors in armhf arch
- Contributors: Jose Luis Blanco-Claraco
1.5.4 (2024-08-20)
- Do not use Eigen::Vector for compatibility with Eigen3 <3.4 in ROS Noetic
- Contributors: Jose Luis Blanco-Claraco
1.5.3 (2024-08-20)
- Re-add ROS1 Noetic as supported distribution
- Generator sanity check asserts: more informative error messages
- sm-cli: new command 'join' to merge simplemaps
- icp-log-viewer UI: new keybind 'I' to switch initial/final pose
- icp-log-viewer UI: add option to visualize voxelmaps empty space
- Contributors: Jose Luis Blanco-Claraco
File truncated at 100 lines see the full file
Package Dependencies
| Deps | Name |
|---|---|
| ros_environment | |
| catkin | |
| mola_common | |
| mrpt_libbase | |
| mrpt_libobs | |
| mrpt_libposes | |
| mrpt_libmaps | |
| mrpt_libgui | |
| mrpt_libtclap |
System Dependencies
Dependant Packages
| Name | Deps |
|---|---|
| mrpt_local_obstacles |