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 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Learning Spatial Fusion for Single-Shot Object Detection -> 正文阅读

[人工智能]Learning Spatial Fusion for Single-Shot Object Detection

论文地址:https://arxiv.org/pdf/1911.09516v2.pdf
源码链接:https://github.com/ruinmessi/ASFF
金字塔特征表示是解决目标检测中尺度变化问题的常用方法。然而,不同特征尺度之间的不一致性是基于特征金字塔的检测器的主要限制。在这项工作中,作者提出了一种新的数据驱动的金字塔特征融合策略,称为自适应空间特征融合(ASFF)。它学习了空间过滤冲突信息以抑制不一致性的方法,从而提高了特征的尺度不变性。以解决单级检测器特征金字塔中的不一致性
所提出的方法使网络能够直接学习如何在其他层次上对特征进行空间过滤,从而只保留有用的信息进行组合。对于某一级别的特征,其他级别的特征首先被集成并调整为相同的分辨率,然后进行训练以找到最佳融合。在每个空间位置,不同级别的特征会自适应地融合,也就是说,一些特征可能会被过滤掉,因为它们在该位置携带矛盾的信息,而一些特征可能会以更具辨别力的线索占据主导地位。
ASFF具有以下优点
(1)由于搜索最优融合的操作是差分的,因此可以方便地在反向传播中学习;
(2) 它与主干模型无关,适用于具有特征金字塔结构的单级探测器;
(3)实现简单,增加的计算量很小。

一、Strong Baseline

在这里插入图片描述
与以往的基于元素求和或级联的多层次特征融合方法不同,本文的关键思想是自适应地学习各尺度特征图融合的空间权重。如↑图所示,它包括两个步骤:相同的尺度缩放和自适应融合。
x l x^l xl表示l级分辨率的特征(l∈ {1,2,3})。对于l级,将另一个n级(N不等于l)的特征 x n x^n xn调整为与 x l x^l xl相同的形状。由于YOLOv3中三个级别的特征具有不同的分辨率和不同的通道数,因此相应地修改了每个级别的上采样和下采样策略。对于上采样,首先使用1×1卷积层将特征的通道数压缩到l级,然后通过插值分别提高分辨率。对于1/2比率的下采样,只需使用3×3卷积层,步幅为2,即可同时修改通道数和分辨率。对于1/4的比例,在步长为2的卷积之前添加了一个步长为2的最大池层。
自适应融合 x i j n → l x^{n→l}_{ij} xijnl?表示从n级调整到l级的特征图上位置(i,j)处的特征向量。建议在相应的l级融合特征,如下所示:
在这里插入图片描述

其中, y i j l y^l_{ij} yijl?表示通道之间输出特征映射yl的第(i,j)个向量。 α i j l α^l_{ij} αijl? β i j l β^l_{ij} βijl? γ i j l γ^l_{ij} γijl?是三个不同级别到l级别的特征图的空间重要性权重,由网络自适应学习。注意,α和γ都是简单的变量。受的启发,令 α i j l α^l_{ij} αijl?+ β i j l β^l_{ij} βijl?+ γ i j l γ^l_{ij} γijl?=1和 α i j l α^l_{ij} αijl? β i j l β^l_{ij} βijl? γ i j l γ^l_{ij} γijl?∈ [0,1],并定义:
在这里插入图片描述
这里, α i j l α^l_{ij} αijl? β i j l β^l_{ij} βijl? γ i j l γ^l_{ij} γijl?分别以 λ α i j l λ^l_{α_{ij}} λαij?l? λ l β i j λ^l{β_{ij}} λlβij? λ γ i j l λ^l_{γ_{ij}} λγij?l?作为控制参数,通过使用softmax函数来定义。使用1×1卷积层从 x 1 → l x^{1→l} x1l x 2 → l x^{2→l} x2l x 3 → l x^{3→l} x3l计算权重标量映射 λ α l λ^l_α λαl? λ β l λ^l_β λβl? λ γ l λ^l_γ λγl?,因此可以通过标准的反向传播来学习。
通过这种方法,在每个尺度上自适应地聚合所有级别的特征。输出{y1,y2,y3} 用于目标检测.

二、Consistency Property

根据链式规则,ASFF梯度计算如下:
在这里插入图片描述
值得注意的是,特征尺寸调整通常使用插值进行上采样,使用池化进行下采样。因此,假设 ? x i j 1 → l / ? x i j 1 ≈ 1 ?^{1→l}_{x_{ij}}/?^1_{x_{ij}}≈ 1 ?xij?1l?/?xij?1?1.为了简单起见。那么等式(3)可以写成:
在这里插入图片描述
对于基于金字塔特征的检测器(即元素求和和级联)中使用的两种常见融合操作,可以使用 ? y i j 1 / ? x i j 1 = 1 ?^{1}_{y_{ij}}/?^1_{x_{ij}}= 1 ?yij?1?/?xij?1?=1 ? x i j 1 / ? x i j 1 → l = 1 ?^1_{x_{ij}}/?^{1→l}_{x_{ij}}= 1 ?xij?1?/?xij?1l?=1
在这里插入图片描述
假设根据一定的比例匹配机制,将level1处的位置(i,j)指定为对象的中心并且 ? L / ? y i j 1 ?L/?y^1_{ij} ?L/?yij1?是来自阳性样本的梯度。由于相应的位置在其他级别被视为背景, ? L / ? y i j 2 ?L/?y^2_{ij} ?L/?yij2? ? L / ? y i j 3 ?L/?y^3_{ij} ?L/?yij3?是来自负样本的梯度。这种不一致性扰乱了梯度 ? L / ? y i j 1 ?L/?y^1_{ij} ?L/?yij1?并降低原始特征映射 x 1 x^1 x1的训练效率。

处理此问题的一种典型方法是将其他级别的相应位置设置为忽略区域(即。 ? L / ? y i j 2 ?L/?y^2_{ij} ?L/?yij2?= ? L / ? y i j 3 = 0 ?L/?y^3_{ij}=0 ?L/?yij3?=0。然而,尽管 x i j 1 x^1_{ij} xij1?中的冲突已被消除,但 y i j 2 y^2_{ij} yij2? y i j 3 y^3_{ij} yij3?的消散往往会导致更差的预测。
对于ASFF,如下所示:
在这里插入图片描述
式中 α i j 1 , α i j 2 , α i j 3 ∈ [ 0 , 1 ] α^1_{ij},α^2_{ij},α^3_{ij}∈ [0, 1] αij1?αij2?αij3?[0,1]. 利用这三个系数,如果 α i j 2 α^2_{ij} αij2?→ 0和 α i j 3 α^3_{ij} αij3?→ 0.由于融合参数可以通过标准的反向传播算法学习,经过良好调整的训练过程可以产生有效系数。同时,监管信息的背景在 y i j 2 y^2_{ij} yij2? y i j 3 y^3_{ij} yij3?被保留,避免产生更多误报。

三、参数训练策略

Θ Θ Θ表示网络参数集(例如卷积滤波器的权重), Φ = λ α l , λ β l , λ γ l ∣ l = 1 , 2 , 3 Φ={λ^l_α,λ^l_β,λ^l_γ| l=1,2,3} Φ=λαl?λβl?λγl?l=123是控制每个尺度的空间融合的融合参数集。通过最小化损失函数 L ( Θ , Φ L(Θ,Φ LΘΦ)来联合优化这两组参数,其中 L L L是原始YOLOv3目标函数加上anchor shape预测和bounding box回归的IoU回归损失。对DarkNet53的分类预训练应用了 mixup,所有新的卷积层都采用了MSRA权重初始化方法。为了减少过度拟合的风险并提高网络预测的泛化,采用了YOLOv3中的多尺度训练方法。更具体地说,将N个训练图像的小批量调整为N×3×H×W,其中H=W在{320、352、384、416、448、480、512、544、576、608}中随机选取。
消融实验:
在这里插入图片描述
在这里插入图片描述
ASSF源码:

class ASFFmobile(nn.Module):
    def __init__(self, level, rfb=False, vis=False):
        super(ASFFmobile, self).__init__()
        # 定义ASSF的尺度级别
        self.level = level
        # 定ASFF不同级别的通道数量
        self.dim = [512, 256, 128]
        # 指定特定级别的通道数量
        self.inter_dim = self.dim[self.level]
        if level==0:
        #先通过3*3步长为2的卷积核进行下采样并且降维后通过3*3的卷积对通道进行调整
            self.stride_level_1 = add_conv(256, self.inter_dim, 3, 2, leaky=False)
            self.stride_level_2 = add_conv(128, self.inter_dim, 3, 2, leaky=False)
            self.expand = add_conv(self.inter_dim, 1024, 3, 1, leaky=False)
        elif level==1:
            self.compress_level_0 = add_conv(512, self.inter_dim, 1, 1, leaky=False)
            self.stride_level_2 = add_conv(128, self.inter_dim, 3, 2, leaky=False)
            self.expand = add_conv(self.inter_dim, 512, 3, 1, leaky=False)
        elif level==2:
            self.compress_level_0 = add_conv(512, self.inter_dim, 1, 1, leaky=False)
            self.compress_level_1 = add_conv(256, self.inter_dim, 1, 1, leaky=False)
            self.expand = add_conv(self.inter_dim, 256, 3, 1,leaky=False)

        compress_c = 8 if rfb else 16  #when adding rfb, we use half number of channels to save memory
		#1*1的卷积为不同等级的权重
        self.weight_level_0 = add_conv(self.inter_dim, compress_c, 1, 1, leaky=False)
        self.weight_level_1 = add_conv(self.inter_dim, compress_c, 1, 1, leaky=False)
        self.weight_level_2 = add_conv(self.inter_dim, compress_c, 1, 1, leaky=False)

        self.weight_levels = nn.Conv2d(compress_c*3, 3, kernel_size=1, stride=1, padding=0)
        self.vis= vis


    def forward(self, x_level_0, x_level_1, x_level_2):
        if self.level==0:
            level_0_resized = x_level_0
            level_1_resized = self.stride_level_1(x_level_1)  #下采样并降低通道

            level_2_downsampled_inter =F.max_pool2d(x_level_2, 3, stride=2, padding=1)  
            level_2_resized = self.stride_level_2(level_2_downsampled_inter)

        elif self.level==1:
            level_0_compressed = self.compress_level_0(x_level_0)
            level_0_resized =F.interpolate(level_0_compressed, scale_factor=2, mode='nearest')
            level_1_resized =x_level_1
            level_2_resized =self.stride_level_2(x_level_2)
        elif self.level==2:
            level_0_compressed = self.compress_level_0(x_level_0)
            level_0_resized =F.interpolate(level_0_compressed, scale_factor=4, mode='nearest')
            level_1_compressed = self.compress_level_1(x_level_1)
            level_1_resized =F.interpolate(level_1_compressed, scale_factor=2, mode='nearest')
            level_2_resized =x_level_2

        level_0_weight_v = self.weight_level_0(level_0_resized)
        level_1_weight_v = self.weight_level_1(level_1_resized)
        level_2_weight_v = self.weight_level_2(level_2_resized)
        levels_weight_v = torch.cat((level_0_weight_v, level_1_weight_v, level_2_weight_v),1)
        levels_weight = self.weight_levels(levels_weight_v)
        levels_weight = F.softmax(levels_weight, dim=1)

        fused_out_reduced = level_0_resized * levels_weight[:,0:1,:,:]+\
                            level_1_resized * levels_weight[:,1:2,:,:]+\
                            level_2_resized * levels_weight[:,2:,:,:]

        out = self.expand(fused_out_reduced)
		#是否对结果进行可视化
        if self.vis:
            return out, levels_weight, fused_out_reduced.sum(dim=1)
        else:
            return out
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:31:02  更:2022-03-10 22:32:47 
 
开发: 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:41:08-

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