码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 上采样之反卷积操作


    本文参考:

    https://www.jianshu.com/p/b48bf190fe61

    理解转置卷积 - 脂环 - 博客园

    深度解析什么是转置卷积-电子发烧友网

    https://blog.csdn.net/weixin_41620490/article/details/105885663

    常用的下采样通过卷积和池化操作,不断缩小图像尺寸,减少矩阵的采样点数。

    上采样通过反卷积或者插值操作,不断扩大图像尺寸,增加矩阵的采样点数。

    卷积操作本身上是一种特征抽取,数据压缩的过程。

    而反卷积是一种特殊的正向卷积,先按照一定的比例通过补0来扩大输入图像的尺寸,接着旋转卷积核,再进行正向卷积。但是该反卷积并不是卷积的逆过程,一旦卷积操作后,是无法通过反卷积还原回去的。反卷积更准确地讲应该是转置卷积。

    如何理解转置?

    首先从卷积操作讲起。

    对于如上卷积操作,

    输入input为4*4,kernel为3*3,stride为1,padding为0。则卷积后为:

     

    数学推导时可以通过滑动kernel分别计算出每个值,但是计算机则是一次性计算出值。

    首先将输入转化成N*1,对于本input为16*1,如下:

    将卷积核转化为4*16的稀疏矩阵,如下图所示:

     矩阵相乘得到4*1的结果的过程如下:

    通过卷积核构造的4*16的稀疏矩阵,使得4*4 -> 16*1的输入直接得到了4*1 -> 2*2的结果。

    而上采样则相反,我们希望2*2 -> 4*1的输入得到16*1 -> 4*4的结果,此时就需要使用到16*4的矩阵,从正向的4*16矩阵变为16*4的转置矩阵,故而得名转置矩阵。

     

    如何计算输出大小?

    首先给出卷积输出大小的计算公式:

    转化后得到:

     

    调换in和out的值,则得到转置卷积后的大小为:

     

    pytorch如何计算转置卷积?

    首先,卷积操作的代码如下:

    1. import torch
    2. import torch.nn as nn
    3. model = nn.Conv2d(in_channels=1, out_channels=1, kernel_size=2,stride=1,padding=0)
    4. x = torch.tensor([[[1.,2.,3.],[4.,5.,6.],[7.,8.,9.]]]).unsqueeze(0)
    5. model.weight.data = torch.tensor([[[[1.,1.],[1.,1.]]]])
    6. model.bias.data = torch.zeros(1)
    7. print(model(x))

    输出结果为:

    tensor([[[[12., 16.],
              [24., 28.]]]], grad_fn=)

     转置卷积操作的代码如下:

    1. import torch
    2. import torch.nn as nn
    3. model = nn.ConvTranspose2d(in_channels=1, out_channels=1, kernel_size=3,stride=1,padding=0)
    4. x = torch.tensor([[[12,16],[24,28]]], dtype=torch.float32).unsqueeze(0)
    5. model.weight.data = torch.tensor([[[[1,1,1],[1,1,1],[1,1,1]]]], dtype=torch.float32)
    6. model.bias.data = torch.zeros(1)
    7. print(model(x))

     输出结果为:

    tensor([[[[12., 28., 28., 16.],
              [36., 80., 80., 44.],
              [36., 80., 80., 44.],
              [24., 52., 52., 28.]]]], grad_fn=)

     

  • 相关阅读:
    如何进行企业数字化转型?数字化转型的3大核心规律
    【PostgreSQL】PG_DUMP的文件大小元小于库占用物理空间统计
    Python判断多个文件夹的文件夹名是否包含“分公司”或“营销中心”怎么处理?(方法三)...
    Aptos、Solana和新公链周期律
    HDFS 读写解析
    如何使用Linux编写STM32程序并且烧录
    [Java Framework] [MQ] SpringBoot 集成RabbitMQ
    如何使用rclone将腾讯云COS桶中的数据同步到华为云OBS
    谷粒商城学习笔记
    [NOIP2001 提高组] 一元三次方程求解
  • 原文地址:https://blog.csdn.net/benben044/article/details/126025438
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号