Releases + Changelogs
Version 13.0.0 - January 14th, 2025
Overview
The major feature of this releaase is a big speedup (2-3x faster in testing) when processing H.264 datasets.
Additionally, this release introduces some breaking changes to the Markers
fiducial type (now
named SquareMarkers
) and minor ones to the format of some metrics in results.json
. Both of these
changes are fairly niche and we do not expect them to have an impact on the vast majority of users.
Changelog
- (Breaking Change) The
Markers
fiducial type has been renamed toSquareMarkers
. Please update your object space file if you are using this (uncommon) fiducial type. - (Breaking Change) Added
marker_ids
field toSquareMarkers
and removedmarker_length
. - (Breaking Change) The
results.json
file no longer contains ametrics.optimized_object_space
field. Instead users should start using theobject_space
field at the top-level of the results as that now contains the inferred object space. This will not affect users who aren't already doing custom processing of theresults.json
file. - Greatly improve performance when ingesting H.264 datasets
Version 12.2.0 - December 13th, 2024
Overview
This release has some nice improvements to camera < - > lidar (especially in multi-target scenarios) as well as greatly improved aprilgrid detection quality. In addition, this release includes some visualization and logging quality of life improvements.
Changelog
Added
- Added an optional
reflective_tape_width
field to the circle board object space format. This is used as a hint to the detector when identifying retroreflective circles in point clouds.
Changed
- Improved detection quality of multiple circle boards in the same environment.
- Made various improvements to the underlying optimization calculations.
- Upgraded to Rerun v0.19.
- Made various improvements to visualization of lidar and image detections.
Fixed
- Greatly improved detection quality on Kalibr-style Aprilgrid targets.
- Fixed an issue with detecting image features with only a single adjacent tag.
- Addressed some small timestamp-related visualization bugs.
Removed
- Evaluate mode has been hidden as a command, due to pending improvements. The mechanism that is currently used to perform the metric generation during evaluate mode runs an optimization, which can lead to some hard-to-interpret results. In particular, errors may projectively compensate into the object-space which at present does not have any user-visible metrics readily available outside of the rerun visualization. For more information on this change, please see the "Evaluate" mode documentation.
Version 12.1.0 - October 23rd, 2024
Overview
This is a small update. The main user-facing change is that MetriCal can now handle markerboards generated by newer versions of OpenCV. OpenCV introduced a silent breaking change to its markerboard generation in version 4.6.0, which can cause problems with MetriCal's detection of certain newer boards under some circumstances. For more information, please reference the initial_corner field in the markerboard docs.
Changelog
Changed
- Update internal OpenCV version from 4.5.4 to 4.10.0
Added
- Add support for both OpenCV "new" style markerboards.
Version 12.0.0
MetriCal Sensor Calibration Utilities repository for v12.0.0: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v12.0.0
Overview
This release is probably one of our largest ever. There are new modes, new mathematics, and more expressivity. And as with every major version bump, we've also made some changes to the CLI arguments. Most old arguments that have changed have been deprecated, not removed, so you can still use your scripts from v11.0 (for the most part). You'll just get loud warnings about switching over before v13 comes around...
Change Your MetriCal Alias!
First and foremost: If you're a current user, we suggest adding the --tty
flag to your metrical
bash alias. See an example in the setup docs. This allows MetriCal
to render progress bars in the terminal, which makes it a much nicer experience when processing
large datasets. Otherwise, you'll just see a blank screen for a while.
UI + UX Highlights
Offline Licensing
MetriCal now offers users the option to cache licenses for offline use. If you're running MetriCal "in the field" (aka away from a modem), this is the feature for you! Note that offline licenses are only valid for a week before MetriCal needs to ping a Tangram server.
Visit the licensing docs for setup and details.
Descriptive Error Messages
We've reworked every. single. error case in MetriCal to have a descriptive error message. Instead of getting something generic, you'll now see the error, the error's cause, and a helpful suggestion on how to fix it. Many of these suggestions link directly to the documentation, so you don't have to search around for the "right answer" anymore.
For those of you developing your own Rust programs, we couldn't recommend miette enough.
Cached Detections
Tired of re-running detections when running a new calibration? We've got you covered. MetriCal now caches its detections from the initial dataset processing. This means you can change models and test different configurations in a fraction of the processing time.
There are two ways MetriCal finds detections:
- Passed to the CLI via the $DATA required argument. For instance, instead of passing an MCAP, one could just pass that MCAP's cached detections JSON.
- Automatically found in the same directory as the dataset. Cached detections are written to the
same directory as the dataset, named with a
.detections.json
extension to the dataset name. For example,/dataset/example.mcap
would have a cached detections file named/dataset/example.detections.json
. If MetriCal finds this file, it will use it instead of re-processing the entire dataset.
This also means that datasets with the same name will produce detection caches with the same name. We don't advise naming all of your files the same thing anyway, but... you do you.
If you have cached detections, but really want to re-process them anyway, just pass the
--overwrite
/-y
flag to Calibrate or Evaluate mode.
Multiple Seed Plex in Init Mode
You can now pass multiple seed plex to Init mode. This is useful in a "big rig" scenario, when it's just not feasible to collect every sensor's data in one run. For example, one might run data from 4 cameras individually, then combine them all into one system to gather extrinsics via Init mode.
When processing multiple seed plex, the newest plex is given priority, being processed for new information from newest to oldest. If there is an existing Init'd plex for the dataset, that plex is also used as a seed. This makes it even easier to compare and contrast different calibrations.
Display Mode
Version 12.0 also introduces Display mode, which allows you to visualize the applied calibration to
any dataset. This takes the place of the --render
flag in Calibrate and Evaluate modes, which now
just renders the detections used for calibration. Important: Display mode expects a running instance
of Rerun v0.18.
Changelog
Added
- CLI:
- Change the logging level more easily with verbose flags:
-v
(Debug),-vv
(Trace),-q
(Warn), or-qq
(Error). - Multi-progress bar to estimate observation read-in time. Make sure to add
-t
to a Docker alias to use this functionality! - Offline licensing. See the licensing docs for setup and details.
- An
OptimizationProfile
argument to Calibrate mode that allows users to tune the parameters of the adjustment e.g. relative error threshold, absolute error threshold, and max iterations. - A binned outlier count is now reported in the camera binned reprojection table.
- Display mode to visualize the output of a calibration.
- A new sub-mode,
metrical shape tabular
which can convert a plex into a simplified, stable, tabular format that holds a set of intrinsics (and direct artefacts of the intrinsics, such as look-up tables) alongside extrinsics. The tabular format from this mode can be exported as either JSON or MsgPack binary (to compress the total filesize, as LUTs can be quite large). - Tables for Component Relative Extrinsics, as well as Preintegrated IMU errors. This should give you a much better idea of extrinsics quality beyond the abstract covariance values for spatial constraints.
- Change the logging level more easily with verbose flags:
- Data I/O:
- Expanded list of encodings for YUYV image types in ROS -
uyvy
,UYVY
,yuv422
,yuyv
,YUYV
, andyuv422_yuy2
are all supported.- That's gotta be all of them, right? Right? Let's all come together to make life easier for your old Tangram pals.
- H264 message types for ROS1 (from this project) and MCAP (from Foxglove's CompressedVideo).
- Added support to
CompressedImage
types for the alternate spelling for "jpg".
- Expanded list of encodings for YUYV image types in ROS -
- Detection and reweighting of Paired 3D Point outliers.
Changed
- Algorithm Changes:
- Use new M-estimators, and remove all explicit outlier logic. No more outlier flags!
- Paired Plane Normals between lidar-lidar pairs are no longer used
- The motion filter has been rewritten to include both images and lidar detections. Users can
manipulate the motion detector thresholds by using the
--camera-motion-threshold
and--lidar-motion-threshold
flags, or just turn it off with--disable-motion-filter
. - The motion filter now runs after all detections have been processed. This means that you can manipulate the motion filter over cached detections, too.
- CLI:
UmbraOutput
is nowCalibrationOutput
.- All error codes have been changed in favor of simpler error code and more descriptive fixes.
- Look Up Tables generated via the
metrical shape lut
command are now generated using theimage_luts
module from the applications crate. This changes the final schema for look up tables but makes them more directly compatible with OpenCV and other software that expects both row and column remappings to be separated.
- Init mode:
- Init mode can now take multiple plex as seeds.
- If a previously generated init plex is found at the same location as the plex-to-be-written, then the previous plex is used as a seed for the new plex.
- Change of basis is respected and applied in Init mode when seeding the plex with an input plex.
- Rendering:
- Observations and detections are rendered in the same entity in the visualization.
- When rendering more than one point cloud in Display mode, each component's point clouds are uniformily colored rather than colored by the point's intensity value. This allows for easier comparison between components.
- Calibrate mode no longer renders the results of a calibration, only the observations and detections. Results are applied in Display mode.
Fixed
- CLI:
- Component names with "/" no longer cause file I/O issues with the
shape focus
command
- Component names with "/" no longer cause file I/O issues with the
- Detectors:
- The circle detector for point clouds and the feature detector for images are now much more robust to misdetections and noise.
- Init mode:
- Init mode now correctly handles all (spec'd) cases in which a seed plex as the basis for a new plex.
- Topics that are not usable by MetriCal for the purposes of calibration are now filtered out.
- If there are no usable topics, Init mode will list the usable topics in a dataset for the user.
- There was a (self-induced) memory pressure build-up during lidar detection that has been remedied.
Removed
- Init mode:
- Preset devices have been removed from Init mode.
Version 11.0.0
MetriCal Sensor Calibration Utilities repository for v11.0.0: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v11.0.0
Overview
This version bump is a big one! Data processing improvements, algorithmic improvements, CLI simplification... there's a little something for everyone here. Most of the changes in 11.0.0 were made based on testing from customers in the field. Thanks, everyone!
Note that many CLI arguments have been shifted or removed. Be sure to check the changelog and updated documentation to make sure your settings remain.
Changelog
Added
- Visualization improvements:
- Render navigation states and IMU data by default.
- Render all observations when log level is set to debug.
- Change of Basis tooling:
- Add
--topic-to-observation-basis
global argument to all modes in order to map a coordinate basis to each component's observations on plex construction (docs). - Add
--topic-to-component-basis
global argument to all modes in order to map a coordinate basis to each component on plex construction (docs). - Changed-basis plex is now included in MetriCal output (docs).
- Add
Changed
- Init mode only looks through the first 100 observations to create the initial plex; this should greatly speed up Init mode for most datasets.
- All observations are now run through their respective detectors before image motion filtering occurs.
- The motion filter acts on the image detections themselves, not the entire image. This should improve the quality of the motion filter in busy, "noisy" datasets (docs).
- A user-specified root is now required to generate the URDF from a plex in Shape mode (docs).
- Reformulate IMU calibration approach:
- Remove unnecessary IMU initialization.
- Implement improvements to IMU optimization mathematics.
- Only one IMU bias is inferred during calibration instead of a wandering bias.
- Shape mode arguments now follow the order
metrical shape [mode] [arguments] [plex] [output]
(docs). license
andreport-path
arguments are now global arguments, and can be passed to any mode (docs).- Lower the minimum required points to fit a circle detector.
Fixed
- Init mode now properly handles differences in the seeded plex (passed through with
-p
) and the created plex. This has been a bug for longer than we care to admit; we're glad it's fixed (docs)! - Observations are no longer held in memory while motion filtering occurs. This greatly reduces memory usage on LiDAR-heavy datasets.
Removed
- Caching of detections and filtered output is no longer supported in Calibrate and Evaluate modes.
Version 10.0.0 (Yanked)
This release was yanked due to a critical bug introduced in Init mode that wasn't caught in time. The odds of many users running into this bug were low, but we played it safe and yanked this version entirely.
All relevant changes will be added to the changelog for 11.0.0.
Version 9.0.0
MetriCal Sensor Calibration Utilities repository for v9.0.0: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v9.0.0
Overview
Version 9.0.0 can be considered a refinement of v8.0, with focus on improving the user experience and clarifying outputs. It also introduces a few new intrinsics models across components. Some default behavior has changed as well, so be sure to check the changelog for details.
This release also includes a big update to rendering. Be sure to update your Rerun version to v0.14!
Changelog
Added
- Introduced
LidarSummary
summary statistics to report lidar-specific metrics (docs). - Support for new IMU intrinsics: Scale, Shear, Rotation, and G-Sensitivity (docs).
- Support for the Omnidirectional camera model (docs).
Changed
- MetriCal now uses Rerun v0.14! 🎊 Make sure to update your version of Rerun accordingly.
- The summary statistics table is now three tables, for optimization, cameras, and lidar respectively (docs).
PerComponentRMSE
in Summary Statistics is nowCameraSummary
(docs).- Circle detector's
detect_interior_points
option is now a mandatory variable, and has no default value (docs). - Circle detector now takes an
x_offset
andy_offset
variable to describe the center of the circle w.r.t. the full board frame (docs). - Object relative extrinsics (OREs) are now generated by default. In turn, the
--enable-ore-inference
flag has been removed and replaced with--disable-ore-inference
(docs). - The camera component initialization process during calibration has been improved to better handle significant distortion.
Fixed
- Rerun rendering code has been completely refactored for user clarity and speed of execution.
- Lidar-lidar datasets are now rendered and registered along with camera-lidar.
- Object relative extrinsics are now rendered when available.
- Images now use lookup tables properly for quick correction.
- Spaces have been reorganized for clarity and ease of use.
- Datasets without cameras no longer print empty camera tables.
Version 8.0.1
MetriCal Sensor Calibration Utilities repository for v8.0.1: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v8.0.1
Overview
This version fixes a small bug found in pipeline license validation.
Changelog
Fixed
null
license values in a pipeline configuration are discarded, not interpreted as a provided license key.
Version 8.0.0
MetriCal Sensor Calibration Utilities repository for v8.0.0: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v8.0.0
Overview
This release brings a ton of new features to the MetriCal CLI, most of them focused on improving the user experience. The biggest difference is one you won't see: all of the math done during optimization is now fully sparse, which means it takes a lot less memory to run a calibration. And smart convergence criteria means that calibrations are faster, too!
We've also added a new mode, pipeline
, which allows you to run a series of commands in serial.
Find out more about it in the Pipeline Mode section of the documentation.
Changelog
Added
- Pipeline mode. This executes a series of Commands in serial, as they're written in a pipeline JSON file.
- Render the optimized plex at the end of a calibration.
- The subplex ID for a spatial constraint now shows up in the Extrinsics table.
- Input JSON files with comments are now accepted as valid.
Changed
- All calibrations now undergo outlier detection and reweighting as part of the BA process. Outliers are detected for cameras, lidar, and relative extrinsics.
- Summary table is sorted by component name, not by UUID.
- Summary statistics in console are now computed using a weighted RMSE.
- The bundle adjustment is now a fully sparse operation, relieving memory pressure on larger datasets.
Fixed
- The height of the sync group chart now adjusts with the number of components present in the dataset.
- Bug in Init mode when using a RealSense435Imu preset.
- All stereo pairs are now derived and graphed in console output
Removed
- The
--metrics-with-outliers
flag and the--outlier-filter
flag have been removed.
Version 7.0.1
MetriCal Sensor Calibration Utilities for v7.0.1: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v7.0.1
Overview
This patch release fixes various errata found in the v7.0.0 release.
Changelog
Fixed
- Rendering the correction at the end of a calibration actually uses the corrected plex (rather than the input plex).
- The extrinsics table now only shows delta values if an input plex is provided.
- Camera-lidar extrinsics rendering in Rerun now takes the spatial constraint with the minimum covariance. This is different from the previous behavior where all spatial constraints were rendered, regardless of quality.
Version 7.0.0
MetriCal Sensor Calibration Utilities for v7.0.0: https://gitlab.com/tangram-vision/platform/metrical/-/releases/v7.0.0
Overview
Welcome, v7.0.0! Yes, merely a week after v6.0.0, we bump major versions. Classic.
Revised Documentation
It's finally here! The revised Tangram Vision documentation site is live: https://docs.tangramvision.com/.
This documentation site holds readmes and tutorials on all of Tangram Vision's products. The MetriCal section is fully-featured, and based on this release. We will be maintaining all documentation for this and newer versions on the official docs site from here on out.
LiDAR-LiDAR Calibration
MetriCal now supports LiDAR-LiDAR calibration, no cameras needed. Users will need a circular markerboard to calibrate LiDAR.
New Modes - pretty-print
and evaluate
v7.0.0 introduces two new modes:
- Pretty Print does what it says on the tin: prints the plex or results of a calibration in a human-readable format. This is useful for debugging and for getting a quick overview of the calibration. Docs: https://docs.tangramvision.com/metrical/modes/pretty_print/
- Evaluate can apply a calibration to a given dataset and produce metrics to validate the quality of the calibration. Docs: https://docs.tangramvision.com/metrical/modes/evaluate/.
The Calibrate mode, by extension, no longer has an --evaluate
flag. This is just Evaluate mode.
Revamped Rendering options + Deprecated Review mode
Review mode is no longer! Instead, passing the --render
flag to either Calibrate or Evaluate mode
will render the corrected calibration at the end of the run. Also, --render
and --render-socket
options are no longer global. Instead, they are only applicable for Calibrate and Evaluate modes.
Changelog
Added
- Support for calibrating multi-LiDAR, no-camera datasets. This still leverages MetriCal's circle target, but no longer requires a camera or any image topics to be present in order to calibrate.
- Pretty Print mode for printing out a plex in a human readable format.
- Evaluate mode to evaluate the quality of a calibration on a test dataset. This is a
reinterpretation of the
--evaluate
flag that was in the Calibrate mode; it's just been given its own command for ease of use. - A
verbose
flag to the shape mode to print the plex that has been created from the command. - Additional descriptions to errors that can be generated by calling the calibrate mode.
Changed
- Calibrate + Evaluate mode now renders its own corrections (rather than punting that capability to review).
- The
--render
flag at the global level has been moved to the Calibrate & Evaluate modes.
Removed
- Review mode and README mode have been removed completely. Review mode's previous functionality is now split between Pretty Print mode and Calibrate mode.
- The
--evaluate
flag in Calibrate mode.
Fixed
- Summary statistics tables now have the correct units displayed alongside their quantities.
- Printing the results of a plex with no extrinsics will now print an empty table, rather than nothing at all.
- Nominal extrinsics deltas in tables are now represented by the string "--".
Errata
- The "corrected" rendering at the end of a calibration run mistakenly uses the input plex, not the output plex. Scheduled fix: v7.0.1.
- The output extrinsics table does not correctly calculate the delta between the input and output plex. Scheduled fix: v7.0.1.
- Rendering the corrected camera-lidar registration would take the first spatial constraints available, rather than taking the constraint with the minimum covariance. This often makes calibrations appear wildly incorrect, despite a good calibration. Scheduled fix: v7.0.1.