news 2026/6/15 19:37:41

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/6/15 18:35:08

Python+hadoop+spark商品数据分析及预测系统 机器学习 预测算法预测销量

1、项目介绍 技术栈:python语言、Django框架、Echarts可视化、机器学习随机森林预测算法预测销量、爬虫、HTML Python 商品数据分析及预测系统介绍 本 Python 商品数据分析及预测系统,以 Python 语言为开发核心,依托 Django 框架搭建稳定后端…

作者头像 李华
网站建设 2026/6/15 14:09:52

期货策略回测精度对比_Tick级和K线级回测实测体验

免责声明:本文基于个人使用体验,与任何厂商无商业关系。文中内容仅供技术交流参考,不构成投资建议。 一、为什么要关注回测精度? 从2005年接触程序化交易算起,我在这个行业已经摸爬滚打了将近二十年。这些年里&#x…

作者头像 李华
网站建设 2026/6/10 18:33:01

期货量化策略优化经验_如何识别和避免过拟合

免责声明:本文基于个人学习经验整理,仅供技术交流参考,不构成投资建议。 一、什么是过拟合? 作为一名在期货量化领域深耕了二十年的老交易员,我见过太多人栽在"过拟合"这个坑里。 所谓过拟合(O…

作者头像 李华
网站建设 2026/6/15 14:58:45

基于单片机的自动感应门设计

博主主页:单片机辅导设计 博主简介:专注单片机技术领域和毕业设计项目。 主要内容:毕业设计、简历模板、学习资料、技术咨询。 文章目录 主要介绍一、自动感应门设计的功能概述二、系统总体方案2.1系统的总体计划2.2元器件的介绍2.2.1单片机的…

作者头像 李华
网站建设 2026/6/15 8:15:08

Spring纯注解开发,有点强!!

01 前言 Spring3.0引入了纯注解开发的模式,框架的诞生是为了简化开发,那注解开发就是简化再简化。Spring的特性在整合MyBatis方面体现的淋漓尽致哦 02 注解开发 以前跟老韩学习SE时他就说: 注解本质是一个继承了Annotation 的特殊接口,其具…

作者头像 李华
网站建设 2026/6/15 13:49:00

2026年TOP8款好用预约二维码推荐榜单

在2026年,预约二维码工具的使用变得更加广泛,能够为各行各业带来便利。用户不仅可以通过这些二维码收集姓名、电话和预约时间,还能利用库存量设置功能,有效管理预约信息。这对于教育机构、企业宣传以及医疗服务等领域尤为重要。 这…

作者头像 李华