This flashcard is just one of a free flashcard set. See all flashcards!
33
How to register two patches obtained by a laser scanner using the Iterative Closest Point algorithm?
Assumption: Scanned patches have identical scale.
Goal: Find a rigid transformation (rotation and translation) for one of the patches to align it with the other.
Algorithm Overview
1. Initial alignment: Provided by the user
2. Matching: Find corresponding points in the two patches
3. Registration: Compute optimal translation and rotation
4. Repeat from step 2 until convergence.
Matching
Matching Strategy: Nearest Neighbor
For every vertex
in patch
, select the nearest neighbor vertex
from patch
.
Filtering: Remove those matchings where one vertex is a boundary vertex (since boundary vertices match to many points). Remove matchings with a high distance. Remove matchings with a high normal deviation.
Matching Strategy: Normal Piercing
From each vertex
in patch
, shoot a ray into normal direction. If this ray intersects with
in point
, add the correspondence
.
Registration
Given a list of corresponding verticesdata:image/s3,"s3://crabby-images/f7cfd/f7cfd5123c1116492b906a6ffda569dee0520c95" alt=""
we want to find a transformation
such that
data:image/s3,"s3://crabby-images/04c1b/04c1b38f782d0b0cd17b5d8838dc849bfd7e3d1f" alt=""
Finding the translational part
just amounts to shifting the center of gravity of the
into that of the
by adding an offset
data:image/s3,"s3://crabby-images/432dc/432dc213be19ad9ef93da62ab6a7d6d7fbe59c77" alt=""
data:image/s3,"s3://crabby-images/df16d/df16d5953576da6803fa7640739c477786d35fe5" alt=""
We just assume this translational registration has already taken place and just focus on the rotational alignment:
data:image/s3,"s3://crabby-images/67a55/67a550c918693b2c31d4c427908357e41fabb3a1" alt=""
data:image/s3,"s3://crabby-images/133ab/133ab37591e455b853d2b59f833d3b732af0bed3" alt=""
data:image/s3,"s3://crabby-images/b5d1b/b5d1b1221cb250baf6c14624365aeb5afb25c304" alt=""
The first and last term are independent ofdata:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/76f4b/76f4b7e581e9014fae8f0c98246b4c62c04f3c51" alt=""
data:image/s3,"s3://crabby-images/0604b/0604b3d5b3c46bb820861eacb538c74d7c32803c" alt=""
Problem: Finding a solution for the rotation matrix
requires finding 9 unknowns (of which 6 need to be constrained). Solution: Formulate the rotation as a quaternion (gives 4 unknowns with 1 additional constraint).
data:image/s3,"s3://crabby-images/ac5aa/ac5aa14f60209347c0e3574a4ca2543a427f6820" alt=""
data:image/s3,"s3://crabby-images/21efb/21efb0eb9abe2203396a18558c1bfa95326c87bb" alt=""
data:image/s3,"s3://crabby-images/bf545/bf54547ca1fc8ee3c64ccbc38f74054265304cd6" alt=""
data:image/s3,"s3://crabby-images/41f60/41f60d3ababcf8a1026756084a6abd4d68819ce6" alt=""
data:image/s3,"s3://crabby-images/187eb/187eb31c522dc0bf7547d93f1c96576bf42d5513" alt=""
data:image/s3,"s3://crabby-images/01e6f/01e6f517000120d085f8ede79ba4d1bd22ad6c06" alt=""
data:image/s3,"s3://crabby-images/03576/035762aaeb8dce18ad60ab05891a56c01557aadd" alt=""
is a symmetric matrix. To compute a solution for
, find the eigenvector to the largest eigenvalue. Normalize to obtain a rotation.
Goal: Find a rigid transformation (rotation and translation) for one of the patches to align it with the other.
Algorithm Overview
1. Initial alignment: Provided by the user
2. Matching: Find corresponding points in the two patches
3. Registration: Compute optimal translation and rotation
4. Repeat from step 2 until convergence.
Matching
Matching Strategy: Nearest Neighbor
For every vertex
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Filtering: Remove those matchings where one vertex is a boundary vertex (since boundary vertices match to many points). Remove matchings with a high distance. Remove matchings with a high normal deviation.
Matching Strategy: Normal Piercing
From each vertex
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/45fdd/45fddaf0ed742478761dee70fe217257a753e8de" alt=""
Registration
Given a list of corresponding vertices
data:image/s3,"s3://crabby-images/f7cfd/f7cfd5123c1116492b906a6ffda569dee0520c95" alt=""
we want to find a transformation
data:image/s3,"s3://crabby-images/637aa/637aa2d12553a7b5899774b69524fc6ea3bed19b" alt=""
data:image/s3,"s3://crabby-images/04c1b/04c1b38f782d0b0cd17b5d8838dc849bfd7e3d1f" alt=""
Finding the translational part
data:image/s3,"s3://crabby-images/73b06/73b069566e78787071567fe04a6130b3e83ece68" alt=""
data:image/s3,"s3://crabby-images/fee80/fee801556efc62e71e539cf587130e6ad8563e7d" alt=""
data:image/s3,"s3://crabby-images/6f91a/6f91ae734d472f0c68f2ba46e8ef4e5b56691b92" alt=""
data:image/s3,"s3://crabby-images/432dc/432dc213be19ad9ef93da62ab6a7d6d7fbe59c77" alt=""
data:image/s3,"s3://crabby-images/df16d/df16d5953576da6803fa7640739c477786d35fe5" alt=""
We just assume this translational registration has already taken place and just focus on the rotational alignment:
data:image/s3,"s3://crabby-images/67a55/67a550c918693b2c31d4c427908357e41fabb3a1" alt=""
data:image/s3,"s3://crabby-images/133ab/133ab37591e455b853d2b59f833d3b732af0bed3" alt=""
data:image/s3,"s3://crabby-images/b5d1b/b5d1b1221cb250baf6c14624365aeb5afb25c304" alt=""
The first and last term are independent of
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/76f4b/76f4b7e581e9014fae8f0c98246b4c62c04f3c51" alt=""
data:image/s3,"s3://crabby-images/0604b/0604b3d5b3c46bb820861eacb538c74d7c32803c" alt=""
Problem: Finding a solution for the rotation matrix
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/ac5aa/ac5aa14f60209347c0e3574a4ca2543a427f6820" alt=""
data:image/s3,"s3://crabby-images/21efb/21efb0eb9abe2203396a18558c1bfa95326c87bb" alt=""
data:image/s3,"s3://crabby-images/bf545/bf54547ca1fc8ee3c64ccbc38f74054265304cd6" alt=""
data:image/s3,"s3://crabby-images/41f60/41f60d3ababcf8a1026756084a6abd4d68819ce6" alt=""
data:image/s3,"s3://crabby-images/187eb/187eb31c522dc0bf7547d93f1c96576bf42d5513" alt=""
data:image/s3,"s3://crabby-images/01e6f/01e6f517000120d085f8ede79ba4d1bd22ad6c06" alt=""
data:image/s3,"s3://crabby-images/03576/035762aaeb8dce18ad60ab05891a56c01557aadd" alt=""
data:image/s3,"s3://crabby-images/42838/42838fe78f291bc228f49733c8cc63dc2feca84f" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/c64c7/c64c7f61abb9e2d96a6c69beff1bd79eb8bfc4e8" alt=""
Flashcard info:
Author: janisborn
Main topic: Informatik
Topic: Computergrafik
School / Univ.: RWTH Aachen
City: Aachen
Published: 18.05.2022