Windows11和Ubuntu用PointNet++训练自己的数据集(部件分割模型)

news2024/12/23 0:23:42

省流:
(1)不管是Linux还是Windows都不影响,只要有pycharm或者vscode即可,啥系统都行。
(2)此外由于自己的需求,所以只做物体部件分割(partseg)任务,没有复现分类(classification)和语义分割(semseg)。
(3)文章包括:建立标注自己的数据集、数据集按格式放到pointnet工程、代码修改、报错修改
(4)博主只是按照自己的数据集复现原本网络的train和test,即跑完一个完整的步骤。至于用自己训练好的模型去检测自己的点云文本,之后再实现可视化和保存检测结果,这个问题博主还有待解决。

背景:自建了一个轮胎表面的点云,需要用pointnet++网络分出轮胎的 槽顶 和 槽底。(自己采的点云,精度不是很高,见笑了)。
所以就是1个物体(即轮胎)2个部件(即槽底 和 槽顶)。记住这个数字,后面数据集标注和改代码会用到。
在这里插入图片描述

一、标注数据集

软件:CloudCompare
标注方法:如何利用CloudCompare软件进行点云数据标注
注意:原文中那个:SF name是一样的,即是luntai(一个物体),但是value的值是不一样的,即槽底设置是0,槽顶设置是1(来两个部件)。
在这里插入图片描述
标注完后:
在这里插入图片描述

得到其中一个txt文本:我们没有用向量信息,所以就是 x y z位置信息和类别。
注意: cloudCompare生成了的txt文件,最后面会有一个空行,我不知道训练时有没有影响,我是删掉了!!!!!!。
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/b30f149dd266492bb28dda3ccca261a3.pn

二、下载源码

链接:https://github.com/yanx27/Pointnet_Pointnet2_pytorch
在这里插入图片描述

三、添加自己的数据集

3.1知识准备——要看!!建议下载shapenet数据集体会一下

自己用得到的功能是部件分割即partseg,所以得参考原作者用的ShapeNet数据集的格式。

格式介绍:点云数据集ShapeNet
ShapeNet数据集百度网盘下载: 百度网盘【提取码:evqi】
百度网盘来源:【三维视觉】【深度学习】ubuntu18.04下PointNet官方代码Pytorch实现

3.2添加自己的数据集

在自己的源码工程下新建 data 文件夹,在其下新建shapenetcore_partanno_segmentation_benchmark_v0_normal文件夹,之后在建立以下三个文件,因为自己是一个物体即luntai,所以就只有一个自己起的编号(01234567)。
在这里插入图片描述

在这里插入图片描述
(1)01234567:0-35,一共36个轮胎的点云
在这里插入图片描述

(2)synsetoffset2category.txt:对应好即可,注意两者之间是tab键还是空格。我是从ShapeNet数据集直接改的,所以不太清楚。
在这里插入图片描述
(3)train_test_split文件夹:指定自己的36个点云文件,哪些点云是用于训练(train)、那些用于测试(test)、那些用于验证(val)。
三个json文件里面的名字、路径对应上就好,不用加.txt且前面的shape_data要加上并且01234567在多个物体时要记得修改。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(4)最后在pycharm的工程上看到:
在这里插入图片描述

四、修改代码

由于原本的partseg代码用的是16种物体共50个部件,咱们是1个物体2个部件,所以有些张量的维度得改。
参考:Pointnet++内Partseg分割网络训练自己的数据集

4.1 改train_partseg.py:

(1)
在这里插入图片描述
(2)
在这里插入图片描述

4.2 改test_partseg.py:

(1)
在这里插入图片描述
(2)
在这里插入图片描述

4.3pointnet2_part_seg_msg.py(你若用这个模型,就改动,用别的模型就改别的)

(1)
在这里插入图片描述
(2)
在这里插入图片描述

(3)
在这里插入图片描述

五、运行train_partseg.py

若习惯终端命令,可以从pycharm运行终端,并进入该工程的文件夹
在这里插入图片描述

5.1运行train_partseg.py

第一种方法:命令行传参
在这里插入图片描述

python train_partseg.py --model pointnet2_part_seg_msg --log_dir pointnet2_part_seg_msg

(1)–model pointnet2_part_seg_msg 是指定模型为pointnet2_part_seg_msg,模型名字可以看工程文件的models文件夹有哪些模型
(2)由于咱们自己的txt文件没有向量信息,所以命令行没加 --normal
(3)–log_dir pointnet2_part_seg_msg是指定训练后的数据保存在log/part_srg下那个文件夹。若是指定就是保存到 后面名字指定的文件夹,没指定就是按时间来命名。如下图
在这里插入图片描述
在这里插入图片描述
第二种方法:直接运行.py文件,但是要设置好默认值(default)
在这里插入图片描述

5.2运行出现的问题

(1)问题1:torch.OutOfMemoryError: CUDA out of memory.
(2)解决:减小上图中的批量大小(batch size) 或者 不要再自己笔记本上跑,在具有好的深度学习条件的电脑上跑。我是换成了更好的台式电脑。
(3)参考:torch.OutOfMemoryError: CUDA out of memory

六、运行test_partseg.py

6.1运行test_partseg.py

在这里插入图片描述
可以看到相比于train_partseg.py参数设置还有有点不同
法一:终端命令行来进行。
此外,同样咱们的txt是没有向量信息,所以也不带–normal

python test_partseg.py --log_dir pointnet2_part_seg_msg

或者日期的文件夹

python test_partseg.py --log_dir 2024-12-05_20-22

在这里插入图片描述
法2:pycharm点击运行

把required改成 default。后面带文件夹
在这里插入图片描述

6.2运行出现问题

(1)问题1:RuntimeError: Error(s) in loading state_dict for model
原因:代码参数值与模型训练时的参数值不一致导致异常信息
解决:看看那些默认值,train和test有些参数是否一样 或者 训练train时存放的log里的文件夹和这里测试test时读取的是否是一个,我的就是单击pycharm运行按钮导致train存放在日期文件夹下,test在终端输入,目录读取pointnet2_part_seg_msg文件夹,不一致,所以命令换成读取相应日期文件就好。
在这里插入图片描述
(2)问题2:numpy‘ has no attribute ‘float‘
原因:numpy‘ has no attribute ‘float
解决方法1:降低numpy版本
快捷安装方法:
点击pycharm右下方解释器,再点击解释器设置:
在这里插入图片描述
+是下载,还可以选择版本,选1.25.3
-是卸载
在这里插入图片描述
在这里插入图片描述
解决方法2:参考PyTorch复现PointNet++——模型训练+模型测试,里面有一种方法说把代码中的报错部分改为np.float64。
np.array(total_correct_class) / np.array(total_seen_class, dtype=np.float64))。这里用了老哥的图贴一下。
在这里插入图片描述

(3)问题3:RuntimeError: GET was unable to find an engine to execute this computation
解决方法1:先按此链接试试,如果都没问题,都能正常打印再参考此篇知乎评论区
在test_partseg.py前面 加上torch.backends.cudnn.enabled = False(亲测有效)
在这里插入图片描述
解决方法2:我看过有帖子说换成cpu就行,我没试过!!!!若用cpu跑。就把那个使用GPU的参数设置为使用cpu。
在这里插入图片描述

我没试过!!

七、用自己训练的模型检测一个自己的数据集,并分类保存在相应的txt,正在攻克!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2257861.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【git】git回退到之前版本+拓展git命令

一、问题 git提交有时候会出错&#xff0c;想回退到之前的版本 1、命令git reset --soft <commit_id> commit_id【回退到的编号】 2、git push --force-with-lease origin <branch_name> branch_name【分支名】 二、拓展 1、git bash 1、进入任意磁盘 cd 磁盘…

Golang使用etcd构建分布式锁案例

在本教程中&#xff0c;我们将学习如何使用Go和etcd构建分布式锁系统。分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要。它有助于维护一致性&#xff0c;防止竞争条件&#xff0c;并确保在任何给定时间只有一个进程独占访问资源。 我们将使用Go作为编程语言&am…

开源数据同步中间件(Dbsyncer)简单玩一下 mysql to mysql 的增量,全量配置

一、什么是Dbsyncer 1、介绍 Dbsyncer是一款开源的数据同步中间件&#xff0c;提供MySQL、Oracle、SqlServer、PostgreSQL、Elasticsearch(ES)、Kafka、File、SQL等同步场景&#xff0c;支持上传插件自定义同步转换业务&#xff0c;提供监控全量和增量数据统计图、应用性能预警…

element-plus的el-tree的双向绑定

el-tree改造了下 可选可取消 有默认值 不包含父级id&#xff08;也可打开注释 包含父级id&#xff09; 默认展开 点击节点也可触发选择 节点内容自定义 <template><div class"absolute"><el-scrollbar class"pall"><div class"…

微信小程序报错:http://159.75.169.224:7300不在以下 request 合法域名列表中,请参考文档

要解决此问题&#xff0c;需打开微信小程序开发者工具进行设置&#xff0c;打开详情-本地设置重新运行&#xff0c;该报错就没有啦

医疗系统国产数据库高质量发展路径探析

信息工程人员操作数据库 一、国外数据库在医疗系统中的困境 &#xff08;一&#xff09;数据分散与难以整合 在美国&#xff0c;分散式医疗服务成为癌症研究数据库优化的巨大障碍。患者先在社区接受肿瘤科医生常规检查&#xff0c;再到学术医疗中心进行尖端治疗&#xff0c;然…

C语言——验证“哥德巴赫猜想”

问题描述&#xff1a; 验证"哥德巴赫猜想" 任何一个大于2的偶数都可以表示为两个质数之和。例如&#xff0c;4可以表示为22&#xff0c;6可以表示为33&#xff0c;8可以表示为35等 //验证"哥德巴赫猜想" //任何一个大于2的偶数都可以表示为两个质数之和…

Windows平台Unity3D下RTMP播放器低延迟设计探讨

技术背景 好多开发者希望我们分享下大牛直播SDK是如何在Unity下实现低延迟的RTMP播放的&#xff0c;以下是一些降低 Unity 中 RTMP 播放器延迟的方法&#xff1a; 一、选择合适的播放插件或工具 评估和选用专业的流媒体插件 市场上有一些专门为 Unity 设计的流媒体插件&…

速通前端篇 —— CSS

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;速通前端 目录 CSS的介绍 基本语法规范 CSS选择器 标签选择器 class选择器 id选择器 复合选择器 通配符选择器 CSS常见样式 颜…

MySQL并发控制(二):锁

只改一行语句&#xff0c;为什么锁那么多 注1&#xff1a;MySQL后面的版本可能会改变加锁策略&#xff0c; 所以这个规则只限于截止到现在的最新版本&#xff0c; 即5.x系列 注2&#xff1a;因为间隙锁在可重复读隔离级别下才有效&#xff0c; 所以本篇文章接下来的描述&#…

从零开始的使用SpringBoot和WebSocket打造实时共享文档应用

在现代应用中&#xff0c;实时协作已经成为了非常重要的功能&#xff0c;尤其是在文档编辑、聊天系统和在线编程等场景中。通过实时共享文档&#xff0c;多个用户可以同时对同一份文档进行编辑&#xff0c;并能看到其他人的编辑内容。这种功能广泛应用于 Google Docs、Notion 等…

PHP保存base64编码图片,图片有一部分是灰色块儿,原因和解决办法

文章目录 场景原因解决方案完整的代码前端代码php代码 场景 我有个需求&#xff0c;移动端h5上传多张的图片。用input file可以上传多张&#xff0c;但是现在照片体积越来越大&#xff0c;同时上传多张会因为体积过大&#xff0c;导致上传失败。如果是小程序会好很多&#xff…

vue图片之放大、缩小、1:1、刷新、左切换、全屏、右切换、左旋咋、右旋转、x轴翻转、y轴翻转

先上效果&#xff0c;代码在下面 <template><!-- 图片列表 --><div class"image-list"><img:src"imageSrc"v-for"(imageSrc, index) in images":key"index"click"openImage(index)"error"handleI…

Oracle EBS FA 如何打开关闭的资产会计期间?

用户“运行折旧”,误勾选为“关闭期间”,还有一部分资产还需要操作报废和调整,希望后台打开关闭的资产会计期 系统环境 RDBMS : 12.1.0.2.0 Oracle Applications : 12.2.9 解决方案 由官方提供SQL脚本代码如下: /*rollback120.sql - for Release 12.X only(based on r…

Hash、HASHTABLE底层原理【Redis对象篇】

&#x1f3c6; 作者简介&#xff1a;席万里 ⚡ 个人网站&#xff1a;https://dahua.bloggo.chat/ ✍️ 一名后端开发小趴菜&#xff0c;同时略懂Vue与React前端技术&#xff0c;也了解一点微信小程序开发。 &#x1f37b; 对计算机充满兴趣&#xff0c;愿意并且希望学习更多的技…

CentOS 二进制安装部署MongoDB 4.0

一、安装MongoDB 1. 下载 MongoDB 二进制文件 前往 MongoDB 官方下载页面(https://www.mongodb.com/try/download/community) 选择对应版本的 tar 包。 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.28.tgz 2. 解压并移动至目标目录 解压文件&#xff…

Redis篇-5--原理篇4--Lua脚本

1、概述 Redis 支持使用 Lua 脚本来执行复杂的操作&#xff0c;这为 Redis 提供了更强的灵活性和性能优化能力。通过 Lua 脚本&#xff0c;你可以在服务器端执行一系列命令&#xff0c;而不需要多次往返客户端与服务器之间&#xff0c;从而减少了网络延迟并提高了效率。此外&a…

新手上路,学Go还是Python

对于新手来说&#xff0c;Go和Python都是很好的编程语言&#xff0c;它们各有特点&#xff0c;以下是详细的对比来帮助你决定先学哪一个&#xff1a; 一、语法和学习难度 Python 语法简洁易懂&#xff1a;Python以其简洁、优雅的语法而闻名&#xff0c;代码的可读性很高。例如…

OceanBase 社区版 4.0 离线方式升级bp1至bp2 指南(含避坑总结)

注&#xff1a;目前社区版对 4.0 升级 bp1至 bp2也未有完善的文档&#xff0c;本次升级中也是遇到不少坑&#xff0c;写本文也希望对OB感兴趣的可以尝试少些遇坑。 也希望对升级有更好方式建议方式的朋友一起切磋交流&#xff0c;以便再进一步完善升级方案。 第一次做OB的升级&…

python学opencv|读取图像(六)读取图像像素RGB值

【1】引言 前序已经掌握了如何获取灰度图像的像素&#xff0c;文章链接为&#xff1a; python学opencv|读取图像&#xff08;五&#xff09;读取灰度图像像素-CSDN博客 实际上像素就像一个坐标轴&#xff0c;约束了图像的大小。 但实际上我们在学习过程中&#xff0c;对于同…