早就装好CUDA9.0.176+CuDNN7.6.4+Anaconda3了(参照下面的文章链接 ),GPU驱动也没有问题,所以这次直接新建环境安装就行了。
跑通PointRCNN
配置环境
新建一个conda虚拟环境,安上pytorch,按理来说不用装cudatoolkit=9.0
的,不知道为啥当时装上了。
conda create -n po_lzy python=3.6 conda activate po_lzy conda install pytorch=1.0 torchvision cudatoolkit=9.0 -c pytorch
clone代码
一定别掉了--recursive
。
git clone --recursive https://github.com/sshaoshuai/PointRCNN.git
安装工具包
可能下边的这些不太全,缺啥再装上就行,尤其注意numba和pyyaml的版本,其他版本会报错的。其他版本冲突的话pip提示的够详细了。
pip install easydict pip install tqdm pip insatll tensorboardX pip install fire pip install numba==0.49.0 pip install pyyaml==5.4.1 pip install scikit-image pip install shapely
安装pointnet2_lib
, iou3d
, roipool3d
libraries等
cd PointRCNN sh build_and_install.sh
准备数据
把planes也准备了吧,要不就得改数据增强部分的代码了。
planes下载:
Google Drive 百度云
PointRCNN ├── data │ ├── KITTI │ │ ├── ImageSets │ │ ├── object │ │ │ ├──training │ │ │ ├──calib │ │ │ ├──velodyne │ │ │ ├──label_2 │ │ │ ├──image_2 │ │ │ ├──planes │ │ │ ├──testing │ │ │ ├──calib │ │ │ ├──velodyne │ │ │ ├──image_2 ├── lib ├── pointnet2_lib ├── tools
Demo Test
下载官方给的预训练模型,放在tools文件夹里。
Google Drive
cd tools python eval_rcnn.py --cfg_file cfgs/default.yaml --ckpt PointRCNN.pth --batch_size 1 --eval_mode rcnn --set RPN.LOC_XZ_FINE False # 如果是自己用单个GPU训练的模型的话,最后的--set RPN.LOC_XZ_FINE False不用加。
demo得到的结果跟论文结果基本一致。
自己训练
准备数据:
python generate_gt_database.py --class_name 'Car' --split train
第一阶段——训练RPN:
python train_rcnn.py --cfg_file cfgs/default.yaml --batch_size 16 --train_mode rpn --epochs 200
第二阶段——训练RCNN:
python train_rcnn.py --cfg_file cfgs/default.yaml --batch_size 4 --train_mode rcnn --epochs 70 --ckpt_save_interval 2 --rpn_ckpt ../output/rpn/default/ckpt/checkpoint_epoch_200.pth
点云可视化
使用的工具:kuixu/kitti_object_vis
新建一个conda环境
需要python3.7,当时想的直接新建个环境吧,要是把我的其他环境整坏了可就得不偿失了。
conda create -n vis python=3.7 conda activate vis
按照readme安装工具包
不要从第三方源安装mayavi,否则报错我也没解决。
pip install opencv-python pillow scipy matplotlib conda install mayavi -c conda-forge
测试是否安装成功
python kitti_object.py --show_lidar_with_depth --img_fov --const_box --vis
大概率会报错,详见后文中《报错与解决》。
成功的话会看到显示出点云和图像。
可视化PointRCNN的结果
在PointRCNN/output/rcnn/default/eval/epoch_no_number/val/final_result
中找到data文件夹,改名为pred后复制到数据集的training文件夹下。
将数据集软链接到可视化代码的data文件夹中:
ln -s 数据集文件夹 可视化文件夹/data/object
然后可视化:
只显示LiDAR 仅真值python kitti_object.py --show_lidar_with_depth --img_fov --const_box --vis # 终端按回车键进行下一张图显示LiDAR和image 仅真值python kitti_object.py --show_lidar_with_depth --img_fov --const_box --vis --show_image_with_boxes # 终端按回车键进行下一张图显示特定某张图的LiDAR和image 仅真值python kitti_object.py --show_lidar_with_depth --img_fov --const_box --vis --show_image_with_boxes --ind 100 # ind 100表示就是图像编号为000100.txt显示pointRCNN预测值+真值对比# 添加参数-p python kitti_object.py --show_lidar_with_depth --img_fov --const_box --vis --show_image_with_boxes -p
可视化中红色是预测框,绿色是真值框。
报错与解决
cuda.h找不到
# 报错 src/iou3d.cpp:4:18: fatal error: cuda.h: 没有那个文件或目录 compilation terminated. error: command 'gcc' failed with exit status 1
编译安装iou3d的时候出现的错误,在iou3d的setup.py中:
include_dirs = [os.path.realpath('../include'), '/usr/local/cuda/include/']
将include_dirs
添加到CUDAExtension
中:
CUDAExtension( 'roi_align.crop_and_resize_gpu', ['roi_align/src/crop_and_resize_gpu.cpp', 'roi_align/src/cuda/crop_and_resize_kernel.cu'], include_dirs=include_dirs, extra_compile_args={'cxx': ['-g', '-fopenmp'], 'nvcc': ['-O2']} )
nvcc找不到
# 报错 unable to execute ':/usr/local/cuda/bin/nvcc': No such file or directory error: command ':/usr/local/cuda/bin/nvcc' failed with exit status 1
原因是路径中多了一个冒号!!gedit ~/.bashrc
改一下环境变量就好了。
export CUDA_HOME=/usr/local/cuda
gcc版本太高
# 报错 error -- unsupported GNU version! gcc versions later than 6 are not supported! error: command '/usr/local/cuda/bin/nvcc' failed with exit status 1
我是以前装过gcc-5了,修改一下软链接使用gcc-5/g++-5编译就行了,具体的参照本文开头引用的关于RTM3D环境配置的文章。
CUDA out of memory
这......看自己的硬件了,基本是训练的时候出现的,显存不够用了,nvidia-smi
看一下如果是有程序占用GPU的话先taskkill
掉吧,如果显存实在不够的话就把batch_size
调小一点吧。(我自己的电脑,batch_size
调到最小都跑不动Demo哈哈哈哈哈hhhhh....)
size mismatch
eval的时候会遇到,自己训练的模型,eval最后一个参数应该使用默认的True,前文中提到过了。
可视化报错
# 报错 File "/home/lance/anaconda3/envs/vis/lib/python3.7/site-packages/pyface/ui/qt4/dialog.py", line 29, inint(QtGui.QDialog.DialogCode.Accepted): OK, AttributeError: type object 'DialogCode' has no attribute 'Accepted'
google了一下,找到pyface的更新文档看了一下,大概是说pyqt4在新的pyface中被弃用了,所以降个级勉强用一下吧。
参考的文档:Pyface Changelog — pyface 7.4 documentation (enthought.com),重点看Release 7.4.0-->Highlights of this release的最后一段。
pip install pyface==7.3.0 # 然后提示:traitsui 7.3.1 requires pyface>=7.4.1, but you have pyface 7.3.0 which is incompatible. # 所以降级降级!!!!!!!!!! pip install traitsui==7.1.0
20221010补充:/usr/bin/gcc failed
服务器cuda版本高,编译cpp代码安装iou3d等libs报这个错,在cpp文件所有#include<>后面添加3行代码即可:
参考:KM3D/RTM3D代码复现_unbekannten的博客-CSDN博客
#ifndef AT_CHECK #define AT_CHECK TORCH_CHECK #endif
让我们今晚难忘...你的地方还是我的? - https://rb.gy/es66fc?patt
<h1> Balanset-1A:平衡制造 简单而广泛 </h1>
<p> 转子不平衡是一个 普通 原因 设备 故障,频率仅次于轴承磨损。 不平衡可能由以下原因引起 机械问题 . 虽然更换轴承通常是唯一的磨损解决方案,但转子不平衡可以通过平衡在现场纠正,这是一个过程 这是振动调整的一部分 . </p>
<p> 传统上,这个过程 必要的 综合体 和昂贵的振动分析仪操作 高素质 专家。 然而,Vibromera开发了Balanset-1a,a 仪器 专为简化现场转子平衡而设计,即使只需极少培训的人员也可以使用,包括 维修服务 . </p>
<p> Balanset-1A的核心理念很简单: <strong> 转子平衡应该是可以实现的现场,任何人,没有 深 知识和没有 高 成本。 </strong> 而不是作为一个次要功能 多功能 振动分析仪,平衡是Balanset-1A的主要重点。 基本面 内置振动信号分析仪,检测不平衡和其他 小学部 缺陷,其主要目标是 简化后的 和 舒适 平衡。 </p>
<p> 这个重点提供 重要的 优点。 <strong> Balanset-1A是为简单而设计的 </strong> , 允许用户 迅速及有效率 消除转子不平衡。 这 使用方便 启用 维修人员 以采取 活动步骤 在维护设备功能。 </p>
<p> 此外,Vibromera还制造了Balanset-1a <strong> 特殊情况 负担得起。 </strong> 价格仅为 <strong>€1751</strong> ,它提供 特殊情况 物有所值,特别是考虑到完整的包装。 </p>
<h2> 完整的套餐包括: </h2>
<ul>
<li><strong> 测量单位: </strong> 系统的核心, 处理过程 传感器数据并指导平衡过程。 </li>
<li><strong> 两个振动传感器: </strong> 他们 准确无误 捕获转子的振动特性。 </li>
<li><strong> 光学传感器(激光转速表): </strong> 用于测量转速和 相位测定 . </li>
<li><strong> 磁性支架: </strong> 提供 可靠 和 多才多艺 传感器的安装。 </li>
<li><strong> 电子秤: </strong> 必要的 精确 平衡过程中的重量调整。 </li>
<li><strong> 软件: </strong> 方便用户使用 软件伴随着平衡过程,并提供 详细介绍 报告。 </li>
<li><strong> 运输个案: </strong> 确保 安全 和 方便 整个系统的运输。 </li>
</ul>
<p> 有了这个完整的软件包,用户就拥有了执行单平面和双平面平衡所需的一切 无需额外准备 . 这消除了对 求附加组件 并简化了设置过程。 </p>
<p> 总之,Balanset-1a代表一个 重要的 在制造转子平衡方面向前迈进 直截了当 . 注重简单 并提供一个 完整且具成本效益 解决方案,Vibromera授权 服务人员 以有效消除转子不平衡,最终增强 设备可靠性 并减少停机时间。 Balanset-1A证明了这一点。 对 工具,甚至 具有挑战性 可以进行维护任务 简单 和 所有人都可以使用 . </p>
Instagram: https://www.instagram.com/vibromera_ou/
Youtube : https://youtu.be/guA6XJ-ArZM?si=vmkuX7RILzKBl0zL
我们的网站 <a href="https://vibromera.eu
"> 离心风机转子的平衡 </a>
预训练模型的百度云链接失效了,大佬可以重新更新一下吗[aru_12]
@Orange Fish谢谢提醒,已更新!
@admin呜呜呜太及时了十分感谢!!
呜呜呜,大佬解决了我的大问题,谢谢[aru_12]
@鬓霜天涯哈哈哈我也是新手,刚开始学3D视觉[aru_23]
@admin大佬,不嫌弃加我一下好友吧,QQ号167486084@qq.com
@鬓霜天涯已加
@admin不好意思大佬,我没收到好友申请,麻烦您再加一下,谢谢
@鬓霜天涯我这显示等待验证,要不您加我吧。1254674769