u2net网络模型训练自己数据集

单分类

下载项目源码
项目源码

准备数据集

将json转为mask

json_to_dataset.py

bash 复制代码
import cv2
import json
import numpy as np
import os
import sys
import glob


def func(file):
    with open(file, mode='r', encoding="utf-8") as f:
        configs = json.load(f)
    shapes = configs["shapes"]

    png_class = np.zeros((configs["imageHeight"], configs["imageWidth"], 1), np.uint8)
    png_other = np.zeros((configs["imageHeight"], configs["imageWidth"], 1), np.uint8)

    for shape in shapes:
        label = shape['label']
        if label == 'class':
            cv2.fillPoly(png_class, [np.array(shape["points"], np.int32)], (255))
        else:
            cv2.fillPoly(png_other, [np.array(shape["points"], np.int32)], (255))

    png = png_class - png_other
    return png


if __name__ == "__main__":
    json_dir = "image"

    save_dir = 'image/masks'

    for file in os.listdir(json_dir):
        print('***************', file)
        if file.endswith(".json"):
            # 在这里添加后续步骤
            png = func(os.path.join(json_dir, file))
            print(png.shape)
            save_path = save_dir + '/' + os.path.splitext(file)[0] + ".png"
            cv2.imwrite(save_path, png)
            print('***************', save_path)

创建文件路径

bash 复制代码
train_data
	|__DUTS
		|__DUTS-TR
			|__im_aug			# mask图
			|__gt_aug			# 原图
		|__DUTS-TE
			|__im_aug			# mask图
			|__gt_aug			# 原图

训练

修改u2net_train.py

bash 复制代码
# ------- 2. set the directory of training dataset --------

model_name = 'u2net' #'u2netp'											# 选择模型

# 修改为对应的数据集路径
data_dir = os.path.join(os.getcwd(), 'train_data' + os.sep)
tra_image_dir = os.path.join('DUTS', 'DUTS-TR', 'im_aug' + os.sep)
tra_label_dir = os.path.join('DUTS', 'DUTS-TR', 'gt_aug' + os.sep)

image_ext = '.jpg'
label_ext = '.png'

model_dir = os.path.join(os.getcwd(), 'saved_models', model_name + os.sep)

alpha_export.py为转换模型,u2net_test.py模型预测

多分类

准备数据集

将json转为mask,由于是多分类,每一个分类一个rgb值,例如分类1(1,1,1),分类2(2,2,2),分类3(3,3,3);

bash 复制代码
import cv2
import json
import numpy as np
import os
import sys
import glob


def func(file):
    with open(file, mode='r', encoding="utf-8") as f:
        configs = json.load(f)
    shapes = configs["shapes"]

    class1 = np.zeros((configs["imageHeight"], configs["imageWidth"], 3), np.uint8)
    class2 = np.zeros((configs["imageHeight"], configs["imageWidth"], 3), np.uint8)
    class3 = np.zeros((configs["imageHeight"], configs["imageWidth"], 3), np.uint8)

    for shape in shapes:
        label = shape['label']
        if label == 'class1':
            cv2.fillPoly(class1, [np.array(shape["points"], np.int32)], (1, 1, 1))
        elif label == 'class2':
            cv2.fillPoly(class2, [np.array(shape["points"], np.int32)], (2, 2, 2))
        elif label == 'class3':
            cv2.fillPoly(class3, [np.array(shape["points"], np.int32)], (3, 3, 3))

    return class1 + class2 + class3


if __name__ == "__main__":
    json_dir = "./train_data/labels_json"

    save_dir = './train_data/masks'

    for file in os.listdir(json_dir):
        print('***************', file)
        if file.endswith(".json"):
            # 在这里添加后续步骤
            png = func(os.path.join(json_dir, file))
            print(png.shape)
            save_path = save_dir + '/' + os.path.splitext(file)[0] + ".png"
            cv2.imwrite(save_path, png)
            print('***************', save_path)

数据集文件夹

bash 复制代码
datasets
	|__train_data
		|__images		# 原图
			|__1.jpg
			|__2.jpg
			|__3.jpg
		|__masks		# mask图
			|__1.png
			|__2.png
			|__3.png
	|__test_data
		|__images
			|__1.jpg
			|__2.jpg
			|__3.jpg
		|__masks
			|__1.png
			|__2.png
			|__3.png
		|__my_results_2
		|__predeict_lables
		|__predict_masks

训练

bash 复制代码
# ------- 2. set the directory of training process --------
model_name = 'u2net'  # 'u2net'							# 选择模型
model_dir = os.path.join('saved_models', model_name + os.sep)

# 图片的文件类型
image_ext = '.jpg'
label_ext = '.png'

# train阶段
# 数据集路径
data_dir = os.path.join("datasets/train_data" + os.sep)
# 原始图片路径
tra_image_dir = os.path.join('images' + os.sep)
# 图片的标签路径
tra_label_dir = os.path.join('masks' + os.sep)

# val阶段
# 数据集类别
num_classes = 4			# 背景+类别数
name_classes = ["background", "class1", "class2","class3"]
# 原始图片路径
images_path = "datasets/test_data/images/"
# 图片的标签路径
gt_dir = "datasets/test_data/masks/"
# 存放推理结果图片的路径
pred_dir = "datasets/test_data/predict_masks/"
predict_label = "datasets/test_data/predict_labels/"
# 存放 miou 计算结果的 图片
miou_out_path = "miou_out_tab"
# 预训练权重
seg_pretrain_u2netp_path = 'saved_models/pretrain_model/segm_u2net.pth'
if not os.path.exists(model_dir):
    os.makedirs(model_dir)

epoch_num = 100
batch_size = 2
train_num = 0
val_num = 0

执行u2net_train.py,开始训练

预测

bash 复制代码
if __name__ == "__main__":
    #   miou_mode用于指定该文件运行时计算的内容
    #   miou_mode为0代表整个miou计算流程,包括获得预测结果、计算miou。
    #   miou_mode为1代表仅仅获得预测结果。
    #   miou_mode为2代表仅仅计算miou。
    #   分类个数+1、如2+1
    # num_classes = 3
    # name_classes = ["background", "green", "red"]
    num_classes = 4
    name_classes =["background", "class1", "class2","class3"]

    # 原始图片路径
    images_path = "datasets_ButtonCell/test_data/images/"
    # 图片的标签路径
    gt_dir = "datasets_ButtonCell/test_data/masks/"
    # 存放推理结果图片的路径
    pred_dir = "datasets_ButtonCell/test_data/predict_masks/"
    predict_label = "datasets_ButtonCell/test_data/predict_labels/"
    # 存放 miou 计算结果的 图片
    miou_out_path = "miou_out"
    # 模型路径
    model_dir = './saved_models/u2netp/u2netp.pth'
    eval_print_miou(num_classes, name_classes, images_path, gt_dir, pred_dir, predict_label, miou_out_path, model_dir)

执行u2net_val.py,开始训练

torch2onnx.py进行模型转换

相关推荐
GOTXX6 分钟前
基于Opencv的图像处理软件
图像处理·人工智能·深度学习·opencv·卷积神经网络
糖豆豆今天也要努力鸭1 小时前
torch.__version__的torch版本和conda list的torch版本不一致
linux·pytorch·python·深度学习·conda·torch
何大春1 小时前
【弱监督语义分割】Self-supervised Image-specific Prototype Exploration for WSSS 论文阅读
论文阅读·人工智能·python·深度学习·论文笔记·原型模式
Suyuoa2 小时前
附录2-pytorch yolov5目标检测
python·深度学习·yolo
余生H3 小时前
transformer.js(三):底层架构及性能优化指南
javascript·深度学习·架构·transformer
罗小罗同学3 小时前
医工交叉入门书籍分享:Transformer模型在机器学习领域的应用|个人观点·24-11-22
深度学习·机器学习·transformer
孤独且没人爱的纸鹤3 小时前
【深度学习】:从人工神经网络的基础原理到循环神经网络的先进技术,跨越智能算法的关键发展阶段及其未来趋势,探索技术进步与应用挑战
人工智能·python·深度学习·机器学习·ai
阿_旭3 小时前
TensorFlow构建CNN卷积神经网络模型的基本步骤:数据处理、模型构建、模型训练
人工智能·深度学习·cnn·tensorflow
羊小猪~~3 小时前
tensorflow案例7--数据增强与测试集, 训练集, 验证集的构建
人工智能·python·深度学习·机器学习·cnn·tensorflow·neo4j
极客代码3 小时前
【Python TensorFlow】进阶指南(续篇三)
开发语言·人工智能·python·深度学习·tensorflow