Day 42 通道注意力

@浙大疏锦行

  • CNN 有很多卷积核,输出很多通道(特征图)
  • 有的通道很重要(比如边缘、纹理)
  • 有的通道没用
  • 通道注意力就是:自动给每个通道算一个权重,重要的通道权重变大,不重要的变小

SE 通道注意力(Squeeze-and-Excitation)

最常用、最简单、效果最好的通道注意力。

结构只有 3 步:

  1. Squeeze(压缩):对每个通道做全局平均池化 → 得到 1×1×C
  2. Excitation(激励):两层全连接 + Sigmoid → 得到每个通道的权重
  3. Scale(缩放):权重 × 原特征 → 强化重要通道
python 复制代码
import torch
import torch.nn as nn
import torch.nn.functional as F

# ===================== 通道注意力(SE Block) =====================
class SEBlock(nn.Module):
    def __init__(self, in_channels, reduction=16):
        super(SEBlock, self).__init__()
        # 1. 全局平均池化 → (B, C, 1, 1)
        self.avg_pool = nn.AdaptiveAvgPool2d(1)
        
        # 2. 两层全连接学习通道权重
        self.fc = nn.Sequential(
            nn.Linear(in_channels, in_channels // reduction),
            nn.ReLU(inplace=True),
            nn.Linear(in_channels // reduction, in_channels),
            nn.Sigmoid()
        )

    def forward(self, x):
        batch, C, H, W = x.size()
        
        # Squeeze
        out = self.avg_pool).view(batch, C)
        
        # Excitation
        weight = self.fc(out).view(batch, C, 1, 1)
        
        # 原特征 × 权重
        return x * weight

通道注意力的好处

  • 几乎不增加计算量
  • 即插即用,所有 CNN 都能加
  • 分类、检测、分割 全都能涨点
  • 配合 ResNet、MobileNet、自己的小 CNN 都极强
相关推荐
九硕智慧建筑一体化厂家1 小时前
什么是楼宇自控?全面解析楼宇自控与楼宇自控系统的作用
大数据·运维·人工智能·网络协议·制造
大连好光景2 小时前
不同任务场景下的模型选择
深度学习·机器学习
Dxy12393102162 小时前
深度学习的优雅收尾:PyTorch中PolynomialLR的终极指南
人工智能·pytorch·深度学习
云境筑桃源哇2 小时前
极光EngageLab 发布 OpenClaw Skills
人工智能
tjl521314_212 小时前
深度学习与医学图像分割论文写作:统一符号、公式与 LaTeX 规范(附模板)
人工智能·深度学习
csdn_aspnet2 小时前
使用 C# 和 Microsoft Agent Framework 构建 AI 代理
人工智能·microsoft·ai·c#·.net·agent·ai agent
AC赳赳老秦2 小时前
2026多智能体协同趋势:DeepSeek搭建多智能体工作流,实现复杂任务自动化
人工智能·python·microsoft·云原生·virtualenv·量子计算·deepseek
njsgcs2 小时前
我要让ai理解3d模型,什么孔面是装轴承,什么面是攻牙孔,什么面是轴面,区分从动轮主动轮
人工智能
猫头_2 小时前
RAG 全链路深度拆解:“大白”学习RAG的极简指南
人工智能·langchain·llm