43 namespace registration {
63 double relative_rmse = 1e-6,
64 int max_iteration = 30)
65 : relative_fitness_(relative_fitness),
66 relative_rmse_(relative_rmse),
67 max_iteration_(max_iteration) {}
98 int max_validation = 1000)
99 : max_iteration_(max_iteration), max_validation_(max_validation) {}
118 const Eigen::Matrix4d &transformation = Eigen::Matrix4d::Identity())
119 : transformation_(transformation), inlier_rmse_(0.0), fitness_(0.0) {}
145 double max_correspondence_distance,
146 const Eigen::Matrix4d &transformation = Eigen::Matrix4d::Identity());
161 double max_correspondence_distance,
162 const Eigen::Matrix4d &init = Eigen::Matrix4d::Identity(),
182 double max_correspondence_distance,
203 double max_correspondence_distance,
207 const std::vector<std::reference_wrapper<const CorrespondenceChecker>>
220 double max_correspondence_distance,
221 const Eigen::Matrix4d &transformation);
double inlier_rmse_
RMSE of all inlier correspondences. Lower is better.
Definition: Registration.h:128
int max_validation_
Maximum times the validation has been run before the iteration stops.
Definition: Registration.h:106
RegistrationResult RegistrationICP(const geometry::PointCloud &source, const geometry::PointCloud &target, double max_correspondence_distance, const Eigen::Matrix4d &init, const TransformationEstimation &estimation, const ICPConvergenceCriteria &criteria)
Functions for ICP registration.
Definition: Registration.cpp:148
int max_iteration_
Maximum iteration before iteration stops.
Definition: Registration.h:104
Eigen::Matrix6d GetInformationMatrixFromPointClouds(const geometry::PointCloud &source, const geometry::PointCloud &target, double max_correspondence_distance, const Eigen::Matrix4d &transformation)
Definition: Registration.cpp:369
RegistrationResult EvaluateRegistration(const geometry::PointCloud &source, const geometry::PointCloud &target, double max_correspondence_distance, const Eigen::Matrix4d &transformation)
Function for evaluating registration between point clouds.
Definition: Registration.cpp:132
std::vector< Eigen::Vector2i > CorrespondenceSet
Definition: TransformationEstimation.h:42
RegistrationResult RegistrationRANSACBasedOnCorrespondence(const geometry::PointCloud &source, const geometry::PointCloud &target, const CorrespondenceSet &corres, double max_correspondence_distance, const TransformationEstimation &estimation, int ransac_n, const RANSACConvergenceCriteria &criteria)
Function for global RANSAC registration based on a given set of correspondences.
Definition: Registration.cpp:202
A point cloud consists of point coordinates, and optionally point colors and point normals...
Definition: PointCloud.h:54
CorrespondenceSet correspondence_set_
Correspondence set between source and target point cloud.
Definition: Registration.h:126
~ICPConvergenceCriteria()
Definition: Registration.h:68
RegistrationResult RegistrationRANSACBasedOnFeatureMatching(const geometry::PointCloud &source, const geometry::PointCloud &target, const Feature &source_feature, const Feature &target_feature, double max_correspondence_distance, const TransformationEstimation &estimation, int ransac_n, const std::vector< std::reference_wrapper< const CorrespondenceChecker >> &checkers, const RANSACConvergenceCriteria &criteria)
Function for global RANSAC registration based on feature matching.
Definition: Registration.cpp:245
~RegistrationResult()
Definition: Registration.h:120
Definition: Registration.h:112
RegistrationResult(const Eigen::Matrix4d &transformation=Eigen::Matrix4d::Identity())
Parameterized Constructor.
Definition: Registration.h:117
Class that defines the convergence criteria of RANSAC.
Definition: Registration.h:90
Definition: Open3DViewer.h:29
double fitness_
Definition: Registration.h:131
double relative_rmse_
Definition: Registration.h:76
Eigen::Matrix4d_u transformation_
The estimated transformation matrix.
Definition: Registration.h:124
ICPConvergenceCriteria(double relative_fitness=1e-6, double relative_rmse=1e-6, int max_iteration=30)
Parameterized Constructor.
Definition: Registration.h:62
RANSACConvergenceCriteria(int max_iteration=1000, int max_validation=1000)
Parameterized Constructor.
Definition: Registration.h:97
~RANSACConvergenceCriteria()
Definition: Registration.h:100
Eigen::Matrix< double, 4, 4, Eigen::DontAlign > Matrix4d_u
Definition: Eigen.h:43
double relative_fitness_
Definition: Registration.h:73
int max_iteration_
Maximum iteration before iteration stops.
Definition: Registration.h:78
Class to store featrues for registration.
Definition: Feature.h:46
Class that defines the convergence criteria of ICP.
Definition: Registration.h:53
Eigen::Matrix< double, 6, 6 > Matrix6d
Extending Eigen namespace by adding frequently used matrix type.
Definition: Eigen.h:37