【点云上采样】基于移动最小二乘(MLS)的上采样

一、声明

  • 本帖持续更新,如有问题,望指正!

二、简介

基于MLS(Moving Least Squares)的上采样是一种常用的点云处理方法,用于增加稀疏点云数据的密度和细节。MLS上采样通过对点云进行局部拟合,并使用拟合结果生成新的点,从而实现点云的平滑和细节恢复。

MLS上采样的工作流程如下:

  1. 针对每一个待上采样的点,选择其邻域内的一组最近邻点。
  2. 对于选定的邻域点集,通过拟合一个平滑的曲面来逼近这些点。常用的拟合方法包括欧式最小二乘法(OLS)和加权最小二乘法(WLS)。
  3. 根据拟合结果,生成新的采样点。通常是在拟合曲面上均匀采样一定数量的点。
  4. 重复以上步骤,直到所有待上采样的点都得到处理。

MLS上采样的结果具有以下特点:

  • 增加点云的密度:通过生成额外的采样点,将原始稀疏点云的密度增加到更高的水平。
  • 平滑点云的表面:由于对每个点进行了局部曲面拟合,MLS上采样可以实现平滑点云的表面,减少形状的噪声和不规则性。
  • 恢复细节:通过在拟合曲面上均匀采样新的点,MLS上采样可以恢复原始点云中的细节信息。

下图所示是使用PCL实现的基于MLS上采样的结果图。

(a)原始点云(b)PCL中基于MLS上采样结果

三、代码

// Create a KD-Tree
pcl::search::KdTree<PointType>::Ptr tree(new pcl::search::KdTree<PointType>);

// Init object (second point type is for the normals, even if unused)
pcl::MovingLeastSquares<PointType, PointType> mls;
mls.setComputeNormals (true);

// Set parameters
mls.setInputCloud(cp_.cloud_);
mls.setPolynomialOrder(3);
mls.setSearchMethod(tree);
mls.setSearchRadius(0.005); // r1

//Upsampling 采样的方法还有 DISTINCT_CLOUD, RANDOM_UNIFORM_DENSITY
mls.setUpsamplingMethod(pcl::MovingLeastSquares<PointType, PointType>::SAMPLE_LOCAL_PLANE); //对点云进行上采样
mls.setUpsamplingRadius(0.002);    // r2
mls.setUpsamplingStepSize(0.0001);  // r3
mls.process(*ocloud_);      //执行采样操作

四、参数理解和讨论

在上述代码中标记了三个半径:
r 1 r_1 r1mls.setSearchRadius(0.005);
r 2 r_2 r2mls.setUpsamplingRadius(0.002);
r 3 r_3 r3mls.setUpsamplingStepSize(0.0001);
下面展示一下这三个参数的效果。请注意下面展示效果的时候 r r r只是参考半径,例如你可以设为点云中最近邻距离最大值等。

r 1 r_1 r1效果

从下面效果图中可以看出 r 1 r_1 r1越大,用于MLS曲面的点越多,从而得到的点云表面越平滑。

a.原始点云b. 设置 r 1 = r r_1=r r1=rc. 设置 r 1 = 1.5 r r_1=1.5r r1=1.5r
c.设置 r 1 = 2 r r_1=2r r1=2rd. 设置 r 1 = 2.5 r r_1=2.5r r1=2.5re. 设置 r 1 = 3 r r_1=3r r1=3r

r 2 r_2 r2效果

从下面效果图中可以看出 r 2 r_2 r2越大,从原始点云的每个点扩展出去的范围越大

a. 设置 r 2 = 0.4 r r_2=0.4r r2=0.4rb. 设置 r 2 = 0.8 r r_2=0.8r r2=0.8rc. 设置 r 2 = 1.5 r r_2=1.5r r2=1.5r

r 3 r_3 r3效果

从下面效果图中可以看出 r 3 r_3 r3越大,采样的步长也越大。

a. 设置 r 3 = 0.1 r r_3=0.1r r3=0.1rb. 设置 r 3 = 0.25 r r_3=0.25r r3=0.25rc. 设置 r 2 = 0.5 r r_2=0.5r r2=0.5r

五、参考

[1] https://blog.51cto.com/u_13157605/6038637

  • 19
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
点云处理中,点云上采样是指通过添加额外的点来增加点云的密度。为了实现点云上采样,我们可以使用一种被称为最近邻搜索(Nearest Neighbor Search)的方法来估计新点的位置。 MLS(Moving Least Squares)是一种常用的点云上采样方法。它基于小领域内的点进行插值,并通过拟合一个局部曲面来估计插值点的位置。 具体步骤如下: 1. 选择一个点作为目标点,并确定其半径为$r$的领域。 2. 根据领域内的点进行最小二乘拟合,获得曲面(通常是一个平面)的法向量和拟合误差。 3. 将目标点的位置投影到曲面上,得到新的点位置。 4. 重复以上步骤,直到所有点都被处理。 MLS的优点在于能够保留原始点云的曲面特征,并且可以根据实际需求进行参数调整。此外,它还可以用于点云数据的平滑处理,在噪声较大的情况下有较好的效果。 然而,MLS也有一些限制。首先,它在进行最小二乘拟合时,假设曲面是局部线性的。因此,对于弯曲或高度变化较大的曲面,插值的效果可能不太理想。其次,MLS的计算复杂度较高,特别是处理大规模点云时,会消耗较多时间和计算资源。 综上所述,MLS是一种常用的点云上采样方法,通过拟合局部曲面来估计新点的位置。它能够较好地保留原始点云曲面特征,但对于弯曲或高度变化较大的面可能效果受限。此外,MLS的计算复杂度较高,需要较多时间和计算资源。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

42方生科技

谢谢!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值