PolarMask环境配置并训练自己的数据集

运行环境:ubuntu18.04, CUDA10,conda

硬件:2080Ti

参考:

PolarMask pytorch代码实现记录(碎碎念事无巨细版)_Amberrr的博客-CSDN博客_polarmask训练自己的数据集源代码地址一、环境安装 基于mmdetection服务器新建Polarmask文件夹。下载Polarmask-master zip。 https://github.com/xieenze/PolarMask将PolarMask -master解压后移动到服务器Polarmask文件夹。(小白不习惯用git)参考安装指令:https://github.com/open-mmlab/mmdetection/blob/master/docs/install.mdconda create.https://blog.csdn.net/qq_41647438/article/details/106260855

PolarMask是基于mmdetection的。

1.下载文件

新建PolarMask文件夹,在其中下载PolarMask源码文件夹,并下载cocoapi文件夹,并列放置

GitHub - xieenze/PolarMask: Code for 'PolarMask: Single Shot Instance Segmentation with Polar Representation'Code for 'PolarMask: Single Shot Instance Segmentation with Polar Representation' - GitHub - xieenze/PolarMask: Code for 'PolarMask: Single Shot Instance Segmentation with Polar Representation'https://github.com/xieenze/PolarMaskhttps://github.com/xieenze/PolarMask

GitHub - cocodataset/cocoapi: COCO API - Dataset @ http://cocodataset.org/COCO API - Dataset @ http://cocodataset.org/ . Contribute to cocodataset/cocoapi development by creating an account on GitHub.https://github.com/cocodataset/cocoapihttps://github.com/cocodataset/cocoapi

2.安装依赖

进入PolarMask文件夹,修改PolarMask/mmdet/datasets/loader/sampler.py文件中:

from mmcv.runner.utils import get_dist_info

为:

from mmcv.runner import get_dist_info

然后开始进行配置,参考安装的指令install.md:

执行如下命令:

conda create -n your_venv_name python=3.7 -y #自己设置虚拟环境名字,和python版本,为了匹配matlib,建议选择3.7

conda activate your_venv_name #激活你建立的虚拟环境

conda install pytorch=1.3.1 cudatoolkit=10.0 torchvision=0.4.2 -c pytorch #安装此版本的pytorch和cuda开发组件

如果下载没问题(使用教育网)跳过此步,但是如果执行conda install pytorch=1.3.1 cudatoolkit=10.0 torchvision=0.4.2 -c pytorch,下载缓慢,则可以尝试使用pip命令安装pip install torch===1.3.1 torchvision===0.4.2 -f https://download.pytorch.org/whl/torch_stable.html

安装成功后,进入cocoapi文件夹中安装coco依赖,再进入PolarMask文件夹中安装PolarMask依赖,代码如下:

cd /cocoapi/PythonAPI #进入cocoapi文件夹

python setup.py build_ext install #安装cocoapi依赖

cd /PolarMask

python setup.py develop #安装PolarMask依赖

过程中如果有报错no module named 'xxxxx' ,可使用conda install xxxx或者pip install xxxxx,命令安装即可。

安装好之后,开始训练dataset

3.制作自己的数据集

其中coco数据集我使用的是2017格式:

data文件夹放在PolarMask代码包里面,布局如下:

data

|     |---coco

|     |           |---annotations

|     |           |---train2017

|     |           |---val2017

设置好数据集格式和位置后,在configs/polarmask/4gpu/polar_768_1x_r50.py中修改为自己的数据集路径(data_root=data/coco/),修改类别数量num_classes=自己数据集中的类别数量,学习率设置为0.025(单块GPU要设置小),可自定义修改工作路径“work_dir=xxxxx”,保存训练过程中的权重文件和训练信息;device_ids = range(4)变为devices_ids = range(1)。

接下来开始训练,训练命令:

python tools/train.py configs/polarmask/4gpu/polar_768_1x_r50.py

执行该命令后可能出现cuda版本的相关信息,此种情况可能是自己的cuda版本与显卡不支持,或者是mmcv/mmdetection的版本不支持,如果这样,请在安装PolarMask依赖之前首先下载mmdetection和mmcv相应版本的代码包,按照:

Prerequisites — MMDetection 2.19.1 documentationhttps://mmdetection.readthedocs.io/en/latest/get_started.html#installationhttps://mmdetection.readthedocs.io/en/latest/get_started.html#installation

安装正确的mmdetection和mmcv版本,之后再安装Polarmask依赖,即可解决该问题,

实际测试中 cuda10,pytorch1.3.1,python3.7, 2080Ti,ubuntu18.04,mmdetection1.0.0, mmcv0.5.3支持运行。

训练完成后相应权重保存在自己设置的工作路径中。

4.test和inference

测试命令,将训练结果输出保存为pkl文件:

#test的格式

python tools/test.py configs/polarmask/4gpu/polar_768_1x_r50.py [YOUR_CHECKPOINT_DIR] --out [OUT_DIR]

# eg:python tools/test.py configs/polarmask/4gpu/polar_768_1x_r101.py /home/wh/weights/polarmask_r101_1x.pth --out work_dirs/polar101.pkl

#自己的

python tools/test.py configs/polarmask/4gpu/polar_768_1x_r50.py work_dirs/trash/epoch_12.pth --out /mnt/ssz/Polarmask/PolarMaskmaster/work_dirs/out/results.pkl

Inference过程

/demo/visual.ipynb改成python脚本visual.py即可

在demo/visual.py里修改cofig路径、模型存储路径和测试图片路径

修改/mmdet/api/infrence.py文件中的函数show_result_pyplot(),在最后加上plt.savefig(“result.jpg”),可以添加参数设置指定目录,可以重新写一个脚本进行批处理。


发布于2021.12.22,后面会更新数据集制作方法及相关源代码。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值