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 都极强
相关推荐
冬奇Lab1 小时前
Workflow 系列(06):安全——跨步骤注入传播与四层防御
人工智能·工作流引擎
冬奇Lab1 小时前
每日一个开源项目(第149篇):RAG-Anything - 把图片、表格、公式当成一等公民的多模态 RAG 框架
人工智能·开源
米小虾1 小时前
AI Agent 安全实战指南:当智能体开始"不听话",开发者该如何应对?
人工智能·安全·agent
IT_陈寒3 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
阿里云大数据AI技术5 小时前
构建高转化海外电商搜索:阿里云OpenSearch行业算法版的全链路智能优化策略实战
人工智能·搜索引擎
Awu12275 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
字节跳动视频云技术团队5 小时前
让 Agent 成为音视频工作台:AI MediaKit CLI + Skill 发布
人工智能·音视频开发
魏祖潇5 小时前
framework 整合实战——DDD/TDD/SDD 三件套在 framework 仓的真实落地
人工智能·后端
Token炼金师6 小时前
去噪扩散:从随机噪声到高保真图像的数学之路
人工智能·aigc