Point Cloud Library (PCL)
1.15.1
Toggle main menu visibility
Loading...
Searching...
No Matches
pcl
registration
impl
default_convergence_criteria.hpp
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Point Cloud Library (PCL) - www.pointclouds.org
5
* Copyright (c) 2012-, Open Perception, Inc.
6
*
7
* All rights reserved.
8
*
9
* Redistribution and use in source and binary forms, with or without
10
* modification, are permitted provided that the following conditions
11
* are met:
12
*
13
* * Redistributions of source code must retain the above copyright
14
* notice, this list of conditions and the following disclaimer.
15
* * Redistributions in binary form must reproduce the above
16
* copyright notice, this list of conditions and the following
17
* disclaimer in the documentation and/or other materials provided
18
* with the distribution.
19
* * Neither the name of the copyright holder(s) nor the names of its
20
* contributors may be used to endorse or promote products derived
21
* from this software without specific prior written permission.
22
*
23
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
29
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
33
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34
* POSSIBILITY OF SUCH DAMAGE.
35
*
36
* $Id$
37
*
38
*/
39
40
#ifndef PCL_REGISTRATION_DEFAULT_CONVERGENCE_CRITERIA_HPP_
41
#define PCL_REGISTRATION_DEFAULT_CONVERGENCE_CRITERIA_HPP_
42
43
#include <pcl/console/print.h>
44
45
namespace
pcl
{
46
47
namespace
registration
{
48
49
template
<
typename
Scalar>
50
bool
51
DefaultConvergenceCriteria<Scalar>::hasConverged
()
52
{
53
if
(
convergence_state_
!=
CONVERGENCE_CRITERIA_NOT_CONVERGED
) {
54
// If it already converged or failed before, reset.
55
iterations_similar_transforms_
= 0;
56
convergence_state_
=
CONVERGENCE_CRITERIA_NOT_CONVERGED
;
57
}
58
59
bool
is_similar =
false
;
60
61
PCL_DEBUG(
"[pcl::DefaultConvergenceCriteria::hasConverged] Iteration %d out of %d.\n"
,
62
iterations_
,
63
max_iterations_
);
64
// 1. Number of iterations has reached the maximum user imposed number of iterations
65
if
(
iterations_
>=
max_iterations_
) {
66
if
(!
failure_after_max_iter_
) {
67
convergence_state_
=
CONVERGENCE_CRITERIA_ITERATIONS
;
68
return
(
true
);
69
}
70
convergence_state_
=
CONVERGENCE_CRITERIA_FAILURE_AFTER_MAX_ITERATIONS
;
71
}
72
73
// 2. The epsilon (difference) between the previous transformation and the current
74
// estimated transformation
75
double
cos_angle = 0.5 * (
transformation_
.coeff(0, 0) +
transformation_
.coeff(1, 1) +
76
transformation_
.coeff(2, 2) - 1);
77
double
translation_sqr =
transformation_
.coeff(0, 3) *
transformation_
.coeff(0, 3) +
78
transformation_
.coeff(1, 3) *
transformation_
.coeff(1, 3) +
79
transformation_
.coeff(2, 3) *
transformation_
.coeff(2, 3);
80
PCL_DEBUG(
"[pcl::DefaultConvergenceCriteria::hasConverged] Current transformation "
81
"gave %f rotation (cosine) and %f translation.\n"
,
82
cos_angle,
83
translation_sqr);
84
85
if
(cos_angle >=
rotation_threshold_
&& translation_sqr <=
translation_threshold_
) {
86
if
(
iterations_similar_transforms_
>=
max_iterations_similar_transforms_
) {
87
convergence_state_
=
CONVERGENCE_CRITERIA_TRANSFORM
;
88
return
(
true
);
89
}
90
is_similar =
true
;
91
}
92
93
correspondences_cur_mse_
=
calculateMSE
(
correspondences_
);
94
if
(std::numeric_limits<double>::max() ==
correspondences_prev_mse_
) {
95
PCL_DEBUG(
"[pcl::DefaultConvergenceCriteria::hasConverged] Previous / Current MSE "
96
"for correspondences distances is: INIT / %f.\n"
,
97
correspondences_cur_mse_
);
98
}
99
else
{
100
PCL_DEBUG(
"[pcl::DefaultConvergenceCriteria::hasConverged] Previous / Current MSE "
101
"for correspondences distances is: %f / %f.\n"
,
102
correspondences_prev_mse_
,
103
correspondences_cur_mse_
);
104
}
105
106
// 3. The relative sum of Euclidean squared errors is smaller than a user defined
107
// threshold Absolute
108
if
(std::abs(
correspondences_cur_mse_
-
correspondences_prev_mse_
) <
109
mse_threshold_absolute_
) {
110
if
(
iterations_similar_transforms_
>=
max_iterations_similar_transforms_
) {
111
convergence_state_
=
CONVERGENCE_CRITERIA_ABS_MSE
;
112
return
(
true
);
113
}
114
is_similar =
true
;
115
}
116
117
// Relative
118
if
(std::abs(
correspondences_cur_mse_
-
correspondences_prev_mse_
) /
119
correspondences_prev_mse_
<
120
mse_threshold_relative_
) {
121
if
(
iterations_similar_transforms_
>=
max_iterations_similar_transforms_
) {
122
convergence_state_
=
CONVERGENCE_CRITERIA_REL_MSE
;
123
return
(
true
);
124
}
125
is_similar =
true
;
126
}
127
128
if
(is_similar) {
129
// Increment the number of transforms that the thresholds are allowed to be similar
130
++
iterations_similar_transforms_
;
131
}
132
else
{
133
// When the transform becomes large, reset.
134
iterations_similar_transforms_
= 0;
135
}
136
137
correspondences_prev_mse_
=
correspondences_cur_mse_
;
138
139
return
(
false
);
140
}
141
142
}
// namespace registration
143
}
// namespace pcl
144
145
#endif
// PCL_REGISTRATION_DEFAULT_CONVERGENCE_CRITERIA_HPP_
pcl::registration::DefaultConvergenceCriteria::convergence_state_
ConvergenceState convergence_state_
The state of the convergence (e.g., why did the registration converge).
Definition
default_convergence_criteria.h:321
pcl::registration::DefaultConvergenceCriteria::iterations_similar_transforms_
int iterations_similar_transforms_
Internal counter for the number of iterations that the internal rotation, translation,...
Definition
default_convergence_criteria.h:314
pcl::registration::DefaultConvergenceCriteria::correspondences_cur_mse_
double correspondences_cur_mse_
The MSE for the current set of correspondences.
Definition
default_convergence_criteria.h:286
pcl::registration::DefaultConvergenceCriteria::transformation_
const Matrix4 & transformation_
The current transformation obtained by the transformation estimation method.
Definition
default_convergence_criteria.h:276
pcl::registration::DefaultConvergenceCriteria::correspondences_
const pcl::Correspondences & correspondences_
The current set of point correspondences between the source and the target.
Definition
default_convergence_criteria.h:280
pcl::registration::DefaultConvergenceCriteria::iterations_
const int & iterations_
The number of iterations done by the registration loop so far.
Definition
default_convergence_criteria.h:272
pcl::registration::DefaultConvergenceCriteria::max_iterations_
int max_iterations_
The maximum nuyyGmber of iterations that the registration loop is to be executed.
Definition
default_convergence_criteria.h:290
pcl::registration::DefaultConvergenceCriteria::translation_threshold_
double translation_threshold_
The translation threshold is the relative translation between two iterations (0 if no translation).
Definition
default_convergence_criteria.h:302
pcl::registration::DefaultConvergenceCriteria::mse_threshold_absolute_
double mse_threshold_absolute_
The absolute change from the previous MSE for the current set of correspondences.
Definition
default_convergence_criteria.h:310
pcl::registration::DefaultConvergenceCriteria::hasConverged
bool hasConverged() override
Check if convergence has been reached.
Definition
default_convergence_criteria.hpp:51
pcl::registration::DefaultConvergenceCriteria::calculateMSE
double calculateMSE(const pcl::Correspondences &correspondences) const
Calculate the mean squared error (MSE) of the distance for a given set of correspondences.
Definition
default_convergence_criteria.h:262
pcl::registration::DefaultConvergenceCriteria::failure_after_max_iter_
bool failure_after_max_iter_
Specifys if the registration fails or converges when the maximum number of iterations is reached.
Definition
default_convergence_criteria.h:294
pcl::registration::DefaultConvergenceCriteria::rotation_threshold_
double rotation_threshold_
The rotation threshold is the relative rotation between two iterations (as angle cosine).
Definition
default_convergence_criteria.h:298
pcl::registration::DefaultConvergenceCriteria::mse_threshold_relative_
double mse_threshold_relative_
The relative change from the previous MSE for the current set of correspondences, e....
Definition
default_convergence_criteria.h:306
pcl::registration::DefaultConvergenceCriteria::correspondences_prev_mse_
double correspondences_prev_mse_
The MSE for the previous set of correspondences.
Definition
default_convergence_criteria.h:283
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_TRANSFORM
@ CONVERGENCE_CRITERIA_TRANSFORM
Definition
default_convergence_criteria.h:75
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_ITERATIONS
@ CONVERGENCE_CRITERIA_ITERATIONS
Definition
default_convergence_criteria.h:74
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_ABS_MSE
@ CONVERGENCE_CRITERIA_ABS_MSE
Definition
default_convergence_criteria.h:76
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_FAILURE_AFTER_MAX_ITERATIONS
@ CONVERGENCE_CRITERIA_FAILURE_AFTER_MAX_ITERATIONS
Definition
default_convergence_criteria.h:79
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_REL_MSE
@ CONVERGENCE_CRITERIA_REL_MSE
Definition
default_convergence_criteria.h:77
pcl::registration::DefaultConvergenceCriteria::CONVERGENCE_CRITERIA_NOT_CONVERGED
@ CONVERGENCE_CRITERIA_NOT_CONVERGED
Definition
default_convergence_criteria.h:73
pcl::registration::DefaultConvergenceCriteria::max_iterations_similar_transforms_
int max_iterations_similar_transforms_
The maximum number of iterations that the internal rotation, translation, and MSE differences are all...
Definition
default_convergence_criteria.h:318
pcl::registration
Definition
convergence_criteria.h:46
pcl
Definition
convolution.h:46