当前位置: 首页 > web >正文

DDcGAN_codes

 train.py代码修改:

1、将os.mkdir改为os.makedirs。

【原因】os.mkdir不能生成多级目录。

try:os.makedirs(f'./weights/{project_name}/')os.makedirs(f'./weights/{project_name}/Generator/')os.makedirs(f'./weights/{project_name}/Discriminator/')
except:pass

2、权重保存

源代码中epoch为100,每个epoch都保存了权重,我改为10次保存一次。修改代码如下:

if epoch % 10 == 0:torch.save(Generator, f'./weights/{project_name}/Generator/Generator_{epoch}.pth')torch.save(Discriminator,
f'./weights/{project_name}/Discriminator/Discriminator_{epoch}.pth')

2、权重保存

源代码中epoch为100,每个epoch都保存了权重,我改为10次保存一次。修改代码如下:

if epoch % 10 == 0:torch.save(Generator, f'./weights/{project_name}/Generator/Generator_{epoch}.pth')torch.save(Discriminator,
f'./weights/{project_name}/Discriminator/Discriminator_{epoch}.pth')

此时,根目录会生成如下权重文件:包括判别器和生成器

test.py代码修改

import torch
from PIL import Image
from torchvision import transforms
import sys
sys.path.append(".")
from core.model import build_model
from core.utils import load_config
# from core.model.build import build_model
# from core.utils.config import load_config# config = load_config('../config/Pan-GAN.yaml')
config = load_config('./config/GAN_G1_D2.yaml')
GAN_Model = build_model(config)
vis_img = Image.open('./demo/test_vis.jpg')
inf_img = Image.open('./demo/test_inf.jpg')
# trans = transforms.Compose([transforms.Resize((256, 256)), transforms.ToTensor()])
trans = transforms.Compose([transforms.Resize((512, 512)), transforms.ToTensor()])
vis_img = trans(vis_img)
inf_img = trans(inf_img)
data = {'Vis': vis_img.unsqueeze(0), 'Inf': inf_img.unsqueeze(0)}
GAN_Model.Generator.load_state_dict(torch.load('./weights/GAN_G1_D2/Generator/Generator_50.pth').state_dict())
Generator_feats, Discriminator_feats, confidence = GAN_Model(data)
untrans = transforms.Compose([transforms.ToPILImage()])img = untrans(Generator_feats['Generator_1'][0])
print(img.size)
img.save('test_result.jpg')

出现的主要错误如下:

1、ModuleNotFoundError: No module named 'core'
1、ModuleNotFoundError:没有名为 'core' 的模块

这部分对应修改如下:

import sys
sys.path.append(".")
from core.model import build_model
from core.utils import load_config
# from core.model.build import build_model
# from core.utils.config import load_config

2、FileNotFoundError: [Errno 2] No such file or directory: '../config/GAN_G1_D2.yaml'
 FileNotFoundError: [Errno 2] 没有这样的文件或目录: '../config/GAN_G1_D2.yaml 中”

这部分对应修改如下:

# config = load_config('../config/Pan-GAN.yaml')
config = load_config('./config/GAN_G1_D2.yaml')
GAN_Model = build_model(config)
vis_img = Image.open('./demo/test_vis.jpg')
inf_img = Image.open('./demo/test_inf.jpg')

3、No such file or directory: './weights/Generator/Generator_100.pth'
没有这样的文件或目录:'./weights/Generator/Generator_100.pth'

权重文件保存错误 修改即可。修改如下 weights/GAN_G1_D2/Generator/Generator_100.pth

4、RuntimeError: Calculated padded input size per channel: (2 x 2). Kernel size: (4 x 4). Kernel size can't be greater than actual input size
   RuntimeError:计算出每个通道的填充输入大小:(2 x 2)。内核大小:(4 x 4)。内核大小不能大于实际输入大小

这部分修改如下:将256*256改为512*512。

# trans = transforms.Compose([transforms.Resize((256, 256)), transforms.ToTensor()])
trans = transforms.Compose([transforms.Resize((512, 512)), transforms.ToTensor()])

5、img = untrans(Generator_feats['Generator'][0])        KeyError: 'Generator'
  img = untrans(Generator_feats['Generator'][0]) KeyError: '生成器'

这部分对应将'Generator'改为'Generator_1'。

# img = untrans(Generator_feats['Generator'][0])
img = untrans(Generator_feats['Generator_1'][0])

改正 :

我结合debug函数中的相关代码,在测试代码中添加了部分操作:

GAN_Model = build_model(config)
vis_img = Image.open('./demo/test_vis.jpg') #test_vis.jpg
inf_img = Image.open('./demo/test_inf.jpg')#test_inf.jpg
# trans = transforms.Compose([transforms.Resize((256, 256)), transforms.ToTensor()])
trans = transforms.Compose([transforms.Resize((512, 512)), transforms.ToTensor()])
vis_img = trans(vis_img)
inf_img = trans(inf_img)
data = {'Vis': vis_img.unsqueeze(0), 'Inf': inf_img.unsqueeze(0)}
GAN_Model.Generator.load_state_dict(torch.load('./weights/GAN_G1_D2/Generator/Generator_100.pth').state_dict()) #./weights/GAN_G1_D2/Generator/Generator_50.pth
Generator_feats, Discriminator_feats, confidence = GAN_Model(data)#------新增,实现图像显示------
mean=Generator_Train_config['mean']
std=Generator_Train_config['std']
mean_t = torch.FloatTensor(mean).view(3, 1, 1).expand(vis_img.shape)
std_t = torch.FloatTensor(std).view(3, 1, 1).expand(vis_img.shape)
Generator_feats['Generator_1'][0] = Generator_feats['Generator_1'][0] * std_t + mean_tuntrans = transforms.Compose([transforms.ToPILImage()])
img = untrans(Generator_feats['Generator_1'][0])

在项目根目录下,有一个debug文件夹,里面能看到不同epoch的融合效果。

http://www.xdnf.cn/news/13828.html

相关文章:

  • 【python】执行deactivate没有关闭虚拟环境
  • 交易所 java, web3 交易所简易模块
  • [SKE]CPU 与 GPU 之间数据加密传输的认证与异常处理
  • 【线程与线程池】线程数设置(四)
  • 线程池启动报null :Caused by: java.lang.IllegalArgumentException: null
  • 每日学习一道数模题-2024国赛B题-生产过程中的决策问题
  • ViT架构所需的大型训练集
  • 在 IntelliJ IDEA 中运行时出现“Log already in use? tmlog in ./“
  • Python数据可视化艺术:社交网络关系图制作
  • parquet批量读取图片文件示例
  • 树莓派5 ubuntu 24.04 docker配置镜像Docker pull时报错:https://registry-1.docker.io/v2/
  • 机器学习与深度学习21-信息论
  • 项目名称:基于计算机视觉的夜间目标检测系统
  • map与set的模拟实现
  • ABAP零碎记录
  • 事件(Event)
  • 56、原生组件注入-原生注解与Spring方式注入
  • 录制mp4 rospy
  • 数字人分身系统源码开发功能深度解析
  • 基于算力魔方与PP-OCRv5的OpenVINO智能文档识别方案
  • CSS实现元素撑满剩余空间的5种方法
  • Linux启动流程和内核管理自我总结
  • 杭州公司一面java题目和解答
  • 2025最新版使用VSCode和CMake图形化编译调试Cuda C++程序(保姆级教学)
  • IOT集群扩容实践:问题剖析与解决策略
  • Vue 3.6前瞻:响应式性能革命与Vapor模式展望
  • c#.net code httpPost请求,携带文件
  • 更进一步深入的研究ObRegisterCallBack
  • Kotlin 协程与 ViewModel 的完美结合
  • Rust 学习笔记:处理任意数量的 future