diff --git a/docs/cspell.json b/docs/cspell.json index 1816892358b9..3465c3698d48 100644 --- a/docs/cspell.json +++ b/docs/cspell.json @@ -85,6 +85,8 @@ "debuginfo", "dedup", "depgraph", + "deskewed", + "deskewing", "devel", "Dhariwal", "dicom", @@ -222,6 +224,7 @@ "nans", "nbconvert", "ncipollo", + "NCLT", "ndarray", "Niantic", "Nichol", @@ -336,6 +339,7 @@ "Struct", "structs", "subdir", + "subsampled", "superquadrics", "tableofcontents", "taplo", @@ -379,6 +383,7 @@ "Viktor", "virtualenv", "visualizability", + "Vizzo", "vstack", "vsuryamurthy", "vulkan", diff --git a/examples/cpp/kiss-icp/README.md b/examples/cpp/kiss-icp/README.md new file mode 100644 index 000000000000..1a425669655e --- /dev/null +++ b/examples/cpp/kiss-icp/README.md @@ -0,0 +1,42 @@ + + +Estimating the odometry is a common problem in robotics and in the [2023, "KISS-ICP: In Defense of Point-to-Point ICP -- Simple, Accurate, and Robust Registration If Done the Right Way" Ignacio Vizzo et al.](https://arxiv.org/abs/2209.15397) they show how one can use an ICP (iterative closest point) algorithm to robustly and accurately estimate poses from LiDAR data. We will demonstrate the KISS-ICP pipeline on the [NCLT dataset](http://robots.engin.umich.edu/nclt/) along with some brief explanations, for a more detailed explanation you should look at the [original paper](https://arxiv.org/abs/2209.15397). + + + + + + + + + +The KISS-ICP odometry pipeline consists of 4 steps. The first step is to compensate for movement of the vehicle during the LiDAR scan which is commonly called deskewing. This is done by creating an estimate of the rotational and translational velocity from previous pose estimates, then calculate the corrected scan under the assumption that the velocity is constant. In the screenshot below the raw scan is shown as green and the corrected scan is shown as the blue. + + + + + + + + + +The second step is to subsample the deskewed point cloud at two different resolutions. The first subsample with the highest resolution iis used to update the map after the pose has been estimated. The second is a subsample of the first subsample but with a lower resolution, this subsample is used during the ICP registration step. In the screenshot below the first subsample is colored pink and the second subsample is colored purple. + + + + + + + + + +The third step is to compute the adaptive threshold which will impose a limit on the distance between correspondences during the ICP. This is done using previously estimated poses to compute a likely limit of the displacement. The final step is to estimate the current pose by doing Point-to-Point ICP. This involves comparing each point in the subsampled scan with the closest point in the constructed map and making incremental updates to the estimated odometry based on these correspondences. + +https://vimeo.com/923395317?autoplay=1&loop=1&autopause=0&background=1&muted=1&ratio=1920:1080 diff --git a/examples/manifest.toml b/examples/manifest.toml index 8638e49769b0..9b812df17728 100644 --- a/examples/manifest.toml +++ b/examples/manifest.toml @@ -76,6 +76,7 @@ examples = [ "tapir", "widebaseline", "arflow", + "kiss-icp", ] [categories.setup] diff --git a/examples/python/kiss-icp/README.md b/examples/python/kiss-icp/README.md new file mode 100644 index 000000000000..1a425669655e --- /dev/null +++ b/examples/python/kiss-icp/README.md @@ -0,0 +1,42 @@ + + +Estimating the odometry is a common problem in robotics and in the [2023, "KISS-ICP: In Defense of Point-to-Point ICP -- Simple, Accurate, and Robust Registration If Done the Right Way" Ignacio Vizzo et al.](https://arxiv.org/abs/2209.15397) they show how one can use an ICP (iterative closest point) algorithm to robustly and accurately estimate poses from LiDAR data. We will demonstrate the KISS-ICP pipeline on the [NCLT dataset](http://robots.engin.umich.edu/nclt/) along with some brief explanations, for a more detailed explanation you should look at the [original paper](https://arxiv.org/abs/2209.15397). + + + + + + + + + +The KISS-ICP odometry pipeline consists of 4 steps. The first step is to compensate for movement of the vehicle during the LiDAR scan which is commonly called deskewing. This is done by creating an estimate of the rotational and translational velocity from previous pose estimates, then calculate the corrected scan under the assumption that the velocity is constant. In the screenshot below the raw scan is shown as green and the corrected scan is shown as the blue. + + + + + + + + + +The second step is to subsample the deskewed point cloud at two different resolutions. The first subsample with the highest resolution iis used to update the map after the pose has been estimated. The second is a subsample of the first subsample but with a lower resolution, this subsample is used during the ICP registration step. In the screenshot below the first subsample is colored pink and the second subsample is colored purple. + + + + + + + + + +The third step is to compute the adaptive threshold which will impose a limit on the distance between correspondences during the ICP. This is done using previously estimated poses to compute a likely limit of the displacement. The final step is to estimate the current pose by doing Point-to-Point ICP. This involves comparing each point in the subsampled scan with the closest point in the constructed map and making incremental updates to the estimated odometry based on these correspondences. + +https://vimeo.com/923395317?autoplay=1&loop=1&autopause=0&background=1&muted=1&ratio=1920:1080