[超分辨率重建]ESRGAN算法训练自己的数据集过程

一、下载数据集及项目包

1. 数据集

1.1 文件夹框架的介绍,如下图所示:主要有train和val,分别有高清(HR)和低清(LR)的图像。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第1张图片

1.2 原图先通过分割尺寸的脚本先将数据集图片处理成两个相同的图像组(HR和LR)。

如训练x4的ESRGAN模型,那么我们需要将HR的图像尺寸与LR的图像尺寸比例是4:1。在我的训练中,我将HR的图像尺寸分割成了480x480,LR的图像分割成了120x120。如下图所示。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第2张图片[超分辨率重建]ESRGAN算法训练自己的数据集过程_第3张图片

随后将分割好的图像按照train和val的分类,分成如1.1图中的文件结构。

2.  项目包

在我的下载资源中有SR项目包的下载,后续上链接。也可以在我上传的资源中下载。

二、训练ESRGAN

ESRGAN模型包括生成模型的训练和判别模型的训练。

2.1 配置RRDBNet_train.py(生成模型)的参数及训练

2.1.1 训练的图像路径设置:dataroot_gt为HR图像的路径、dataroot_lq为LR图像的路径。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第4张图片

2.1.2 batch_size_per_gpu为batchsize的设置,根据显存大小相应设置,显存越大可以设置的值越大,但是训练时间也会增大。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第5张图片

2.1.3 val的数据集路径设置,dataroot_gt为HR的图像路径、dataroot_lq为LR图像的路径。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第6张图片

2.1.4 训练迭代次数的设置,可以设置到10万或者更大

2.1.5 训练结果指标的计算psnr和ssim。val_freq参数为保存结果的频率。下图中我的设置为1e3即1000轮保存一次。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第7张图片

2.1.6 保存训练权重的频率设置。下图中我的设置为1e3,即为1000次保存一次训练权重。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第8张图片

2.1.7 RRDBNet_train.py的训练
python basicsr/train.py -opt options\train\ESRGAN\train_RRDBNet_PSNR_x4.yml

2.2 配置ESRGAN_train.py(判别模型)的参数及训练

2.2.1 ESRGAN_train.py的参数设置

ESRGAN_train.py的参数设置与RRDBNet_train.py相同,但是多了一个pretrain_network_g参数的设置,即填RRDBNet_train.py训练完以后最好的那次权重路径。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第9张图片

2.2.2 ESRGAN_train.py的训练
python basicsr/train.py -opt options\train\ESRGAN\train_RRDBNet_PSNR_x4.yml

三、测试

3.1 测试图片路径的设置

包括HR和LR的路径,分别为dataroot_gt和dataroot_lq。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第10张图片

3.2 ESRGAN模型权重的路径导入

在pretrain_network_g参数中导入ESRGAN模型训练完后生成的权重路径。

[超分辨率重建]ESRGAN算法训练自己的数据集过程_第11张图片

四、训练中断后,继续训练

只需要在训练代码后加上--auto_resume

python basicsr/train.py -opt options\train\ESRGAN\train_RRDBNet_PSNR_x4.yml --auto_resume


------------------     今天不学习,明天变垃圾。    ---------------------

你可能感兴趣的:(超分辨率重建,超分辨率重建,人工智能,深度学习)