Ubuntu18.04/20.04复现算法RandLa-net 数据集S3DIS

原本打算先复现Pointnet++的,现在RandLa-net的性能吊打Pointnet++,先复现这个吧,Pointnet++以后再做。

在大场景三维点云语义分割算法RandLA-net,原论文代码的环境是python3.5+tensorflow1.11+cuda9,而cuda9是不能在显卡RTX3080上跑通的。

环境搭建:Ubuntu18.04复现RandLA-net网络 环境搭建 记录_Parkerfive的博客-CSDN博客

本片博客指引:在RTX 3090上复现点云语义分割算法RandLA-net_lucky li的博客-CSDN博客

感谢指引,侵删。代码为大佬改编更新。

Ubuntu18.04或者Ubuntu20.04任选一  —>  搭配cuda11.4或者cuda11.3任选一 --> 配合tf2.6都是可以的,博主装了几遍系统都亲测过,不过cuda和cudnn安装的版本要和ubuntu版本对应。 

1.下载代码

git clone --depth=1 https://github.com/luckyluckydadada/randla-net-tf2.git

2.创建环境

conda create -n randlanet python=3.6

 

3.进入环境

conda activate randlanet

从现在开始都在环境内操作在终端的命令前有(randlanet):

pip install tensorflow-gpu==2.6 -i https://pypi.tuna.tsinghua.edu.cn/simple  --timeout=120

安装了很多包

安装完成如下:

 4.安装需要支持:

 注意路径进入randla-net-tf2文件夹,这里是安装一些工具。【打开helper_requirements.txt可看】

 pip install -r helper_requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple  --timeout=120

完成后如下:

如有问题可再次安装一遍。

5.注意路径进入randla-net-tf2文件夹下,再运行: 

 sh compile_op.sh

6.数据集介绍和下载:

大场景室内点云标注数据集S3DIS介绍_lucky li的博客-CSDN博客_s3dis

 点云数据集_zhulf0804的博客-CSDN博客_点云数据集

下载后数据集存放位置:家目录/data/S3DIS下。

 ls  ~/data/S3DIS/Stanford3dDataset_v1.2_Aligned_Version

同上皆是环境内,randla-net-tf2文件夹下运行:

7.运行代码生成需要文件。

python utils/data_prepare_s3dis.py

 python utils/data_prepare_s3dis.py  # 通过Stanford3dDataset_v1.2_Aligned_Version 生成input_0.040和original_ply

8.训练 area2~5 :

python -B main_S3DIS.py --gpu 0 --mode train --test_area 1

 

 应该会出现下列问题:

问题:

WARNING:tensorflow:From /home/siasun18/anaconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/compat/v2_compat.py:101: disable_resource_variables (from tensorflow.python.ops.variable_scope) is deprecated and will be removed in a future version.

原因:应该是源码用的版本比较老的原因吧,可以不用管。

问题:AlreadyExistsError: Another metric with the same name already exists.

解决:就是keras问题:tensorflow2.6.0安装 another metric with the same name already exists_qq_45759229的博客-CSDN博客

再次运行:

 问题:epoch 0 不往下运行了:

 往下划可以看到oom(爆显存了):资源耗尽,1块RTX3080显卡共10G显存不够用了

 解决:修改源代码:

打开/home/siasun18/randla-net-tf2/helper_tool.py文件,51行" batch_size = 6" 改小,改成

"batch_size = 4" , "train_steps = 750" 即可,显存不够batch_size可以再改小。

再次执行:

python -B main_S3DIS.py --gpu 0 --mode train --test_area 1

可以训练了

9.预测area1:

python -B main_S3DIS.py --gpu 0 --mode test --test_area 1

 10.可视化操作:

python vis_S3DIS.py     #在vis_S3DIS.py文件里2处把家目录后面的用户名文件目录改成自己的

 

 左边:原始点云        右边:预测点云

 



参考文献:

在RTX 3090上复现点云语义分割算法RandLA-net_lucky li的博客-CSDN博客

 

RandLANet是一种用于实时点云语义分割的神经网络模型,旨在提高点云处理的效率和准确性。要进行RandLANet的改进,可以从以下几个方面入手。 首先,可以改进RandLANet的网络结构。可以尝试使用更深层的神经网络结构,以提高模型的学习能力和表达能力。另外,可以在网络中引入注意力机制或门控机制,使得模型能够更加关注重要的局部信息,从而提高分割的准确性。 其次,可以考虑引入更多的训练数据和数据增强方法。点云数据的获取比较困难,但可以利用现有的数据集进行数据增强,比如进行旋转、缩放、平移等操作,增加数据的多样性和数量。此外,还可以考虑将其他传感器数据,如图像数据,与点云数据进行融合,从而提供更全面的信息。 另外,可以尝试改进模型的训练算法。可以尝试使用更先进的优化算法,如自适应学习率调整算法,以加速收敛和提高模型的表现。同时,可以尝试使用更有效的损失函数,如Dice损失函数或Focal损失函数等,用于平衡不同类别的分割准确度。 最后,可以尝试优化模型的推理过程。可以考虑引入更有效的数据结构和算法,以减少计算量和存储开销,从而提高模型的推理速度。此外,可以考虑利用GPU并行计算的特性,进一步提高模型的运行效率。 综上所述,通过改进RandLANet的网络结构、增加训练数据和数据增强、优化训练算法以及优化推理过程等方面的工作,可以进一步提高RandLANet的性能和应用范围。
评论 55
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值