news 2026/6/9 23:49:13

简单的GAN生成学习案例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
简单的GAN生成学习案例
importtorchimporttorch.nnasnnimporttorch.optimasoptimfromtorchvisionimportdatasets,transformsfromtorch.utils.dataimportDataLoaderimportmatplotlib.pyplotaspltimportnumpyasnp# 定义生成器网络classGenerator(nn.Module):""" 生成器网络:将随机噪声转换为伪造的图像 输入:随机噪声向量(维度为latent_dim) 输出:生成的图像(1 x 28 x 28) """def__init__(self,latent_dim):super(Generator,self).__init__()self.model=nn.Sequential(nn.Linear(latent_dim,256),nn.LeakyReLU(0.2),nn.BatchNorm1d(256),nn.Linear(256,512),nn.LeakyReLU(0.2),nn.BatchNorm1d(512),nn.Linear(512,1024),nn.LeakyReLU(0.2),nn.BatchNorm1d(1024),nn.Linear(1024,28*28),nn.Tanh())defforward(self,z):""" 前向传播 参数: z: 随机噪声向量 返回: 生成的图像,形状为 [batch_size, 1, 28, 28] """img=self.model(z)img=img.view(img.size(0),1,28,28)returnimg# 定义判别器网络classDiscriminator(nn.Module):""" 判别器网络:判断输入的图像是真实的还是生成的 输入:图像(1 x 28 x 28) 输出:图像为真实的概率(0-1之间的标量) """def__init__(self):super(Discriminator,self).__init__()self.model=nn.Sequential(nn.Linear(28*28,1024),nn.LeakyReLU(0.2),nn.Dropout(0.3),nn.Linear(1024,512),nn.LeakyReLU(0.2),nn.Dropout(0.3),nn.Linear(512,256),nn.LeakyReLU(0.2),nn.Dropout(0.3),nn.Linear(256,1),nn.Sigmoid())defforward(self,img):""" 前向传播 参数: img: 输入图像,形状为 [batch_size, 1, 28, 28] 返回: 图像为真实的概率,形状为 [batch_size, 1] """img_flat=img.view(img.size(0),-1)validity=self.model(img_flat)returnvaliditydeftrain_gan(epochs=100,batch_size=64,latent_dim=100,sample_interval=200):""" 训练GAN模型 参数: epochs: 训练轮数 batch_size: 批次大小 latent_dim: 随机噪声向量的维度 sample_interval: 生成并保存样本的间隔 """# 设置设备(GPU或CPU)device=torch.device("cuda"iftorch.cuda.is_available()else"cpu")print(f"使用设备:{device}")# 加载MNIST数据集transform=transforms.Compose([transforms.ToTensor(),transforms.Normalize([0.5],[0.5])])dataset=datasets.MNIST(root="./data",train=True,download=True,transform=transform)dataloader=DataLoader(dataset,batch_size=batch_size,shuffle=True)# 初始化生成器和判别器generator=Generator(latent_dim).to(device)discriminator=Discriminator().to(device)# 定义损失函数和优化器adversarial_loss=nn.BCELoss()optimizer_G=optim.Adam(generator.parameters(),lr=0.0002,betas=(0.5,0.999))optimizer_D=optim.Adam(discriminator.parameters(),lr=0.0002,betas=(0.5,0.999))# 训练循环forepochinrange(epochs):fori,(imgs,_)inenumerate(dataloader):# 配置输入real_imgs=imgs.to(device)batch_size=real_imgs.size(0)# 创建标签real=torch.ones(batch_size,1).to(device)fake=torch.zeros(batch_size,1).to(device)# ---------------------# 训练判别器# ---------------------optimizer_D.zero_grad()# 计算真实图像的损失real_loss=adversarial_loss(discriminator(real_imgs),real)# 生成假图像z=torch.randn(batch_size,latent_dim).to(device)gen_imgs=generator(z)# 计算假图像的损失fake_loss=adversarial_loss(discriminator(gen_imgs.detach()),fake)# 总判别器损失d_loss=(real_loss+fake_loss)/2d_loss.backward()optimizer_D.step()# ---------------------# 训练生成器# ---------------------optimizer_G.zero_grad()# 生成假图像z=torch.randn(batch_size,latent_dim).to(device)gen_imgs=generator(z)# 生成器希望判别器认为生成的图像是真实的g_loss=adversarial_loss(discriminator(gen_imgs),real)g_loss.backward()optimizer_G.step()# 打印训练进度ifi%50==0:print(f"[Epoch{epoch}/{epochs}] [Batch{i}/{len(dataloader)}] "f"[D loss:{d_loss.item():.4f}] [G loss:{g_loss.item():.4f}]")# 定期保存生成的图像ifi%sample_interval==0:save_images(gen_imgs,epoch,i)# 训练完成后,生成最终样本print("\n训练完成!生成最终样本...")z=torch.randn(25,latent_dim).to(device)gen_imgs=generator(z)save_images(gen_imgs,epochs,0,final=True)defsave_images(images,epoch,batch_idx,final=False):""" 保存生成的图像 参数: images: 生成的图像张量 epoch: 当前轮数 batch_idx: 当前批次索引 final: 是否为最终样本 """images=images.detach().cpu().numpy()images=0.5*images+0.5# 反归一化到[0, 1]范围fig,axes=plt.subplots(5,5,figsize=(10,10))fori,axinenumerate(axes.flat):ifi<images.shape[0]:ax.imshow(images[i,0],cmap='gray')ax.axis('off')iffinal:plt.savefig(f'gan_final_samples.png')print(f"最终样本已保存为: gan_final_samples.png")else:plt.savefig(f'gan_epoch{epoch}_batch{batch_idx}.png')plt.close()if__name__=="__main__":# 训练GAN模型train_gan(epochs=20,batch_size=64,latent_dim=100,sample_interval=200)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 17:23:22

专业仿写文章Prompt

专业仿写文章Prompt 【免费下载链接】xnbcli A CLI tool for XNB packing/unpacking purpose built for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/xn/xnbcli 任务要求&#xff1a; 基于给定的技术文章&#xff08;关于xnbcli工具&#xff09;创作一篇…

作者头像 李华
网站建设 2026/6/9 17:28:00

Windows平台Poppler终极指南:5分钟掌握PDF高效处理技巧

Windows平台Poppler终极指南&#xff1a;5分钟掌握PDF高效处理技巧 【免费下载链接】poppler-windows Download Poppler binaries packaged for Windows with dependencies 项目地址: https://gitcode.com/gh_mirrors/po/poppler-windows Poppler for Windows是一款专为…

作者头像 李华
网站建设 2026/6/8 14:43:05

HMI设计|这两天跟着德国那帮子人学了两招!

嘿&#xff0c;大家好&#xff01;今天咱们唠唠工业HMI界面设计&#xff0c;这玩意儿说白了就是工厂里那些屏幕咋排版才能好看又顺手。德国那帮设计师在这方面玩得贼溜&#xff0c;现在咱们就来跟着学学。三层聚焦法 简单实用在某种意义上触摸屏界面就跟手机桌面其实是类似的&a…

作者头像 李华
网站建设 2026/6/9 18:37:45

PaddlePaddle镜像训练模型后如何做A/B测试?

PaddlePaddle镜像训练模型后如何做A/B测试&#xff1f; 在AI模型从实验室走向生产环境的过程中&#xff0c;一个常见的困境是&#xff1a;离线指标明明提升了&#xff0c;上线后业务效果却毫无起色&#xff0c;甚至出现负向波动。这种“纸上谈兵”式的模型迭代&#xff0c;在金…

作者头像 李华
网站建设 2026/6/9 18:34:06

Blender MMD Tools:从零基础到精通的全流程操作指南

Blender MMD Tools&#xff1a;从零基础到精通的全流程操作指南 【免费下载链接】blender_mmd_tools MMD Tools is a blender addon for importing/exporting Models and Motions of MikuMikuDance. 项目地址: https://gitcode.com/gh_mirrors/bl/blender_mmd_tools MMD…

作者头像 李华