码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • AIGC笔记--基于DDPM实现图片生成


    目录

    1--扩散模型

    2--训练过程

    3--损失函数

    4--生成过程

    5--参考


    1--扩散模型

    完整代码:ljf69/DDPM

    扩散模型包含两个过程,前向扩散过程和反向生成过程。

    前向扩散过程对一张图像逐渐添加高斯噪声,直至图像变为随机噪声。

    反向生成过程从一个随机噪声开始,逐渐去噪声直至生成一张图像。

    2--训练过程

    通过以下公式对图像进行加噪:

    1. def forward(self, x0, t, eta = None):
    2. n, c, h, w = x0.shape # 输入图片的shape
    3. a_bar = self.alpha_bars[t]
    4. if eta is None:
    5. eta = torch.randn(n, c, h, w).to(self.device)
    6. noisy = a_bar.sqrt().reshape(n, 1, 1, 1) * x0 + (1 - a_bar).sqrt().reshape(n, 1, 1, 1) * eta # 加噪
    7. return noisy # 返回加噪结果

    3--损失函数

    通过一个UNet网络来预测损失,计算预测损失和真实损失MSE损失:

    1. ...
    2. eta = torch.randn_like(x0).to(device) # 产生真实随机噪声
    3. t = torch.randint(0, n_steps, (n,)).to(device)
    4. # 前向扩散过程
    5. noisy_imgs = ddpm(x0, t, eta)
    6. # 通过UNet预测噪声
    7. eta_theta = ddpm.backward(noisy_imgs, t.reshape(n, -1))
    8. # 计算预测噪声和真实随机噪声的MSE损失
    9. loss = mse(eta_theta, eta)
    10. ...

    4--生成过程

    通过以下公式实现图片生成:

    1. x = torch.randn(n_samples, c, h, w).to(device) # 随机初始化噪声
    2. for idx, t in enumerate(list(range(ddpm.n_steps))[::-1]):
    3. time_tensor = (torch.ones(n_samples, 1) * t).to(device).long()
    4. eta_theta = ddpm.backward(x, time_tensor)
    5. alpha_t = ddpm.alphas[t]
    6. alpha_t_bar = ddpm.alpha_bars[t]
    7. x = (1 / alpha_t.sqrt()) * (x - (1 - alpha_t) / (1 - alpha_t_bar).sqrt() * eta_theta) # 去噪
    8. if t > 0:
    9. z = torch.randn(n_samples, c, h, w).to(device)
    10. beta_t = ddpm.betas[t]
    11. sigma_t = beta_t.sqrt()
    12. x = x + sigma_t * z

    5--参考

    怎么理解今年 CV 比较火的扩散模型(DDPM)

  • 相关阅读:
    断崖式难度春招,需要注意这些点
    是时候检查一下使用索引的姿势是否正确了
    【vue3】消息的订阅与发布
    参加了个算法比赛,真是一言难尽啊
    pytorch复现_conv2d
    Autowired如何实现自动注入?
    分库分表理论总结
    云原生微服务治理 第四章 Spring Cloud Netflix 服务注册/发现组件Eureka
    单机/分布式限流-漏桶/令牌桶/滑动窗口/redis/nginx/sentinel
    设计模式 - 组合模式理解及示例
  • 原文地址:https://blog.csdn.net/weixin_43863869/article/details/133997567
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号