CycleGAN文件构成

转载自网络,但找不到原作

首先,进入根目录pytorch-CycleGAN-and-pix2pix:

need-to-insert-img

这个目录下imgs下是两张示例图片,不用管;

后面文件夹中所有的.pyc文件都是运行相应代码之后产生的文件,这里着重解释一下pyc文件:.pc文件是由.py文件经过编译后生成的字节码文件,其加载速度相对于之前的.py文件有所提高,而且还可以实现源码隐藏,以及一定程度上的反编译。比如,Python3.3编译生成的.pyc文件,Python3.4就别想着去运行啦!

生成.pyc文件后,之后再次调用到之前的.py文件都可以通过.pyc文件快速加载。所以,运行一次之后,py文件可以删掉,后面运行文件时直接调用.pyc文件就可以更高效地执行。

train.py和test.py是训练和测试的文件,通过它们来调用其他文件夹的网络文件来进行实验。

checkpoints文件(训练的时候生成的):checkpoints文件是在代码运行后由options/base_options.py根据设置的路径产生的,其目录下还生成一个maps_cyclegan:里面保存着模型文件.pth(由models/base_model.py生成),初始化参数文件:opt.txt、保存网络训练过程中loss的文件:loss_log.txt和一个文件夹web(由util/visualizer.py生成)

need-to-insert-img

接下来进入web:包含一个文件夹和一个.html文件

need-to-insert-img

images文件夹下存放着每个epoch的图片(由util/visualizer.py生成),每个epoch存放6张:

need-to-insert-img

再回到根目录下的datasets文件夹:训练、测试数据所在地

再回到根目录下的options文件夹:option里面存放着网络最基本的参数

need-to-insert-img

其中训练时用到train_options.py和base_options.py文件;

测试时用到test_options.py和base_options.py文件。

下面是网络最初的base_options.py文件:

need-to-insert-img


其中:batchsize是每次迭代图片数量、loadsize和finesize决定输入图片的大小,这三个参数直接影响网络训练时占用的内存大小(和训练图片本身的size无关,测试图片最后的大小也由finesize决定)实践证明,网络中loadsize和finesize这两个参数不要轻易改动(虽然变小能够加快训练速度,不过最后的结果只对小图有用,不能达到和大图评估的作用);which_model_netD和which_model_netG用于定义网络判别器和生成器的模型;

train_options和test_options继承自base_options,调用train_options和test_options会初始化base_options里面的参数并在base的基础上添加自带的参数;

train_options.py文件参数如下:

need-to-insert-img

其中,phase表明现在的阶段是训练还是测试;niter表示多少个epoch后学习率开始变化;niter_decay表示学习率经过多少个epoch衰减为0;

lr是学习率(因为梯度回传的原因,神经网络对输入非常敏感。我们拿乘法门来举例,如果输入的xi全都变成原来1000倍,而权重w不变,那么在反向传播计算的时候,x路径上获得的回传梯度不变,而w上的梯度则会变大1000倍,这使得你不得不降低学习速率(learning

rate)成原来的1/1000以维持平衡);no_lsgan决定网络所用的loss函数;lambda_A和lambda_B分别是cycleGAN网络两个cycle

loss的权重。

test_options.py文件参数如下:

need-to-insert-img

其中,which_epoch表示test阶段所要加载的模型文件是哪个;how_many表示测试图片数。


根目录下的results文件夹(test的时候生成的)下maps_cyclegan里面存放着网络结果文件test_latest:保存test后的结果文件

need-to-insert-img

images存放1000到1045代的图片数据

need-to-insert-img

回到根目录下的util文件下:visualizer.py用于输出训练中间结果和保存相应文件

need-to-insert-img

data文件夹下:data文件夹下存放加载数据的文件,包括一些数据的基本设置(如路径,大小等)

need-to-insert-img

models文件夹下:通过models.py来加载我们需要的网络结构;networks.py用于定义网络结构和网络相应的输出,cycleGAN的网络结构中,生成器的结构来源于Perceptual losses for real-time style transfer and

super-resolution,同样使用InstanceNormalization;判别器的结构来源于pix2pix(PatchGANon 70*70 patches)。训练模型的保存和测试阶段模型的加载通过base_model.py实现。

need-to-insert-img

scripts文件夹下:也就是脚本文件,包括训练和测试的脚本文件,最后根据你训练的网络来修改test_single.sh

对单独的数据进行测试。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容