44 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) {}
92 : transformation_(transformation), inlier_rmse_(0.0), fitness_(0.0) {}
126 double max_correspondence_distance,
151 const double max_correspondence_distance,
157 const double voxel_size = -1.0,
158 const std::function<
void(
const std::unordered_map<std::string, core::Tensor>
159 &)> &callback_after_iteration =
nullptr);
189 const std::vector<double> &voxel_sizes,
190 const std::vector<ICPConvergenceCriteria> &criteria_list,
191 const std::vector<double> &max_correspondence_distances,
197 void(
const std::unordered_map<std::string, core::Tensor> &)>
198 &callback_after_iteration =
nullptr);
212 const double max_correspondence_distance,
core::Tensor GetInformationMatrix(const geometry::PointCloud &source, const geometry::PointCloud &target, const double max_correspondence_distance, const core::Tensor &transformation)
Computes Information Matrix, from the transformation between source and target pointcloud. It returns the Information Matrix of shape {6, 6}, of dtype Float64 on device CPU:0.
Definition: Registration.cpp:414
int max_iteration_
Maximum iteration before iteration stops.
Definition: Registration.h:78
double relative_fitness_
Definition: Registration.h:73
Class that defines the convergence criteria of ICP.
Definition: Registration.h:50
core::Tensor transformation_
The estimated transformation matrix of dtype Float64 on CPU device.
Definition: Registration.h:103
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:111
double fitness_
Definition: Registration.h:112
ICPConvergenceCriteria(double relative_fitness=1e-6, double relative_rmse=1e-6, int max_iteration=30)
Parameterized Constructor. ICP algorithm stops if the relative change of fitness and rmse hit relativ...
Definition: Registration.h:62
RegistrationResult MultiScaleICP(const geometry::PointCloud &source, const geometry::PointCloud &target, const std::vector< double > &voxel_sizes, const std::vector< ICPConvergenceCriteria > &criterias, const std::vector< double > &max_correspondence_distances, const core::Tensor &init_source_to_target, const TransformationEstimation &estimation, const std::function< void(const std::unordered_map< std::string, core::Tensor > &)> &callback_after_iteration)
Functions for Multi-Scale ICP registration. It will run ICP on different voxel level, from coarse to dense. The vector of ICPConvergenceCriteria(relative fitness, relative rmse, max_iterations) contains the stopping condition for each voxel level. The length of voxel_sizes vector, criteria vector, max_correspondence_distances vector must be same, and voxel_sizes must contain positive values in strictly decreasing order [Lower the voxel size, higher is the resolution]. Only the last value of the voxel_sizes vector can be {-1}, as it allows to run on the original scale without downsampling.
Definition: Registration.cpp:335
double inlier_rmse_
RMSE of all inlier correspondences. Lower is better.
Definition: Registration.h:109
A point cloud contains a list of 3D points.
Definition: PointCloud.h:99
bool IsBetterThan(const RegistrationResult &other) const
Definition: Registration.h:96
Definition: PinholeCameraIntrinsic.cpp:35
core::Tensor correspondences_
Definition: Registration.h:107
RegistrationResult(const core::Tensor &transformation=core::Tensor::Eye(4, core::Float64, core::Device("CPU:0")))
Parameterized Constructor.
Definition: Registration.h:90
~RegistrationResult()
Definition: Registration.h:94
~ICPConvergenceCriteria()
Definition: Registration.h:68
double relative_rmse_
Definition: Registration.h:76
const Dtype Float64
Definition: Dtype.cpp:62
static Tensor Eye(int64_t n, Dtype dtype, const Device &device)
Create an identity matrix of size n x n.
Definition: Tensor.cpp:404
RegistrationResult ICP(const geometry::PointCloud &source, const geometry::PointCloud &target, const double max_correspondence_distance, const core::Tensor &init_source_to_target, const TransformationEstimation &estimation, const ICPConvergenceCriteria &criteria, const double voxel_size, const std::function< void(const std::unordered_map< std::string, core::Tensor > &)> &callback_after_iteration)
Functions for ICP registration.
Definition: Registration.cpp:113
Definition: Registration.h:84