Tan_pytorch_segmentation/pytorch_segmentation/PV_U-Net/README.md

54 lines
2.6 KiB
Markdown
Raw Normal View History

2025-05-19 20:48:24 +08:00
# U-Net(Convolutional Networks for Biomedical Image Segmentation)
## 该项目主要参考以下开源仓库
* [https://github.com/milesial/Pytorch-UNet](https://github.com/milesial/Pytorch-UNet)
* [https://github.com/pytorch/vision](https://github.com/pytorch/vision)
## 环境配置:
* Python3.6/3.7/3.8
* Pytorch1.10
* Ubuntu或Centos(Windows暂不支持多GPU训练)
* 最好使用GPU训练
* 详细环境配置见`requirements.txt`
## 文件结构:
```
├── src: 搭建U-Net模型代码
├── train_utils: 训练、验证以及多GPU训练相关模块
├── my_dataset.py: 自定义dataset用于读取DRIVE数据集(视网膜血管分割)
├── train.py: 以单GPU为例进行训练
├── train_multi_GPU.py: 针对使用多GPU的用户使用
├── predict.py: 简易的预测脚本,使用训练好的权重进行预测测试
└── compute_mean_std.py: 统计数据集各通道的均值和标准差
```
## DRIVE数据集下载地址
* 官网地址: [https://drive.grand-challenge.org/](https://drive.grand-challenge.org/)
* 百度云链接: [https://pan.baidu.com/s/1Tjkrx2B9FgoJk0KviA-rDw](https://pan.baidu.com/s/1Tjkrx2B9FgoJk0KviA-rDw) 密码: 8no8
## 训练方法
* 确保提前准备好数据集
* 若要使用单GPU或者CPU训练直接使用train.py训练脚本
* 若要使用多GPU训练使用`torchrun --nproc_per_node=8 train_multi_GPU.py`指令,`nproc_per_node`参数为使用GPU数量
* 如果想指定使用哪些GPU设备可在指令前加上`CUDA_VISIBLE_DEVICES=0,3`(例如我只要使用设备中的第1块和第4块GPU设备)
* `CUDA_VISIBLE_DEVICES=0,3 torchrun --nproc_per_node=2 train_multi_GPU.py`
## 注意事项
* 在使用训练脚本时,注意要将`--data-path`设置为自己存放`DRIVE`文件夹所在的**根目录**
* 在使用预测脚本时,要将`weights_path`设置为你自己生成的权重路径。
* 使用validation文件时注意确保你的验证集或者测试集中必须包含每个类别的目标并且使用时只需要修改`--num-classes`、`--data-path`和`--weights`即可,其他代码尽量不要改动
## 使用U-Net在DRIVE数据集上训练得到的权重(仅供测试使用)
- 链接: https://pan.baidu.com/s/1BOqkEpgt1XRqziyc941Hcw 密码: p50a
## 如果对U-Net网络不了解的可参考我的bilibili
* [https://www.bilibili.com/video/BV1Vq4y127fB/](https://www.bilibili.com/video/BV1Vq4y127fB/)
## 进一步了解该项目以及对U-Net代码的分析可参考我的bilibili
* [https://b23.tv/PCJJmqN](https://b23.tv/PCJJmqN)
## 本项目U-Net默认使用双线性插值做为上采样结构图如下
![u-net](unet.png)