IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 论文阅读《Coarse-to-Fine Spatio-Temporal Information Fusion for Compressed Video Quality Enhancement》 -> 正文阅读

[人工智能]论文阅读《Coarse-to-Fine Spatio-Temporal Information Fusion for Compressed Video Quality Enhancement》

文献《Coarse-to-Fine Spatio-Temporal Information Fusion for Compressed Video Quality Enhancement》

D. Luo, M. Ye, S. Li and X. Li, “Coarse-to-Fine Spatio-Temporal Information Fusion for Compressed Video Quality Enhancement,” in IEEE Signal Processing Letters, vol. 29, pp. 543-547, 2022, doi: 10.1109/LSP.2022.3147441.


问题描述

文中在Bottleneck layer之前将4维度转3伟的操作通过reshape函数或者view函数可以实现。两者效果相同。

这里的dense bolck的concat前的一个卷积+ReLU的输出是不是画了两条线的输入了?

在这里插入图片描述
K应该是DCN的核的尺度的平方,3*3的采样点。

网络结构代码

不知道对不对
输入7帧 x = [B, 1, 7, H, W]

import torch
from torch import nn
from nets.ops.dcn.deform_conv import ModulatedDeformConv


class CFM(nn.Module):
    def __init__(self):
        super(CFM, self).__init__()
        self.c3d_input = nn.Sequential(
            nn.Conv3d(1, 32, (3, 3, 3), padding=(1, 1, 1)),
            nn.ReLU(inplace=True)
        )
        self.c3d = nn.Sequential(
            nn.Conv3d(32, 32, (3, 3, 3), padding=(1, 1, 1)),
            nn.ReLU(inplace=True)
        )
        self.bottleneck = nn.Conv2d(224, 64, 1)  # todo reshape [C*T H W]

    def forward(self, x):
        b, c, t, h, w = x.size()
        out = self.c3d(self.c3d_input(x)).view(b, 224, h, w)
        # 这里view和reshape函数效果相同,通过debug验证
        out = self.bottleneck(out)
        return out


class Residual_block(nn.Module):
    def __init__(self):
        super(Residual_block, self).__init__()
        self.conv = nn.Conv2d(64, 64, 3, 1, 1)
        self.relu = nn.ReLU(inplace=True)

    def forward(self, x):
        out = self.conv(self.relu(self.conv(x)))
        out += x
        out = self.relu(out)
        return out


class MLRF(nn.Module):
    def __init__(self):
        super(MLRF, self).__init__()
        self.downsample = nn.Sequential(
            nn.Conv2d(64, 64, 3, stride=2, padding=1),
            nn.ReLU(inplace=True),
            nn.Conv2d(64, 64, 3, 1, 1),
            nn.ReLU(inplace=True),
        )
        self.upsample = nn.Sequential(
            nn.ConvTranspose2d(64, 64, 4, 2, 1),
            # nn.PixelShuffle(2)  # todo 亚像素上采样
            nn.ReLU(inplace=True),
            nn.Conv2d(64, 64, 3, 1, 1),
            nn.ReLU(inplace=True),
        )
        self.residual = Residual_block()
        self.conv_relu = nn.Sequential(
            nn.Conv2d(64, 64, 3, 1, 1),
            nn.ReLU(inplace=True)
        )

    def forward(self, x):
        out_3 = self.residual(self.downsample(self.downsample(x)))
        out_2 = self.residual(self.downsample(x) + self.upsample(out_3))
        out_1 = self.residual(x + self.upsample(out_2))
        out_2 = self.upsample(self.residual(out_2))
        out_3 = self.upsample(self.upsample(self.residual(out_3)))
        out = self.conv_relu(out_1 + out_2 + out_3)
        return out


class DCN_fuse(nn.Module):
    def __init__(self, nf, in_nc, out_nc, base_ks, deform_ks):
        super(DCN_fuse, self).__init__()
        self.size_dk = deform_ks * deform_ks
        # regression head
        # why in_nc*3*size_dk?
        #   in_nc: each map use individual offset and mask
        #   2*size_dk: 2 coordinates for each point
        #   1*size_dk: 1 confidence (attention) score for each point
        self.offset = nn.Conv2d(
            nf, in_nc * 2 * self.size_dk, base_ks, padding=base_ks // 2
        )
        self.mask = nn.Conv2d(
            nf, in_nc * 1 * self.size_dk, base_ks, padding=base_ks // 2
        )

        # deformable conv
        # notice group=in_nc, i.e., each map use individual offset and mask
        self.deform_conv = ModulatedDeformConv(
            in_nc, out_nc, deform_ks, padding=deform_ks // 2, deformable_groups=in_nc
        )

    def forward(self, x, x_original_in):
        offsets = self.offset(x)
        mask = self.mask(x)
        out = self.deform_conv(x_original_in, offsets, mask)
        return out


class dense_block(nn.Module):
    def __init__(self):
        super(dense_block, self).__init__()
        self.relu = nn.ReLU(inplace=True)
        self.conv = nn.Conv2d(64, 64, 3, 1, 1)
        self.conv_cat = nn.Conv2d(256, 64, 3, 1, 1)

    def forward(self, x):
        out1 = self.relu(self.conv(self.relu(x)))
        out2 = self.relu(self.conv(out1))
        out3 = self.relu(self.conv(out2))
        out = self.conv_cat(torch.cat([out1, out2, out3, x], dim=1))
        return out


class RM(nn.Module):
    def __init__(self):
        super(RM, self).__init__()
        self.conv = nn.Conv2d(64, 64, 3, 1, 1)
        self.relu = nn.ReLU(inplace=True)
        self.dense = dense_block()
        self.conv_cat = nn.Conv2d(256, 64, 3, 1, 1)
        self.conv_output = nn.Conv2d(64, 1, 3, 1, 1)

    def forward(self, x):
        out1 = self.conv(x)
        out2 = self.dense(out1)
        out3 = (self.dense(out1 - out2)) + out1
        out4 = self.dense(out3)
        out = self.conv_cat(torch.cat([out1, out2, out3, out4], dim=1))
        out += out1
        out = self.conv_output(self.relu(self.conv(out)))
        return out


class CF_STIF(nn.Module):
    def __init__(self):
        super(CF_STIF, self).__init__()
        self.cfm = CFM()
        self.mlrf = MLRF()
        self.dcn = DCN_fuse(nf=64, in_nc=7, out_nc=64, base_ks=3, deform_ks=3)
        self.rm = RM()

    def forward(self, x):  # todo x = [B, C, T, H, W]
        _, _, T, _, _ = x.unsqueeze(1).size()
        # Coarse Fusion Module
        out = self.cfm(x.unsqueeze(1))
        # Multi-level Residual Fusion Module
        out = self.mlrf(out)
        # DCN
        out = self.dcn(out, x)
        out = self.rm(out)
        out += x[:, [T // 2], ...]
        return out


  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:30:27  更:2022-03-12 17:34:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 16:18:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码