DeepLab V3+ 训练自己的数据

本文档详细介绍了如何使用DeepLab V3+进行自定义数据集的训练,包括环境配置、数据准备、训练前的修改、训练过程、验证、可视化和模型导出等步骤。在训练前,确保所有依赖库正确安装,数据转换成tfrecord格式,同时解决训练过程中可能遇到的问题,如数据不平衡。训练完成后,通过可视化工具查看分割结果。
摘要由CSDN通过智能技术生成

一、前提

官网代码:https://github.com/tensorflow/models/tree/master/research/deeplab 

1. 依赖

DeepLab依赖于以下库:

  • Numpy
  • Pillow 1.0
  • tf Slim (which is included in the "tensorflow/models/research/" checkout)
  • Jupyter notebook
  • Matplotlib
  • Tensorflow1.6及以上

2. 将库添加到PYTHONPATH

在本地运行时,tensorflow / models / research /和slim目录应该附加到PYTHONPATH。 这可以通过在 tensorflow / models / research /路径下运行以下命令来完成:

# From tensorflow/models/research/
export PYTHONPATH=$PYTHONPATH:`pwd`:`pwd`/slim

注意:每次启用新终端,此命令都需要运行。 如果想避免手动运行,可以将其作为新行添加到〜/ .bashrc文件的末尾。

3. 简单测试

可以通过运行以下命令来测试是否已成功安装 Tensorflow DeepLab:

运行 model_test.py 进行快速测试:

# From tensorflow/models/research/
python deeplab/model_test.py

在PASCAL VOC 2012数据集上快速运行整个代码:

# From tensorflow/models/research/deeplab
sh local_test.sh

local_test.sh 脚本用于在PASCAL VOC 2012上运行本地测试。

之后在自己数据集上进行训练等操作就可以参照 local_test.sh 来编辑指令。打开脚本看一下,发现它:

(1)执行了model_test.py

(2)执行了download_and_convert_voc2012.sh

(3)从model_zoo(http://download.tensorflow.org/models)下载了模型deeplabv3_pascal_train_aug

(4)执行了train.py

(5)执行了eval.py

(6)执行了vis.py

(7)执行了export_model.py

建议仔细阅读上面提到的脚本和程序,为以后训练自己的数据提供参考。

错误1:

运行 model_test.py 进行快速测试时出错:

参考 https://github.com/tensorflow/models/issues/5523

 将 model_test.py 中140行左右的:

self.assertListEqual(scales_to_model_results.keys(),

修改为:

self.assertListEqual(list(scales_to_model_results.keys()),

错误2:

测试程序需要运行eval.py,我在这里出现了一个错误:

即:InvalidArgumentError (see above for traceback): assertion failed: [`predictions` out of bound] [Condition x < y did not hold element-wise:] [x (mean_iou/confusion_matrix/control_dependency_1:0) = ] [0 0 0...] [y (mean_iou/ToInt64_2:0) = ] [21]

参考https://github.com/tensorflow/models/issues/4203中trobr的说法:

修改 eval.py 中第145 行左右:

将:

metric_map = {}

metric_map[predictions_tag] = t
在Win10系统下,使用DeepLab V3进行语义分割训练自己的数据集可以通过以下步骤实现: 1. 准备数据集:首先,需要进行数据集的准备工作。收集大量的图像数据,并为每张图像标注像素级别的语义标签。确保训练图像和标签数据是一一对应的。 2. 安装依赖环境:在Win10系统下,首先需要安装Python和TensorFlow等深度学习框架,并配置好相应的环境变量。确保能够成功导入相关的库和模块。 3. 下载DeepLab V3:从GitHub上下载DeepLab V3的源代码,并解压到本地目录。在命令行中切换到DeepLab V3的根目录。 4. 数据预处理:使用脚本文件对数据集进行预处理,将图像和标签数据转换成模型可接受的格式。这可以通过运行预处理脚本来完成。 5. 配置参数:在配置文件中设置相关的训练参数,如训练图像的路径、标签的路径、模型的参数等。可以根据实际需要进行调整。 6. 运行训练:在命令行中运行训练脚本,该脚本会调用DeepLab V3模型进行训练。根据配置文件中的设置,模型将使用训练数据进行迭代训练,以优化模型的性能。 7. 评估模型:训练完成后,可以运行评估脚本对训练得到的模型进行评估。该脚本将使用测试数据进行预测,并计算出预测结果的准确性。 8. 使用模型:训练完成后,可以使用已训练好的模型对新的图像进行语义分割。通过在命令行中运行预测脚本,将输入图像作为参数进行预测,即可得到相应的语义分割结果。 以上是在Win10系统下使用DeepLab V3进行语义分割训练自己的数据集的基本步骤。根据具体情况和需求,可能还需要进行一些额外的调整和改进。
评论 20
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值