码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 李宏毅hw-6利用GAN生成动漫图像


    一、查漏补缺、熟能生巧:
    1.什么是转置卷积convTranspose、以及这种转置卷积怎么使用:

    (1)具体的原理直接看李沐老师的那个演示,非常清晰:

    47 转置卷积【动手学深度学习v2】_哔哩哔哩_bilibili

    (2)对于这个代码

    1. def dconv_bn_relu(self, in_dim, out_dim):
    2. return nn.Sequential(
    3. nn.ConvTranspose2d(in_dim, out_dim, kernel_size=5, stride=2,
    4. padding=2, output_padding=1, bias=False), #double height and width
    5. nn.BatchNorm2d(out_dim),
    6. nn.ReLU(True)
    7. )

    来自GPT的说法:

    2.关于weight_init和self.apply()

    3.关于G(z_samples)部分的一个不理解的地方:

    二、DCGAN , WGAN ,WGAN_GP (三种的5个epoch的效果对比):
    1.DCGAN版本:一般般,直接用助教的sample_code即可,

    2.对于WGAN的代码:

    也就是在DCGAN中进行这种修改就好了

    效果:

    3.采用WAGN-GP:

    需要做的修改:

    PyTorch-GAN/implementations/wgan_gp/wgan_gp.py at master · eriklindernoren/PyTorch-GAN (github.com)

     主要是写一个函数,然后把weight_clam那个for循环注释掉,其他的就按照助教给的注释来就好了

    1. def compute_gradient_penalty(self,D, real_samples, fake_samples):
    2. Tensor = torch.cuda.FloatTensor #if cuda else torch.FloatTensor
    3. """
    4. #这里需要参考那个link引入gradient penalty function
    5. Implement gradient penalty function
    6. """
    7. """Calculates the gradient penalty loss for WGAN GP"""
    8. # Random weight term for interpolation between real and fake samples
    9. alpha = Tensor(np.random.random((real_samples.size(0), 1, 1, 1)))
    10. # Get random interpolation between real and fake samples
    11. interpolates = (alpha * real_samples + ((1 - alpha) * fake_samples)).requires_grad_(True)
    12. d_interpolates = D(interpolates)
    13. fake = Variable(Tensor(d_interpolates.shape).fill_(1.0), requires_grad=False)
    14. # Get gradient w.r.t. interpolates
    15. gradients = autograd.grad(
    16. outputs=d_interpolates,
    17. inputs=interpolates,
    18. grad_outputs=fake,
    19. create_graph=True,
    20. retain_graph=True,
    21. only_inputs=True,
    22. )[0]
    23. gradients = gradients.view(gradients.size(0), -1)
    24. gradient_penalty = ((gradients.norm(2, dim=1) - 1) ** 2).mean()
    25. return gradient_penalty

    效果:

    ;

    中午睡觉的时候,用这个kaggle来train一下这个WGAN-GP,

    直接设置critic =5 , epoch =1000 试一试

    很可惜,第36个epoch的时候就崩掉了,不过生成的效果还不错,比之前的都要好一些,

    所以,估计只要epoch足够多,用WGAN-GP可以生成比较好的动漫人脸的

  • 相关阅读:
    openEuler系统安装并运行nginx
    泛型边界的问题
    svg图片代码data:image/svg+xml转png图片方法
    Python中的map()、apply()、applymap()的区别
    从零开始训练神经网络【学习笔记】[2/2]
    JAVA微服务场景下分布式日志收集排查问题实战
    生成 eps 的四种方法(总有一款适合你)
    【CH559l单片机入门篇】通过串口打印内部ID信息
    leetcode做题笔记131. 分割回文串
    mPEG-Cholesterol,mPEG-CLS,甲氧基-聚乙二醇-胆固醇可用于脂质体制备
  • 原文地址:https://blog.csdn.net/xiao_ZHEDA/article/details/132942846
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号