Next: ICP-based 6D SLAM
Up: Range Image Registration and
Previous: Range Image Registration and
In every iteration the optimal tranformation (
,
)
has to be computed. Eq. (
) can be reduced to
with
, since the
correspondence matix can be represented by a vector containing
the point pairs.
Four methods are known to minimize eq. (
)
[17]. In earlier work [20,27] we
used a quaternion based method [7], but the
following one, based on singular value decomposition (SVD), is
robust and easy to implement, thus we give a brief overview of
the SVD-based algorithms. It was first published by Arun, Huang
and Blostein [2]. The difficulty of this
minimization problem is to enforce the orthonormality of matrix
. The first step of the computation is to decouple the
calculation of the rotation
from the translation
using the centroids of the points belonging to the matching,
i.e.,
data:image/s3,"s3://crabby-images/e789e/e789ee06aad38d8e9f615159adea728ecff14c13" alt="$\displaystyle \V c_m = \frac{1}{N} \sum_{i=1}^{N} \V m_{i}, \qquad \qquad \V c_d = \frac{1}{N}
\sum_{i=1}^{N} \V d_{j}$" |
|
|
(3) |
and
data:image/s3,"s3://crabby-images/0708e/0708e95d9eae499b1f034e2e1131936c1fb47cfb" alt="$\displaystyle M'$" |
data:image/s3,"s3://crabby-images/1ed42/1ed42579af84867e48646fb1d3c1c259753c445d" alt="$\displaystyle =$" |
|
(4) |
data:image/s3,"s3://crabby-images/4eae9/4eae9b13eed876c78932e3279700a156ff39dccf" alt="$\displaystyle end{tex2html_deferred}{ \V m'_{i} = \V m_{i} - \V c_{m} $" |
|
|
(5) |
data:image/s3,"s3://crabby-images/7700c/7700c96d2e187707b88e1a44e997dc93889f7c05" alt="$\displaystyle end{tex2html_deferred}}_{1,\ldots,N},$" |
|
|
(6) |
data:image/s3,"s3://crabby-images/0349f/0349f00b3f396876bdc05c884dcdd60722a4d190" alt="$\displaystyle end{tex2html_deferred}$" |
|
|
(7) |
data:image/s3,"s3://crabby-images/2c5cd/2c5cdbabfaa00f2068baf4124de57afd56401a37" alt="$\displaystyle end{tex2html_deferred}
\qquad
D'$" |
data:image/s3,"s3://crabby-images/1ed42/1ed42579af84867e48646fb1d3c1c259753c445d" alt="$\displaystyle =$" |
|
(8) |
data:image/s3,"s3://crabby-images/9cb7b/9cb7bc7ce70322748184ca657ae151a587126815" alt="$\displaystyle end{tex2html_deferred}{ \V d'_{i}$" |
|
|
(9) |
data:image/s3,"s3://crabby-images/4b243/4b243f98131742af034035859c4bed3b1af180c4" alt="$\displaystyle end{tex2html_deferred}= \V d_{i}$" |
|
|
(10) |
data:image/s3,"s3://crabby-images/b700c/b700cc8d39b4b464519efb60b8ecd57e72e922bd" alt="$\displaystyle end{tex2html_deferred}, - \V c_{d} $" |
|
|
(11) |
data:image/s3,"s3://crabby-images/907b7/907b79c75da75a4623826edd60dda5d9480bdb9c" alt="$\displaystyle end{tex2html_deferred}}_{1,\ldots,N}.$" |
|
|
(12) |
After replacing (
), (
) and
(
) in the error function,
eq. (
) becomes:
In order to minimize the sum above, all terms have to be
minimized. The second sum (
) is zero, since all
values refer to centroid. The third part (
) has
its minimum for
or
data:image/s3,"s3://crabby-images/09ea4/09ea4253cd366c4c527083a63a58e3baf18bf671" alt="$\displaystyle \V t = \V c_m - \M R \V c_d.$" |
|
|
(14) |
Therefore the algorithm has to minimize only the first
term, and the error function is expressed in terms of the
rotation only:
data:image/s3,"s3://crabby-images/133c0/133c0b19054808a442cfe5fc26857c45dadb9372" alt="$\displaystyle E(\M R, \V t) \propto
\sum_{i=1}^{N}\norm {\V m'_{i}-\M R \V d'_i}^2.$" |
|
|
(15) |
Theorem: The optimal rotation is calculated
by
. Herby the matrices
and
are
derived by the singular value decomposition
of a correlation matrix
. This
matrix
is given by
data:image/s3,"s3://crabby-images/d8773/d87732a910cadaae4c76bccedf065191aff3670b" alt="\begin{displaymath}\M H = \sum_{i=1}^{N} \V m'^T_i \V d'_i
= \left(
\begin{array...
...} & S_{yz} \\
S_{zx} & S_{zy} & S_{zz} \\
\end{array}\right),\end{displaymath}" |
|
|
(16) |
with
. The analogous
algorithm is derived directly from this theorem.
Proof: Since rotation is length preserving, i.e.,
the error function (
) is expanded
The rotation affects only the middle term, thus it is sufficient
to maximize
Using the trace of a matrix, (
) can be rewritten to
obtain
With
defined as in (
). Now we have
to find the matrix
that maximizes
.
Assume that the singular value decomposition of
is
with
and
orthonormal
matrices and
a
diagonal matrix without negative
elements. Suppose
is orthonormal and
is a symmetric, positive definite matrix. Arun, Huang and
Blostein provide a lemma to show that
for any orthonormal matrix
. Therefore the matrix
is
optimal. Prooving the lemma is straightforward using the
Cauchy-Schwarz [2]. Finally, the
optimal translation is calculated as (cf. eq. (
)
and (
))
Next: ICP-based 6D SLAM
Up: Range Image Registration and
Previous: Range Image Registration and
root
2005-05-03