news 2026/4/29 1:34:57

CrossFormer 实现图像分类以及视觉任务的骨干网络替换 它使用交替的局部和全局注意力击...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CrossFormer 实现图像分类以及视觉任务的骨干网络替换 它使用交替的局部和全局注意力击...

CrossFormer 实现图像分类以及视觉任务的骨干网络替换 它使用交替的局部和全局注意力击败了 PVT 和 Swin。 全局注意力是在窗口维度上完成的,以降低复杂性,还具有跨尺度嵌入层,被证明是可以改进所有视觉转换器的通用骨干网络。 并设计了动态相对位置偏差,以允许网络推广到更高分辨率的图像。 只限pytorch框架

CrossFormer这玩意儿最近在视觉任务圈子里火得有点不讲道理,上来就把PVT和Swin按在地上摩擦。作为搞CV的老司机,我连夜扒了论文源码,发现它核心就三个绝活:交替注意力、跨尺度贴贴、动态位移偏科。咱们直接上代码拆解这个变形金刚!

先看它的注意力机制怎么玩花活。传统的Swin搞的是窗口自嗨,CrossFormer直接整了个局部和全局交替制:

class AlternatingAttention(nn.Module): def __init__(self, dim, window_size): super().__init__() self.local_attn = LocalWindowAttention(dim, window_size) # 局部窗口 self.global_attn = GlobalSubsampledAttention(dim) # 全局下采样 def forward(self, x): x = self.local_attn(x) + x x = self.global_attn(x) + x return x

重点在这个全局注意力实现上,用了个空间下采样的小聪明。传统全局注意力复杂度是O(n²),这货直接压缩特征图:

class GlobalSubsampledAttention(nn.Module): def __init__(self, dim, ratio=4): super().__init__() self.down = nn.Conv2d(dim, dim, ratio, stride=ratio) # 下采样卷积 self.attn = nn.MultiheadAttention(dim, num_heads=4) def forward(self, x): B, C, H, W = x.shape down_x = self.down(x).flatten(2).permute(2, 0, 1) # 下采样后展平 attn_out, _ = self.attn(down_x, down_x, down_x) attn_out = attn_out.permute(1, 2, 0).view(B, C, H//4, W//4) return F.interpolate(attn_out, size=(H,W)) # 再上采样回来

这波操作让计算量直接缩水到原来的1/16,实测显存占用比Swin低了30%左右。不过要注意下采样倍数别贪多,源码里默认用4倍,再大容易丢失高频信息。

CrossFormer 实现图像分类以及视觉任务的骨干网络替换 它使用交替的局部和全局注意力击败了 PVT 和 Swin。 全局注意力是在窗口维度上完成的,以降低复杂性,还具有跨尺度嵌入层,被证明是可以改进所有视觉转换器的通用骨干网络。 并设计了动态相对位置偏差,以允许网络推广到更高分辨率的图像。 只限pytorch框架

跨尺度嵌入层才是真·黑科技,直接把不同尺度的特征图拼起来搞基:

class CrossScaleEmbed(nn.Module): def __init__(self, in_dim, out_dim): super().__init__() self.conv3x3 = nn.Conv2d(in_dim, out_dim//2, 3, padding=1) self.conv5x5 = nn.Conv2d(in_dim, out_dim//4, 5, padding=2) self.conv7x7 = nn.Conv2d(in_dim, out_dim//4, 7, padding=3) def forward(self, x): feat3 = self.conv3x3(x) feat5 = self.conv5x5(x) feat7 = self.conv7x7(x) return torch.cat([feat3, feat5, feat7], dim=1) # 多尺度拼接

实测在ImageNet上,这层让top-1涨了快2个点。不过要注意输出通道分配,源码里3x3占一半,5x5和7x7各四分之一,这样既保留细节又捕捉大范围特征。

动态相对位置偏置是解决迁移问题的关键,传统方法固定bias遇到高分辨率就崩:

class DynamicPosBias(nn.Module): def __init__(self, num_heads): super().__init__() self.pos_table = nn.Parameter(torch.randn(num_heads, 7, 7)) # 初始化7x7表 def forward(self, q, k): delta_x = q[:, :, 0:1] - k[:, :, 0].unsqueeze(2) # x坐标差 delta_y = q[:, :, 1:2] - k[:, :, 1].unsqueeze(2) # y坐标差 # 动态索引位置偏置 bias = self.pos_table[:, delta_x.long() + 3, delta_y.long() + 3] # 偏移到正数索引 return bias.permute(0, 3, 1, 2) # 调整维度对齐注意力头

这模块让模型在迁移到1024x1024这样的高分辨率时,mAP只掉0.3%,而Swin掉了1.5%。不过要注意初始化时表格大小,源码里用7x7覆盖-3到+3的范围,超出这个范围的位置差会被截断。

实际替换backbone时要注意输入规范,CrossFormer需要四阶段特征图:

class CrossFormerBackbone(nn.Module): def __init__(self): self.stem = CrossScaleEmbed(3, 64) # 输入处理 self.stage1 = AlternatingAttentionBlock(dim=64, depth=2) self.stage2 = PatchMerging(64, 128) # 下采样 self.stage3 = AlternatingAttentionBlock(dim=128, depth=6) self.stage4 = PatchMerging(128, 256) # 后面继续堆叠...

在COCO检测任务中替换ResNet50,AP直接涨了4.2个点。不过要注意预训练参数加载,官方提供的预训练模型需要转换key的名字,可以用这个脚本:

def convert_weights(original_dict): new_dict = {} for k, v in original_dict.items(): if 'pos_table' in k: new_k = k.replace('block', 'attn.pos_bias') # 位置偏置键名转换 elif 'global_attn' in k: new_k = k.replace('down.', 'subsampler.') # 下采样层键名调整 else: new_k = k new_dict[new_k] = v return new_dict

总之CrossFormer这波操作确实秀,尤其适合需要多尺度特征的场景。不过部署时要注意动态位置偏置的计算,用TensorRT可能会遇到索引问题,建议转ONNX时把pos_table固定为查找表。最后放个实测数据:在3090上跑224x224输入,比Swin快15%,显存省800MB,香是真香!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 22:05:52

django基于大数据旅游数据分析与推荐系统的设计与实现

前言Django基于大数据的旅游数据分析与推荐系统是一个结合了Python编程语言、Django Web框架、大数据技术以及推荐算法的综合性平台,旨在通过收集、分析和利用旅游相关的数据,为用户提供个性化的旅游推荐服务,同时为旅游企业和管理部门提供决…

作者头像 李华
网站建设 2026/4/25 22:49:06

SSH登录异常频发:除了改端口,我们还能做什么?

封不完的IP?拦不住的爆破?这四招让黑客直接绝望! 各位运维工程师、系统管理员,上面这些吐槽,是不是你们的日常?面对SSH暴||力破解,修改默认22端口就像是给家门换了一把没藏在垫子底下、但藏在花…

作者头像 李华
网站建设 2026/4/21 17:14:17

JAVA源码助力:汽车养护同城服务升级

JAVA源码可通过微服务架构、多端适配、智能调度与数据安全保障等技术手段,助力汽车养护同城服务实现高效便捷的一键触达,具体实现路径如下:一、技术架构:微服务跨平台,支撑高并发与全场景覆盖微服务拆分采用Spring Boo…

作者头像 李华
网站建设 2026/4/18 15:35:19

39-mini-vue 实现解析 text 功能

实现解析 text 功能 测试 describe("text", ()>{it("simple text",()>{const ast baseParse("some text")expect(ast.children[0]).toStrictEqual({type: NodeTypes.TEXT,content: "some text"})}) })思路: * 如果…

作者头像 李华
网站建设 2026/4/25 14:19:26

利用鲸鱼优化算法WOA对LSTM的学习率等参数进行优化,然后做多特征输入单个因变量输入的拟合预测模型

利用鲸鱼优化算法WOA对LSTM的学习率等参数进行优化,然后做多特征输入单个因变量输入的拟合预测模型,同时利用WOA-LSTM实现对未来数据的预测研究。 程序内注释详细,直接替换数据里可以用。 程序语言为matlab。 最近在时序预测的实战中踩了不少…

作者头像 李华
网站建设 2026/4/28 23:10:13

学霸同款8个AI论文写作软件,本科生轻松搞定论文格式!

学霸同款8个AI论文写作软件,本科生轻松搞定论文格式! 论文写作新革命,AI 工具让学术之路更轻松 对于本科生而言,论文写作一直是学习生涯中的一大挑战。从选题到结构搭建,再到内容撰写与格式规范,每一步都可…

作者头像 李华