三维重建10:点云配准和点云匹配

         点云的配准一般分为等价集合和律属集合两种配准,其中等价集合配准叫做匹配过程,律属集合配准被称为Alignment。

        点云的匹配一般使用ICP方法(  ICP:Iterative Closest Point迭代最近点),即两个点云纯粹通过刚体位姿变换即可大致重合,参考三维点集拟合:平面拟合、RANSAC、ICP算法。

        若找稠密/稀疏点的匹配关系,ICP算法即简化成一个最小二乘问题,可以通过解方程的方法得到解析解,使用优化方式迭代求解则一定可以得到全局最优解。若没有匹配关系,纯粹的迭代最近点方法也能得到一个极值结果,但不一定是最优的。

ICP的求解方法

         把ICP方法看做一个点云位姿变换的过程,可以使用代数方法和非线性优化方法。

          假设有两堆点云,分别记为两个集合X=x1,x2,...,xmY=y1,y2,...,ym(m并不总是等于n)。

           ICP公式为:

         

1.SVD等代数方法

         先构建误差矩阵,构建最小二乘问题,求使得误差平方和最小的点云旋转和位移R,T。

         初始化估计:ICP发展了多年之后,当然有很多的方法来估计初始的R和t,PCL自己的函数 SampleConsensusInitalAlignment 函数以及TransformationEstimationSVD函数 都可以得到较好的初始估计。

         优化:得到初始化估计之后仍然存在误差问题,RANSAC之后,若已存在完全正确匹配,则可以再次求取旋转的essential矩阵,通过SVD分解得到最终旋转R和平移t。


2.非线性优化方法

         RANSAC算法之后,去除掉 外点之后。

         使用位姿的代数变化转换构建一个误差项,在非线性优化过程中不停地迭代,一般能找到极小值。


3.PCL的ICP方法

code:

// A translation on Z axis (0.4 meters)
  transformation_matrix (2, 3) = 0.4;

  
// Executing the transformation
  pcl::transformPointCloud (*cloud_in, *cloud_icp, transformation_matrix);
  *cloud_tr = *cloud_icp;  // We backup cloud_icp into cloud_tr for later use

  // The Iterative Closest Point algorithm
  time.tic ();
  pcl::IterativeClosestPoint<PointT, PointT> icp;
  icp.setMaximumIterations (iterations);
  icp.setInputSource (cloud_icp);
  icp.setInputTarget (cloud_in);
  icp.align (*cloud_icp);
  icp.setMaximumIterations (1);  // We set this variable to 1 for the next time we will call .align () function
  std::cout << "Applied " << iterations << " ICP iteration(s) in " << time.toc () << " ms" << std::endl;

transformation_matrix = icp.getFinalTransformation ().cast<double>();


Alignment方法:

PCL链接:http://pointclouds.org/documentation/tutorials/template_alignment.php#template-alignment

        Alignment分特殊情况即目标单侧面匹配,即是确定可见面对应目标物体的位姿。此种方案有多种解决方法,可以划分到物体位姿识别的范畴,使用位姿识别的通用方法来完成Alignment。

        Alignment的通常情况是可见面是目标物体的一部分,并非单侧面全覆盖,同时对应了单侧面被遮挡的状况,此种平凡状态使用不同于位姿识别的简单方法。一般使用体素化降采样,先找到大致可能的位姿变换;再通过特征匹配的方法,使用RANSAC方法,找到可视子集的目标附属位置;而后使用ICP方法,进行再次精准配准。

PCL代码:

// ... and downsampling the point cloud
  const float voxel_grid_size = 0.005f;
  pcl::VoxelGrid<pcl::PointXYZ> vox_grid;
  vox_grid.setInputCloud (cloud);
  vox_grid.setLeafSize (voxel_grid_size, voxel_grid_size, voxel_grid_size);
  //vox_grid.filter (*cloud); // Please see this http://www.pcl-developers.org/Possible-problem-in-new-VoxelGrid-implementation-from-PCL-1-5-0-td5490361.html
  pcl::PointCloud<pcl::PointXYZ>::Ptr tempCloud (new pcl::PointCloud<pcl::PointXYZ>); 
  vox_grid.filter (*tempCloud);
  cloud = tempCloud; 

  // Assign to the target FeatureCloud
  FeatureCloud target_cloud;
  target_cloud.setInputCloud (cloud);

  // Set the TemplateAlignment inputs
  TemplateAlignment template_align;
  for (size_t i = 0; i < object_templates.size (); ++i)
  {
    template_align.addTemplateCloud (object_templates[i]);
  }
  template_align.setTargetCloud (target_cloud);

  // Find the best template alignment
  TemplateAlignment::Result best_alignment;
  int best_index = template_align.findBestAlignment (best_alignment);
  const FeatureCloud &best_template = object_templates[best_index];

  // Print the alignment fitness score (values less than 0.00002 are good)
  printf ("Best fitness score: %f\n", best_alignment.fitness_score);

  // Print the rotation matrix and translation vector
  Eigen::Matrix3f rotation = best_alignment.final_transformation.block<3,3>(0, 0);
  Eigen::Vector3f translation = best_alignment.final_transformation.block<3,1>(0, 3);

后记:

        在去除外点,匹配已知的情况下,ICP的最小二乘问题总会得到一个最优解,即ICP的SVD方法总会有一个解析解。


### 回答1: 点云数据融合是指将多个点云数据集合并成一个更大的点云数据。在MATLAB中,实现点云数据融合需要使用PointCloud Toolbox工具包。该工具包提供了许多用于点云处理和分析的函数。 在点云数据融合过程中,需要考虑以下几个方面: 1. 数据格式:不同的点云数据格式可能不同,需要将它们转换为同一格式才能进行融合。PointCloud Toolbox提供了许多函数用于加载和转换不同格式的点云数据。 2. 数据点的重合度:重合的数据点需要合并,否则会导致重复计算。可以使用voxelGridFilter函数对点云数据进行下采样,减少重复点的数量。 3. 坐标系的一致性:不同的点云数据可能使用不同的坐标系,需要将它们统一到同一坐标系下。可以使用pcmerge函数对点云进行融合并统一坐标系。 4. 融合算:不同的融合算会影响融合结果的精度和效率。PointCloud Toolbox支持多种点云数据融合算,例如Kd-tree、Octree等。 点云数据融合在机器人感知、自动驾驶、建筑测绘等领域中应用广泛。MATLAB的PointCloud Toolbox提供了丰富的函数和工具,可以帮助用户实现高效准确的点云数据融合。 ### 回答2: 点云数据融合是指将多个采集的点云数据集合并成一个点云,以提高点云数据的完整性和精度。Matlab作为一种强大的科学计算软件,可以通过其图像处理工具箱和计算机视觉工具箱实现点云数据融合。 Matlab中常用的点云融合方包括:基于ICP(Iterative Closest Point)的点云配准、基于轮廓的点云匹配和基于光流的点云融合等。 ICP方是一种常用的点云配准,它通过不断优化点云之间的对应关系,最终获得高精度的点云配准结果。在Matlab中可以使用pcmerge函数实现点云的融合,该函数可以利用ICP算实现点云的自动配准和融合。 基于轮廓的点云匹配是利用点云的投影信息进行匹配的一种方。Matlab中可以通过将点云转化为二维的轮廓图像,然后使用图像处理工具箱中的函数进行轮廓匹配,最终实现点云的融合。 基于光流的点云融合方是利用点云之间的运动关系进行匹配的一种方。在Matlab中可以使用opticalFlow函数计算点云之间的光流场,然后利用该光流场进行点云匹配和融合。 总之,利用Matlab可以方便地实现点云数据的融合,提高点云数据的精度和完整性。 ### 回答3: MATLAB是一种常用的数据处理和分析工具,可以用于点云数据融合。点云数据指的是由3D扫描设备获取的点云模型,每个点包含x、y、z三个坐标值和对应的颜色信息。点云融合指的是将多个点云模型合并为一个更完整的模型。 在MATLAB中,可以使用点云处理工具箱(PointCloudProcessing Toolbox)来处理点云数据。首先,需要将多个点云数据导入到MATLAB中,并对其进行预处理,确保它们的坐标系统一致。这可以通过使用点云处理函数(如pcmerge)来实现。 接下来,可以使用点云配准(point cloud registration)算将多个点云数据配准到同一坐标系中。一般来说,这需要计算每个点云之间的变换矩阵,并将其应用于每个点云中的所有点。配准可以使用MATLAB中的点云配准工具箱(Point Cloud Registration Toolbox)来实现。 最后,可以使用点云合并算将多个配准后的点云数据合并为一个更完整的点云模型。这可以使用MATLAB中的点云处理函数(如pcmerge)来实现。 总之,MATLAB是一个强大的点云数据处理工具,可以用于点云数据的融合和处理。通过使用点云处理工具箱和点云配准工具箱,可以将多个点云数据合并为一个更完整的模型,进一步实现对点云数据的分析和应用。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值