PVT:Pyramid Vision Transformer 能接受高分图像的Transformer骨干网

参考资料

https://blog.youkuaiyun.com/weixin_44966641/article/details/118733341
http://jalammar.github.io/illustrated-transformer/
https://www.cnblogs.com/jins-note/p/14815511.html

Transformer结构

Encoder-Decoder

Transformer结构可以表示为Encoder和Decoder两个部分。Encoder和Decoder主要由Self-Attention和Feed-Forward Network两个组件构成,Self-Attention由Scaled Dot-Product Attention和Multi-Head Attention两个组件构成。
Scaled Dot-Product Attention公式:

Multi-Head Attention公式:

Feed-Forward Network公式:

Positional Encoding

对位置编码,加入到Embedding的向量上。

Self Attention

Scaled Dot-Product Attention

点积Attention
公式

Multi-Head Attention

多头AttentionScaled Dot-Product Attention和Multi-Head Attention都加入了short-cut机制

论文总结

In short

QKV使得attention map计算复杂度和显存使用量呈平方O(n^2)增大,使用SRA对其KV的特征图进行限制

论文原文

公式

Self-Attention 使用矩阵点乘进行的余弦相似度计算

QKV是什么

Querys Keys Values

### Pyramid Vision Transformer (PVT) 介绍 Pyramid Vision Transformer (PVT) 是一种用于计算机视觉任务的新型骨干网络架构,旨在替代传统的卷积神经网络(CNN)[^1]。该模型通过多尺度特征提取来增强对不同大小目标物体的理解能力。 #### 整体结构概述 整体上,PVT采用了金字塔式的分层设计,每一层都由若干个Transformer编码器构成[^2]。这种层次化的构建方法允许模型在同一时间处理来自多个分辨率下的输入数据,从而提高了对于复杂场景下细节信息捕捉的能力。 ```python class PyramidVisionTransformer(nn.Module): def __init__(self, img_size=224, patch_size=16, in_chans=3, num_classes=1000, embed_dims=[64, 128, 256, 512], depths=[3, 4, 6, 3], num_heads=[1, 2, 4, 8], mlp_ratios=[4, 4, 4, 4], qkv_bias=True, norm_layer=nn.LayerNorm, drop_rate=0., attn_drop_rate=0., drop_path_rate=0.1, pretrained=None): super().__init__() self.num_stages = len(depths) dpr = [x.item() for x in torch.linspace(0, drop_path_rate, sum(depths))] cur = 0 for i in range(self.num_stages): patch_embed = PatchEmbed( img_size=img_size if isinstance(img_size, int) else img_size[i], patch_size=patch_size if isinstance(patch_size, int) else patch_size[i], in_chans=in_chans if isinstance(in_chans, int) else in_chans[i], embed_dim=embed_dims[i]) block = nn.ModuleList([Block( dim=embed_dims[i], num_heads=num_heads[i], mlp_ratio=mlp_ratios[i], qkv_bias=qkv_bias, drop=drop_rate, attn_drop=attn_drop_rate, drop_path=dpr[cur + j]) for j in range(depths[i])]) setattr(self, f"patch_embed{i + 1}", patch_embed) setattr(self, f"block{i + 1}", block) cur += depths[i] self.norm = norm_layer(embed_dims[-1]) ``` 此代码片段展示了`PyramidVisionTransformer`类初始化函数的一部分逻辑,定义了各个阶段中的嵌入维度、深度以及其他超参数设置[^3]。 #### 应用领域 除了作为图像分类的基础框架外,PVT还被广泛应用于其他多种密集预测任务中,比如语义分割、对象检测等。这些应用场景得益于其强大的表征学习能力和灵活性,在不依赖于传统CNN操作的情况下实现了优异的表现效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值