PointCleanNet: 一种基于数据驱动的点云去噪方法

2023-11-11 11:51

本文主要是介绍PointCleanNet: 一种基于数据驱动的点云去噪方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近投文章,不止一个审稿人向我推荐了PointCleanNet用于稠密点云去噪。查了一下,是Ovsjanikov教授挂名的文章,发表在CGF上。高手背书,果断决定研究一下。

1. 介绍

点云去噪是一个老问题了,一般主要是针对高斯噪声和异常点(Outliers)进行去噪,经典的方法包括双线性,高斯核以及MLS曲面重映射等方法。作者在PointCleanNet中,提出了一些关于点云去噪的一些细节问题,如下:

1)平衡去噪与特征保护;2)自适应;3)对无序点云与刚性变换鲁棒;4)不干扰非噪声点。

这里给出我个人的解释,一般在点云去噪中,为了追求点云的连续性,通常都会采取平滑算法。可想而知,一些重要的几何特征,如锐利的边界以及几何纹理细节会被平滑掉。这是我们不希望发生的。因此,去噪需要在平滑与特征保持中建立平衡。自适应,意思是不希望有过多的人为输入。因为一些经典算法都要求用户输入搜索半径等参数,而这些参数对结果又会有很大影响,同时用户又不太清楚如何输入较好的参数,所以导致基于参数的算法实用性一般。自适应就是要解决这个问题。无序与刚性变换鲁棒比较容易理解,就是对同一个点云,变换点的顺序与对点云进行平移旋转,去噪结果一致。最有一点,不干扰非噪声点,就是说点云需要在尽可能保持原始信息的基础上去噪,否则就是输出一个和原来模型不一致的所谓理想结果,自己逗自己玩。

为了解决这些问题,作者提出了PointCleanNet。该网络基于PCPNet architecture [1] 来估计局部几何特征,并根据该特征实现去噪。通过对一组包括了噪声的点云块集合进行训练,得到PointCleanNet,即首先去除Outliers,然后估计留下的点的校正向量。

2. 问题建模

假设带噪声点云表示如下:

P‘为输入点云;我们希望恢复噪声点的位置并去除Outlier, 于是我们建立校正向量的表示

 d为校正向量,p_i^'为消除了Outlier的点。

PointCleanNet的目标就是消除Outlier并且获得对校正向量的估计。基本上这是一个局部估计的问题,校正向量要与点云的邻域结果报纸一致,以获得平滑的曲面。PCPNet能够用来计算一个点云的邻域结构的几何特征。

 使用一个非线性函数g来估计输入点是outlier的概率: 

o^{~}_i是outliers的判断概率,当大于0.5时,即判断输入点为outlier。

使用一个函数f来估计校正向量d

建立局部块local patch:建立一个类似于ball space的空间,来搜索附近的区域,以获得outlier的概率;使用spatial transformer network(quaternion spatial transformer network:QSTN)[2] 来去除旋转影响;

Loss function: 基本上就是点的欧氏距离,也可以是Hausdorff距离。

3. 程序调试

首先下载源代码,作者已经提供了项目链接:GitHub - mrakotosaon/pointcleannet

配置,我是在pycharm上配置的,需要安装的包包括cudatoolkit,cudnn,pytorch,numpy,script,tensorboardx,请按照版本需求安装。

程序的使用:

首先,下载训练数据,使用download_data.py

之后,训练,使用train_pcpnet.py

按照要求,在项目根目录中创建一个文件夹,存储输出的去噪结果

最后,运行run.sh (如果是windows平台,需要安装shell执行应用。我没有搞定,就直接把sh里的命令在命令行模式里输入的,总共三条语句,即对点云进行的三次迭代。)

我对python的点云项目不太熟,应该是可以把这个程序重新改一下,不需要这么麻烦,熟悉python点云项目的兄弟有空可以优化一下: 

论文中的一些去噪的实验结果: 

我用自己的数据跑出来的一些结果:(有效果,但是确实一般。事实上,依靠局部邻域的patch去建立源输入,还是不能彻底解决过于离散的outlier的情况。不过,肯定比传统方法要好一点。)

 

[1] GUERRERO P, et al. PCPNet: Learning local shape properties from raw point clouds.CGF 37, 2 (2018), 75–85.

[2] JADERBERG M, et al. Spatial transformer networks. In NIPS (2015), pp. 2017–2025.

这篇关于PointCleanNet: 一种基于数据驱动的点云去噪方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/389870

相关文章

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Conda虚拟环境的复制和迁移的四种方法实现

《Conda虚拟环境的复制和迁移的四种方法实现》本文主要介绍了Conda虚拟环境的复制和迁移的四种方法实现,包括requirements.txt,environment.yml,conda-pack,... 目录在本机复制Conda虚拟环境相同操作系统之间复制环境方法一:requirements.txt方法

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求

MySQL 打开binlog日志的方法及注意事项

《MySQL打开binlog日志的方法及注意事项》本文给大家介绍MySQL打开binlog日志的方法及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、默认状态二、如何检查 binlog 状态三、如何开启 binlog3.1 临时开启(重启后失效)

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal