作者:as8244433 | 来源:互联网 | 2023-10-12 14:54
PointNet(Stanford,2017.6)DeepHierarchicalFeatureLearningonPointSetsinaMetricSpace总结ÿ
PointNet++(Stanford,2017.6) Deep Hierarchical Feature Learning on PointSets in a Metric Space 总结:Pointnet++ 是pointnet的增强版本,可以看作增加了层次结构的pointNet。
把pointnet拿来做blocks级联,获得更大的感受野(类比CNN)。主要的contributes:
设计了set abstraction (包括Sampling layer、Grouping layer、以及PointNet layer)结构来提取点云特征 应对 raw 点云 的分布不均匀问题,论文提出了一种自适应的特征提取方式,根据点云密度调整 底层特征 和 高层特征 的在最终的融合特征中的权重。相比多尺度金字塔结构,计算量小,性能近似(略低) 总的来说就是改善了感受野,并能自适应的提取特征,最大化的发挥了point net的能力。
Pointnet 介绍 https://blog.csdn.net/weixin_39373480/article/details/88878629
https://www.cnblogs.com/wishchin/p/9199846.html
https://blog.csdn.net/sinat_37011812/article/details/81945050
1.为什么使用点云 点云是目前表示三维数据的最佳形式,其优点有:
点云更接近于设备的原始表征(即雷达扫描物体直接产生点云) 点云的表达方式更加简单,一个物体仅用一个N×D 的矩阵表示 2.PointNet PointNet,其本质就是一种网络结构,按一定的规则输入点云数据,经过一层层地计算,得出分类结果或者分割结果。其中比较特殊的地方在于两个转换矩阵(input transform & feature transform)的存在,根据文中所说,这两个转换矩阵可以在深度学习过程中保持点云数据的空间不变性。
pointnet当时不论是分割还是分类的结果都超过了当时的体素系列网络,同时由于参数少等特点,训练快,属于轻量级网络。
不仅如此,论文对PointNet对点云的点的缺失鲁棒性做了实验,实验证明,当PointNet缺失了60%左右的点的时候,其网络的效果都不怎么减少:
PointNet++ 1.PointNet的缺点 PointNet++的提出源于PointNet的缺点——缺失局部特征。PointNet对于场景的分割效果十分一般,由于其网络直接暴力地将所有的点最大池化为了一个全局特征,因此局部点与点之间的联系并没有被网络学习到。
2.PointNet++的思路 分层方式处理在度量空间中采样的一组点
通过基础空间的距离度量将这组点分割成重叠的局部区域
提取局部特征来捕获来自小邻域的精细几何结构; 这些局部特征被进一步分组为更大的单元并被处理以产生更高级的特征
重复这个过程直到我们获得整个点集的特征。
2.1 Set Abstraction 提取点云特征 blocks Sampling layer:采样层在输入点云中选择一系列点,由此定义出局部区域的中心。采样算法使用迭代最远点采样方法 iterative farthest point sampling(FPS)。
FPS: 先随机选择一个点,然后再选择离这个点最远的点作为起点,再继续迭代,直到选出需要的个数为止
相比随机采样,能更完整得通过区域中心点采样到全局点云
Grouping layer:目的是要构建局部区域,进而提取特征。思想就是利用临近点,并且论文中使用的是neighborhood ball,而不是K近邻,是因为可以保证有一个固定的感受野,主要的指标还是距离distance
Pointnet layer:在如何对点云进行局部特征提取的问题上,利用原有的Pointnet就可以很好的提取点云的特征,由此在Pointnet++中,原先的Pointnet网络就成为了Pointnet++网络中的子网络,层级迭代提取特征。
2.2 点云密度不均匀时的鲁棒特征学习 1.Multi-scale Grouping
简单而有效的方式,直接对不同密度的点云特征(通过Pointnet提取后的)进行组合,不同密度的点云是通过对输入点云进行不同概率的dropout得到的,问题是计算量比较大,慢。
2.Multi-resolution Grouping
分两部分,一部分直接用Pointnet从raw points上提取的特征,另一部分是对subregion使用 set abstraction得到的特征的集合。第一部分相当于是一个比较底层的部分,第二部分相当于是一个比较高层的部分,这里用两部分可以很好的控制局部区域的密度。当局部区域的密度比较小的时候,说明局部特征没有全局特征可靠,因此可以增加全局特征的权重。反之也是如此。就相当于权重可以在密度的变化之中可以被学习到。
2.3 分割 分割是逐点的,所以需要对特征进行上采样。
使用插值的方法再和之前的set abstraction 中的feature 做一个 concatenate
2.4 实验结果 Pointnet++的结构在3D point clouds上取得了state of art的水平,解决了如何处理采样不均匀的问题,也考虑了空间中点与点之间的距离度量,通过层级结构利用局部区域信息学习特征,网络结构更有效更鲁棒