<img src="./images/vit.gif" width="500px"></img>
## Table of Contents
- [Vision Transformer - Pytorch](#vision-transformer---pytorch)
- [Install](#install)
- [Usage](#usage)
- [Parameters](#parameters)
- [Simple ViT](#simple-vit)
- [NaViT](#navit)
- [Distillation](#distillation)
- [Deep ViT](#deep-vit)
- [CaiT](#cait)
- [Token-to-Token ViT](#token-to-token-vit)
- [CCT](#cct)
- [Cross ViT](#cross-vit)
- [PiT](#pit)
- [LeViT](#levit)
- [CvT](#cvt)
- [Twins SVT](#twins-svt)
- [CrossFormer](#crossformer)
- [RegionViT](#regionvit)
- [ScalableViT](#scalablevit)
- [SepViT](#sepvit)
- [MaxViT](#maxvit)
- [NesT](#nest)
- [MobileViT](#mobilevit)
- [XCiT](#xcit)
- [Masked Autoencoder](#masked-autoencoder)
- [Simple Masked Image Modeling](#simple-masked-image-modeling)
- [Masked Patch Prediction](#masked-patch-prediction)
- [Masked Position Prediction](#masked-position-prediction)
- [Adaptive Token Sampling](#adaptive-token-sampling)
- [Patch Merger](#patch-merger)
- [Vision Transformer for Small Datasets](#vision-transformer-for-small-datasets)
- [3D Vit](#3d-vit)
- [ViVit](#vivit)
- [Parallel ViT](#parallel-vit)
- [Learnable Memory ViT](#learnable-memory-vit)
- [Dino](#dino)
- [EsViT](#esvit)
- [Accessing Attention](#accessing-attention)
- [Research Ideas](#research-ideas)
* [Efficient Attention](#efficient-attention)
* [Combining with other Transformer improvements](#combining-with-other-transformer-improvements)
- [FAQ](#faq)
- [Resources](#resources)
- [Citations](#citations)
## Vision Transformer - Pytorch
Implementation of <a href="https://openreview.net/pdf?id=YicbFdNTTy">Vision Transformer</a>, a simple way to achieve SOTA in vision classification with only a single transformer encoder, in Pytorch. Significance is further explained in <a href="https://www.youtube.com/watch?v=TrdevFK_am4">Yannic Kilcher's</a> video. There's really not much to code here, but may as well lay it out for everyone so we expedite the attention revolution.
For a Pytorch implementation with pretrained models, please see Ross Wightman's repository <a href="https://github.com/rwightman/pytorch-image-models">here</a>.
The official Jax repository is <a href="https://github.com/google-research/vision_transformer">here</a>.
A tensorflow2 translation also exists <a href="https://github.com/taki0112/vit-tensorflow">here</a>, created by research scientist <a href="https://github.com/taki0112">Junho Kim</a>! 🙏
<a href="https://github.com/conceptofmind/vit-flax">Flax translation</a> by <a href="https://github.com/conceptofmind">Enrico Shippole</a>!
## Install
```bash
$ pip install vit-pytorch
```
## Usage
```python
import torch
from vit_pytorch import ViT
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(1, 3, 256, 256)
preds = v(img) # (1, 1000)
```
## Parameters
- `image_size`: int.
Image size. If you have rectangular images, make sure your image size is the maximum of the width and height
- `patch_size`: int.
Size of patches. `image_size` must be divisible by `patch_size`.
The number of patches is: ` n = (image_size // patch_size) ** 2` and `n` **must be greater than 16**.
- `num_classes`: int.
Number of classes to classify.
- `dim`: int.
Last dimension of output tensor after linear transformation `nn.Linear(..., dim)`.
- `depth`: int.
Number of Transformer blocks.
- `heads`: int.
Number of heads in Multi-head Attention layer.
- `mlp_dim`: int.
Dimension of the MLP (FeedForward) layer.
- `channels`: int, default `3`.
Number of image's channels.
- `dropout`: float between `[0, 1]`, default `0.`.
Dropout rate.
- `emb_dropout`: float between `[0, 1]`, default `0`.
Embedding dropout rate.
- `pool`: string, either `cls` token pooling or `mean` pooling
## Simple ViT
<a href="https://arxiv.org/abs/2205.01580">An update</a> from some of the same authors of the original paper proposes simplifications to `ViT` that allows it to train faster and better.
Among these simplifications include 2d sinusoidal positional embedding, global average pooling (no CLS token), no dropout, batch sizes of 1024 rather than 4096, and use of RandAugment and MixUp augmentations. They also show that a simple linear at the end is not significantly worse than the original MLP head
You can use it by importing the `SimpleViT` as shown below
```python
import torch
from vit_pytorch import SimpleViT
v = SimpleViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048
)
img = torch.randn(1, 3, 256, 256)
preds = v(img) # (1, 1000)
```
## NaViT
<img src="./images/navit.png" width="450px"></img>
<a href="https://arxiv.org/abs/2307.06304">This paper</a> proposes to leverage the flexibility of attention and masking for variable lengthed sequences to train images of multiple resolution, packed into a single batch. They demonstrate much faster training and improved accuracies, with the only cost being extra complexity in the architecture and dataloading. They use factorized 2d positional encodings, token dropping, as well as query-key normalization.
You can use it as follows
```python
import torch
from vit_pytorch.na_vit import NaViT
v = NaViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1,
token_dropout_prob = 0.1 # token dropout of 10% (keep 90% of tokens)
)
# 5 images of different resolutions - List[List[Tensor]]
# for now, you'll have to correctly place images in same batch element as to not exceed maximum allowed sequence length for self-attention w/ masking
images = [
[torch.randn(3, 256, 256), torch.randn(3, 128, 128)],
[torch.randn(3, 128, 256), torch.randn(3, 256, 128)],
[torch.randn(3, 64, 256)]
]
preds = v(images) # (5, 1000) - 5, because 5 images of different resolution above
```
Or if you would rather that the framework auto group the images into variable lengthed sequences that do not exceed a certain max length
```python
images = [
torch.randn(3, 256, 256),
torch.randn(3, 128, 128),
torch.randn(3, 128, 256),
torch.randn(3, 256, 128),
torch.randn(3, 64, 256)
]
preds = v(
images,
group_images = True,
group_max_seq_len = 64
) # (5, 1000)
```
Finally, if you would like to make use of a flavor of NaViT using <a href="https://pytorch.org/tutorials/prototype/nestedtensor.html">nested tensors</a> (which will omit a lot of the masking and padding altogether), make sure you are on version `2.4` and import as follows
```python
import torch
from vit_pytorch.na_vit_nested_tensor import NaViT
v = NaViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.,
emb_dropout = 0.,
token_dropout_prob = 0.1
)
# 5 images of different resolutions - List[Tensor]
images = [
torch.randn(3, 256, 256), torch.randn(3, 128, 128),
torch.randn(3, 128, 256), torch.randn(3, 256, 128),
torch.randn(3, 64, 256)
]
preds = v(images)
assert preds.shape == (5, 1000)
```
## Distillation
<img src="./images/distill.png" width="300px"></img>
A recent <a href="https://arxiv.org/abs/2012.12877">paper</a> has shown that use of a distillation token for distilling knowledge from convolutional nets to vision transformer can yield small and efficient vision transformers. This repository offers the means to do distillation easily.
ex. distilling from Resnet50 (or any teacher) to a vision transformer
```python
import torch
from torchvision.models import resnet50
from vit_pytorch.distill import DistillableViT, DistillWrapper
teacher = resnet50(pretrained = True)
v = DistillableViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
distiller = DistillWrapper(
student = v,
teacher = teacher,
temperature = 3, # temperature of distillation
alpha = 0.5, # trade between main loss and distillation loss
hard = False # whether to use soft or hard distillation
)
img = torch.randn(2, 3, 256, 256)
labels = torch.randint(0, 1000, (2,))
loss = distiller(img, labels)
loss.backward()
# after lots of training above ...
pred = v(img) # (2, 1000)
```
The `DistillableViT` class is identical to `ViT` except for how the forward pass is handled, so you should be able to load the parameters back to `ViT` after you have completed distillation training.
You can also use the handy `.to_vit` method on the `DistillableViT` instance to get back a `ViT` instance.
```python
v = v.to_vit()
type(v) # <class 'vit_pytorch.vit_pytorch.ViT'>
```
## Deep ViT
This <a href="https://arxiv.org/abs/2103.11886">paper</a> notes that ViT struggles to attend at greater depths (past 12 layers), and suggests mixing the attention of each head post-softmax as a solution, dubbed Re-attention. The results line up with the <a href="https://github.com/lucidrains/x-transformers#talking-heads-attention">Talking Heads</a> paper from NLP.
You can use it as follows
```python
import torch
from vit_pytorch.deepvit import DeepViT
v = DeepViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(1, 3, 256, 256)
preds = v(img) # (1, 1000)
```
## CaiT
<a href="https://arxiv.org/abs/2103.17239">This paper</a> also notes difficulty in training vision transformers at greater depths and proposes two solutions. First it proposes to do per-channel multiplication of the output of the residual block. Second, it proposes to have the patches attend to one another, and only allow the CLS token to attend to the patches in the last few layers.
They also add <a href="https://github.com/lucidrains/x-transformers#talking-heads-attention">Talking Heads</a>, noting improvements
You can use this scheme as follows
```python
import torch
from vit_pytorch.cait import CaiT
v = CaiT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 12, # depth of transformer for patch to patch attention only
cls_depth = 2, # depth of cross attention of CLS tokens to patch
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1,
layer_dropout = 0.05 # randomly dropout 5% of the layers
)
img = torch.randn(1, 3, 256, 256)
preds = v(img) # (1, 1000)
```
## Token-to-Token ViT
<img src="./images/t2t.png" width="400px"></img>
<a href="https://arxiv.org/abs/2101.11986">This paper</a> proposes that the first couple layers should downsample the image sequence by unfolding, leading to overlapping image data in each token as shown in the figure above. You can use this variant of the `ViT` as follows.
```python
import torch
from vit_pytorch.t2t import T2TViT
v = T2TViT(
dim = 512,
image_size = 224,
depth = 5,
heads = 8,
mlp_dim = 512,
num_classes = 1000,
t2t_layers = ((7, 4), (3, 2), (3, 2)) # tuples of the kernel size and stride of each consecutive layers of the initial token to token module
)
img = torch.randn(1, 3, 224, 224)
preds = v(img) # (1, 1000)
```
## CCT
<img src="https://raw.githubusercontent.com/SHI-Labs/Compact-Transformers/main/images/model_sym.png" width="400px"></img>
<a href="https://arxiv.org/abs/2104.05704">CCT</a> proposes compact transformers
by using convolutions instead of patching and performing sequence pooling. This
allows for CCT to have high accuracy and a low number of parameters.
You can use this with two methods
```python
import torch
from vit_pytorch.cct import CCT
cct = CCT(
img_size = (224, 448),
embedding_dim = 384,
n_conv_layers = 2,
kernel_size = 7,
stride = 2,
padding = 3,
pooling_kernel_size = 3,
pooling_stride = 2,
pooling_padding = 1,
num_layers = 14,
num_heads = 6,
mlp_ratio = 3.,
num_classes = 1000,
positional_embedding = 'learnable', # ['sine', 'learnable', 'none']
)
img = torch.randn(1, 3, 224, 448)
pred = cct(img) # (1, 1000)
```
Alternatively you can use one of several pre-defined models `[2,4,6,7,8,14,16]`
which pre-define the number of layers, number of attention heads, the mlp ratio,
and the embedding dimension.
```python
import torch
from vit_pytorch.cct import cct_14
cct = cct_14(
img_size = 224,
n_conv_layers = 1,
kernel_size = 7,
stride = 2,
padding = 3,
pooling_kernel_size = 3,
pooling_stride = 2,
pooling_padding = 1,
num_classes = 1000,
positional_embedding = 'learnable', # ['sine', 'learnable', 'none']
)
```
<a href="https://github.com/SHI-Labs/Compact-Transformers">Official
Repository</a> includes links to pretrained model checkpoints.
## Cross ViT
<img src="./images/cross_vit.png" width="400px"></img>
<a href="https://arxiv.org/abs/2103.14899">This paper</a> proposes to have two vision transformers processing the image at different scales, cross attending to one every so often. They show improvements on top of the base vision transformer.
```python
import torch
from vit_pytorch.cross_vit import CrossViT
v = CrossViT(
image_size = 256,
num_classes = 1000,
depth = 4, # number of multi-scale encoding blocks
sm_dim = 192, # high res dimension
sm_patch_size = 16, # high res patch size (should be smaller than lg_patch_size)
sm_enc_depth = 2, # high res depth
sm_enc_heads = 8, # high res heads
sm_enc_mlp_dim = 2048, # high res feedforward dimension
lg_dim = 384, # low res dimension
lg_patch_size = 64, # low res patch size
lg_enc_depth = 3, # low res depth
lg_enc_heads = 8, # low res heads
lg_enc_mlp_dim = 2048, # low res feedforward dimensions
cross_attn_depth = 2, # cross attention rounds
cross_attn_heads = 8, # cross attention heads
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(1, 3, 256, 256)
pred = v(img) # (1, 1000)
```
## PiT
<img src="./images/pit.png" width="400px"></img>
<a href="https://arxiv.org/abs/2103.16302">This paper</a> proposes to downsample the tokens through a pooling procedure using depth-wise convolutions.
```python
import torch
from vit_pytorch.pit import PiT
v = PiT(
image_size = 224,
patch_size = 14,
dim = 256,
num_classes = 1000,
depth = (3, 3, 3), # list of depths, indicating the number of rounds of each stage before a downsample
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
# forward pass now returns predictions and the attention maps
img = torch.randn(1, 3, 224, 224)
preds = v(img) # (1, 1000)
```
## LeViT
<img src="./images/levit.png" width="300px"></img>
<a href="https://arxiv.org/abs/2104.01136">This paper</a> proposes a number of changes, including (1) convolutional embedding instead of patch-wise projection (2) downsampling in stages (3) extra non-linearity in attention (4) 2d relative positional biases instead of initial absolute positional bias (5) batchnorm in place of layernorm.
<a href="https://github.com/facebookresearch/LeViT">Official repository</a>
```python
import torch
from vit_pytorch.levit import LeViT
levit = LeViT(
image_size = 224,
num_classes = 1000,
stages = 3, # number of stages
dim = (256, 384, 512), # dimensions at each stage
depth = 4, # transformer of depth 4 at each stage
heads = (4, 6, 8), # heads at each stage
mlp_mult = 2,
dropout = 0.1
)
img = torch.randn(1, 3, 224, 224)
levit(img) # (1, 1000)
```
## CvT
<img src="./images/cvt.png" width="400px"></img>
<a href="https://arxiv.org/abs/2103.15808">This paper</a> proposes mixing convolutions and attention. Specifically, convolutions are used to embed and downsample the image / feature map in three stages. Depthwise-convoltion is also used to project the queries, keys, and values for attention.
```python
import torch
from vit_pytorch.cvt import CvT
v = CvT(
num_classes = 1000,
s1_emb_dim = 64, # stage 1 - dimension
s1_emb_kernel = 7, # stage 1 - conv kernel
s1_emb_stride = 4, # stage 1 - conv stride
s1_proj_kernel = 3, # stage 1 - attention ds-conv kernel size
s1_kv_proj_stride = 2, # stage 1 - attention key / value projection stride
s1_heads = 1, # stage 1 - heads
s1_depth = 1, # stage 1 - depth
s1_mlp_mult = 4, # stage 1 - feedforward expansion factor
s2_emb_dim = 192, # stage 2 - (same as above)
s2_emb_kernel = 3,
s2_emb_stride = 2,
s2_proj_kernel = 3,
s2_kv_proj_stride = 2,
s2_heads = 3,
s2_depth = 2,
s2_mlp_mult = 4,
s3_emb_dim = 384, # stage 3 - (same as above)
s3_emb_kernel = 3,
s3_emb_stride = 2,
s3_proj_kernel = 3,
s3_kv_proj_stride = 2,
s3_heads = 4,
s3_depth = 10,
s3_mlp_mult = 4,
dropout = 0.
)
img = torch.randn(1, 3, 224, 224)
pred = v(img) # (1, 1000)
```
## Twins SVT
<img src="./images/twins_svt.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2104.13840">paper</a> proposes mixing local and global attention, along with position encoding generator (proposed in <a href="https://arxiv.org/abs/2102.10882">CPVT</a>) and global average pooling, to achieve the same results as <a href="https://arxiv.org/abs/2103.14030">Swin</a>, without the extra complexity of shifted windows, CLS tokens, nor positional embeddings.
```python
import torch
from vit_pytorch.twins_svt import TwinsSVT
model = TwinsSVT(
num_classes = 1000, # number of output classes
s1_emb_dim = 64, # stage 1 - patch embedding projected dimension
s1_patch_size = 4, # stage 1 - patch size for patch embedding
s1_local_patch_size = 7, # stage 1 - patch size for local attention
s1_global_k = 7, # stage 1 - global attention key / value reduction factor, defaults to 7 as specified in paper
s1_depth = 1, # stage 1 - number of transformer blocks (local attn -> ff -> global attn -> ff)
s2_emb_dim = 128, # stage 2 (same as above)
s2_patch_size = 2,
s2_local_patch_size = 7,
s2_global_k = 7,
s2_depth = 1,
s3_emb_dim = 256, # stage 3 (same as above)
s3_patch_size = 2,
s3_local_patch_size = 7,
s3_global_k = 7,
s3_depth = 5,
s4_emb_dim = 512, # stage 4 (same as above)
s4_patch_size = 2,
s4_local_patch_size = 7,
s4_global_k = 7,
s4_depth = 4,
peg_kernel_size = 3, # positional encoding generator kernel size
dropout = 0. # dropout
)
img = torch.randn(1, 3, 224, 224)
pred = model(img) # (1, 1000)
```
## RegionViT
<img src="./images/regionvit.png" width="400px"></img>
<img src="./images/regionvit2.png" width="400px"></img>
<a href="https://arxiv.org/abs/2106.02689">This paper</a> proposes to divide up the feature map into local regions, whereby the local tokens attend to each other. Each local region has its own regional token which then attends to all its local tokens, as well as other regional tokens.
You can use it as follows
```python
import torch
from vit_pytorch.regionvit import RegionViT
model = RegionViT(
dim = (64, 128, 256, 512), # tuple of size 4, indicating dimension at each stage
depth = (2, 2, 8, 2), # depth of the region to local transformer at each stage
window_size = 7, # window size, which should be either 7 or 14
num_classes = 1000, # number of output classes
tokenize_local_3_conv = False, # whether to use a 3 layer convolution to encode the local tokens from the image. the paper uses this for the smaller models, but uses only 1 conv (set to False) for the larger models
use_peg = False, # whether to use positional generating module. they used this for object detection for a boost in performance
)
img = torch.randn(1, 3, 224, 224)
pred = model(img) # (1, 1000)
```
## CrossFormer
<img src="./images/crossformer.png" width="400px"></img>
<img src="./images/crossformer2.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2108.00154">paper</a> beats PVT and Swin using alternating local and global attention. The global attention is done across the windowing dimension for reduced complexity, much like the scheme used for axial attention.
They also have cross-scale embedding layer, which they shown to be a generic layer that can improve all vision transformers. Dynamic relative positional bias was also formulated to allow the net to generalize to images of greater resolution.
```python
import torch
from vit_pytorch.crossformer import CrossFormer
model = CrossFormer(
num_classes = 1000, # number of output classes
dim = (64, 128, 256, 512), # dimension at each stage
depth = (2, 2, 8, 2), # depth of transformer at each stage
global_window_size = (8, 4, 2, 1), # global window sizes at each stage
local_window_size = 7, # local window size (can be customized for each stage, but in paper, held constant at 7 for all stages)
)
img = torch.randn(1, 3, 224, 224)
pred = model(img) # (1, 1000)
```
## ScalableViT
<img src="./images/scalable-vit-1.png" width="400px"></img>
<img src="./images/scalable-vit-2.png" width="400px"></img>
This Bytedance AI <a href="https://arxiv.org/abs/2203.10790">paper</a> proposes the Scalable Self Attention (SSA) and the Interactive Windowed Self Attention (IWSA) modules. The SSA alleviates the computation needed at earlier stages by reducing the key / value feature map by some factor (`reduction_factor`), while modulating the dimension of the queries and keys (`ssa_dim_key`). The IWSA performs self attention within local windows, similar to other vision transformer papers. However, they add a residual of the values, passed through a convolution of kernel size 3, which they named Local Interactive Module (LIM).
They make the claim in this paper that this scheme outperforms Swin Transformer, and also demonstrate competitive performance against Crossformer.
You can use it as follows (ex. ScalableViT-S)
```python
import torch
from vit_pytorch.scalable_vit import ScalableViT
model = ScalableViT(
num_classes = 1000,
dim = 64, # starting model dimension. at every stage, dimension is doubled
heads = (2, 4, 8, 16), # number of attention heads at each stage
depth = (2, 2, 20, 2), # number of transformer blocks at each stage
ssa_dim_key = (40, 40, 40, 32), # the dimension of the attention keys (and queries) for SSA. in the paper, they represented this as a scale factor on the base dimension per key (ssa_dim_key / dim_key)
reduction_factor = (8, 4, 2, 1), # downsampling of the key / values in SSA. in the paper, this was represented as (reduction_factor ** -2)
window_size = (64, 32, None, None), # window size of the IWSA at each stage. None means no windowing needed
dropout = 0.1, # attention and feedforward dropout
)
img = torch.randn(1, 3, 256, 256)
preds = model(img) # (1, 1000)
```
## SepViT
<img src="./images/sep-vit.png" width="400px"></img>
Another <a href="https://arxiv.org/abs/2203.15380">Bytedance AI paper</a>, it proposes a depthwise-pointwise self-attention layer that seems largely inspired by mobilenet's depthwise-separable convolution. The most interesting aspect is the reuse of the feature map from the depthwise self-attention stage as the values for the pointwise self-attention, as shown in the diagram above.
I have decided to include only the version of `SepViT` with this specific self-attention layer, as the grouped attention layers are not remarkable nor novel, and the authors were not clear on how they treated the window tokens for the group self-attention layer. Besides, it seems like with `DSSA` layer alone, they were able to beat Swin.
ex. SepViT-Lite
```python
import torch
from vit_pytorch.sep_vit import SepViT
v = SepViT(
num_classes = 1000,
dim = 32, # dimensions of first stage, which doubles every stage (32, 64, 128, 256) for SepViT-Lite
dim_head = 32, # attention head dimension
heads = (1, 2, 4, 8), # number of heads per stage
depth = (1, 2, 6, 2), # number of transformer blocks per stage
window_size = 7, # window size of DSS Attention block
dropout = 0.1 # dropout
)
img = torch.randn(1, 3, 224, 224)
preds = v(img) # (1, 1000)
```
## MaxViT
<img src="./images/max-vit.png" width="400px"></img>
<a href="https://arxiv.org/abs/2204.01697">This paper</a> proposes a hybrid convolutional / attention network, using MBConv from the convolution side, and then block / grid axial sparse attention.
They also claim this specific vision transformer is good for generative models (GANs).
ex. MaxViT-S
```python
import torch
from vit_pytorch.max_vit import MaxViT
v = MaxViT(
num_classes = 1000,
dim_conv_stem = 64, # dimension of the convolutional stem, would default to dimension of first layer if not specified
dim = 96, # dimension of first layer, doubles every layer
dim_head = 32, # dimension of attention heads, kept at 32 in paper
depth = (2, 2, 5, 2), # number of MaxViT blocks per stage, which consists of MBConv, block-like attention, grid-like attention
window_size = 7, # window size for block and grids
mbconv_expansion_rate = 4, # expansion rate of MBConv
mbconv_shrinkage_rate = 0.25, # shrinkage rate of squeeze-excitation in MBConv
dropout = 0.1 # dropout
)
img = torch.randn(2, 3, 224, 224)
preds = v(img) # (2, 1000)
```
## NesT
<img src="./images/nest.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2105.12723">paper</a> decided to process the image in hierarchical stages, with attention only within tokens of local blocks, which aggregate as it moves up the hierarchy. The aggregation is done in the image plane, and contains a convolution and subsequent maxpool to allow it to pass information across the boundary.
You can use it with the following code (ex. NesT-T)
```python
import torch
from vit_pytorch.nest import NesT
nest = NesT(
image_size = 224,
patch_size = 4,
dim = 96,
heads = 3,
num_hierarchies = 3, # number of hierarchies
block_repeats = (2, 2, 8), # the number of transformer blocks at each hierarchy, starting from the bottom
num_classes = 1000
)
img = torch.randn(1, 3, 224, 224)
pred = nest(img) # (1, 1000)
```
## MobileViT
<img src="./images/mbvit.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2110.02178">paper</a> introduce MobileViT, a light-weight and general purpose vision transformer for mobile devices. MobileViT presents a different
perspective for the global processing of information with transformers.
You can use it with the following code (ex. mobilevit_xs)
```python
import torch
from vit_pytorch.mobile_vit import MobileViT
mbvit_xs = MobileViT(
image_size = (256, 256),
dims = [96, 120, 144],
channels = [16, 32, 48, 48, 64, 64, 80, 80, 96, 96, 384],
num_classes = 1000
)
img = torch.randn(1, 3, 256, 256)
pred = mbvit_xs(img) # (1, 1000)
```
## XCiT
<img src="./images/xcit.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2106.09681">paper</a> introduces the cross covariance attention (abbreviated XCA). One can think of it as doing attention across the features dimension rather than the spatial one (another perspective would be a dynamic 1x1 convolution, the kernel being attention map defined by spatial correlations).
Technically, this amounts to simply transposing the query, key, values before executing cosine similarity attention with learned temperature.
```python
import torch
from vit_pytorch.xcit import XCiT
v = XCiT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 12, # depth of xcit transformer
cls_depth = 2, # depth of cross attention of CLS tokens to patch, attention pool at end
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1,
layer_dropout = 0.05, # randomly dropout 5% of the layers
local_patch_kernel_size = 3 # kernel size of the local patch interaction module (depthwise convs)
)
img = torch.randn(1, 3, 256, 256)
preds = v(img) # (1, 1000)
```
## Simple Masked Image Modeling
<img src="./images/simmim.png" width="400px"/>
This <a href="https://arxiv.org/abs/2111.09886">paper</a> proposes a simple masked image modeling (SimMIM) scheme, using only a linear projection off the masked tokens into pixel space followed by an L1 loss with the pixel values of the masked patches. Results are competitive with other more complicated approaches.
You can use this as follows
```python
import torch
from vit_pytorch import ViT
from vit_pytorch.simmim import SimMIM
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048
)
mim = SimMIM(
encoder = v,
masking_ratio = 0.5 # they found 50% to yield the best results
)
images = torch.randn(8, 3, 256, 256)
loss = mim(images)
loss.backward()
# that's all!
# do the above in a for loop many times with a lot of images and your vision transformer will learn
torch.save(v.state_dict(), './trained-vit.pt')
```
## Masked Autoencoder
<img src="./images/mae.png" width="400px"/>
A new <a href="https://arxiv.org/abs/2111.06377">Kaiming He paper</a> proposes a simple autoencoder scheme where the vision transformer attends to a set of unmasked patches, and a smaller decoder tries to reconstruct the masked pixel values.
<a href="https://www.youtube.com/watch?v=LKixq2S2Pz8">DeepReader quick paper review</a>
<a href="https://www.youtube.com/watch?v=Dp6iICL2dVI">AI Coffeebreak with Letitia</a>
You can use it with the following code
```python
import torch
from vit_pytorch import ViT, MAE
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048
)
mae = MAE(
encoder = v,
masking_ratio = 0.75, # the paper recommended 75% masked patches
decoder_dim = 512, # paper showed good results with just 512
decoder_depth = 6 # anywhere from 1 to 8
)
images = torch.randn(8, 3, 256, 256)
loss = mae(images)
loss.backward()
# that's all!
# do the above in a for loop many times with a lot of images and your vision transformer will learn
# save your improved vision transformer
torch.save(v.state_dict(), './trained-vit.pt')
```
## Masked Patch Prediction
Thanks to <a href="https://github.com/zankner">Zach</a>, you can train using the original masked patch prediction task presented in the paper, with the following code.
```python
import torch
from vit_pytorch import ViT
from vit_pytorch.mpp import MPP
model = ViT(
image_size=256,
patch_size=32,
num_classes=1000,
dim=1024,
depth=6,
heads=8,
mlp_dim=2048,
dropout=0.1,
emb_dropout=0.1
)
mpp_trainer = MPP(
transformer=model,
patch_size=32,
dim=1024,
mask_prob=0.15, # probability of using token in masked prediction task
random_patch_prob=0.30, # probability of randomly replacing a token being used for mpp
replace_prob=0.50, # probability of replacing a token being used for mpp with the mask token
)
opt = torch.optim.Adam(mpp_trainer.parameters(), lr=3e-4)
def sample_unlabelled_images():
return torch.FloatTensor(20, 3, 256, 256).uniform_(0., 1.)
for _ in range(100):
images = sample_unlabelled_images()
loss = mpp_trainer(images)
opt.zero_grad()
loss.backward()
opt.step()
# save your improved network
torch.save(model.state_dict(), './pretrained-net.pt')
```
## Masked Position Prediction
<img src="./images/mp3.png" width="400px"></img>
New <a href="https://arxiv.org/abs/2207.07611">paper</a> that introduces masked position prediction pre-training criteria. This strategy is more efficient than the Masked Autoencoder strategy and has comparable performance.
```python
import torch
from vit_pytorch.mp3 import ViT, MP3
v = ViT(
num_classes = 1000,
image_size = 256,
patch_size = 8,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048,
dropout = 0.1,
)
mp3 = MP3(
vit = v,
masking_ratio = 0.75
)
images = torch.randn(8, 3, 256, 256)
loss = mp3(images)
loss.backward()
# that's all!
# do the above in a for loop many times with a lot of images and your vision transformer will learn
# save your improved vision transformer
torch.save(v.state_dict(), './trained-vit.pt')
```
## Adaptive Token Sampling
<img src="./images/ats.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2111.15667">paper</a> proposes to use the CLS attention scores, re-weighed by the norms of the value heads, as means to discard unimportant tokens at different layers.
```python
import torch
from vit_pytorch.ats_vit import ViT
v = ViT(
image_size = 256,
patch_size = 16,
num_classes = 1000,
dim = 1024,
depth = 6,
max_tokens_per_depth = (256, 128, 64, 32, 16, 8), # a tuple that denotes the maximum number of tokens that any given layer should have. if the layer has greater than this amount, it will undergo adaptive token sampling
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(4, 3, 256, 256)
preds = v(img) # (4, 1000)
# you can also get a list of the final sampled patch ids
# a value of -1 denotes padding
preds, token_ids = v(img, return_sampled_token_ids = True) # (4, 1000), (4, <=8)
```
## Patch Merger
<img src="./images/patch_merger.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2202.12015">paper</a> proposes a simple module (Patch Merger) for reducing the number of tokens at any layer of a vision transformer without sacrificing performance.
```python
import torch
from vit_pytorch.vit_with_patch_merger import ViT
v = ViT(
image_size = 256,
patch_size = 16,
num_classes = 1000,
dim = 1024,
depth = 12,
heads = 8,
patch_merge_layer = 6, # at which transformer layer to do patch merging
patch_merge_num_tokens = 8, # the output number of tokens from the patch merge
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(4, 3, 256, 256)
preds = v(img) # (4, 1000)
```
One can also use the `PatchMerger` module by itself
```python
import torch
from vit_pytorch.vit_with_patch_merger import PatchMerger
merger = PatchMerger(
dim = 1024,
num_tokens_out = 8 # output number of tokens
)
features = torch.randn(4, 256, 1024) # (batch, num tokens, dimension)
out = merger(features) # (4, 8, 1024)
```
## Vision Transformer for Small Datasets
<img src="./images/vit_for_small_datasets.png" width="400px"></img>
This <a href="https://arxiv.org/abs/2112.13492">paper</a> proposes a new image to patch function that incorporates shifts of the image, before normalizing and dividing the image into patches. I have found shifting to be extremely helpful in some other transformers work, so decided to include this for further explorations. It also includes the `LSA` with the learned temperature and masking out of a token's attention to itself.
You can use as follows:
```python
import torch
from vit_pytorch.vit_for_small_dataset import ViT
v = ViT(
image_size = 256,
patch_size = 16,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(4, 3, 256, 256)
preds = v(img) # (1, 1000)
```
You can also use the `SPT` from this paper as a standalone module
```python
import torch
from vit_pytorch.vit_for_small_dataset import SPT
spt = SPT(
dim = 1024,
patch_size = 16,
channels = 3
)
img = torch.randn(4, 3, 256, 256)
tokens = spt(img) # (4, 256, 1024)
```
## 3D ViT
By popular request, I will start extending a few of the architectures in this repository to 3D ViTs, for use with video, medical imaging, etc.
You will need to pass in two additional hyperparameters: (1) the number of frames `frames` and (2) patch size along the frame dimension `frame_patch_size`
For starters, 3D ViT
```python
import torch
from vit_pytorch.vit_3d import ViT
v = ViT(
image_size = 128, # image size
frames = 16, # number of frames
image_patch_size = 16, # image patch size
frame_patch_size = 2, # frame patch size
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
video = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)
preds = v(video) # (4, 1000)
```
3D Simple ViT
```python
import torch
from vit_pytorch.simple_vit_3d import SimpleViT
v = SimpleViT(
image_size = 128, # image size
frames = 16, # number of frames
image_patch_size = 16, # image patch size
frame_patch_size = 2, # frame patch size
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048
)
video = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)
preds = v(video) # (4, 1000)
```
3D version of <a href="https://github.com/lucidrains/vit-pytorch#cct">CCT</a>
```python
import torch
from vit_pytorch.cct_3d import CCT
cct = CCT(
img_size = 224,
num_frames = 8,
embedding_dim = 384,
n_conv_layers = 2,
frame_kernel_size = 3,
kernel_size = 7,
stride = 2,
padding = 3,
pooling_kernel_size = 3,
pooling_stride = 2,
pooling_padding = 1,
num_layers = 14,
num_heads = 6,
mlp_ratio = 3.,
num_classes = 1000,
positional_embedding = 'learnable'
)
video = torch.randn(1, 3, 8, 224, 224) # (batch, channels, frames, height, width)
pred = cct(video)
```
## ViViT
<img src="./images/vivit.png" width="350px"></img>
This <a href="https://arxiv.org/abs/2103.15691">paper</a> offers 3 different types of architectures for efficient attention of videos, with the main theme being factorizing the attention across space and time. This repository includes the factorized encoder and the factorized self-attention variant.
The factorized encoder variant is a spatial transformer followed by a temporal one. The factorized self-attention variant is a spatio-temporal transformer with alternating spatial and temporal self-attention layers.
```python
import torch
from vit_pytorch.vivit import ViT
v = ViT(
image_size = 128, # image size
frames = 16, # number of frames
image_patch_size = 16, # image patch size
frame_patch_size = 2, # frame patch size
num_classes = 1000,
dim = 1024,
spatial_depth = 6, # depth of the spatial transformer
temporal_depth = 6, # depth of the temporal transformer
heads = 8,
mlp_dim = 2048,
variant = 'factorized_encoder', # or 'factorized_self_attention'
)
video = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)
preds = v(video) # (4, 1000)
```
## Parallel ViT
<img src="./images/parallel-vit.png" width="350px"></img>
This <a href="https://arxiv.org/abs/2203.09795">paper</a> propose parallelizing multiple attention and feedforward blocks per layer (2 blocks), claiming that it is easier to train without loss of performance.
You can try this variant as follows
```python
import torch
from vit_pytorch.parallel_vit import ViT
v = ViT(
image_size = 256,
patch_size = 16,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048,
num_parallel_branches = 2, # in paper, they claimed 2 was optimal
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(4, 3, 256, 256)
preds = v(img) # (4, 1000)
```
## Learnable Memory ViT
<img src="./images/learnable-memory-vit.png" width="350px"></img>
This <a href="https://arxiv.org/abs/2203.15243">paper</a> shows that adding learnable memory tokens at each layer of a vision transformer can greatly enhance fine-tuning results (in addition to learnable task specific CLS token and adapter head).
You can use this with a specially modified `ViT` as follows
```python
import torch
from vit_pytorch.learnable_memory_vit import ViT, Adapter
# normal base ViT
v = ViT(
image_size = 256,
patch_size = 16,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(4, 3, 256, 256)
logits = v(img) # (4, 1000)
# do your usual training with ViT
# ...
# then, to finetune, just pass the ViT into the Adapter class
# you can do this for multiple Adapters, as shown below
adapter1 = Adapter(
vit = v,
num_classes = 2, # number of output classes for this specific task
num_memories_per_layer = 5 # number of learnable memories per layer, 10 was sufficient in paper
)
logits1 = adapter1(img) # (4, 2) - predict 2 classes off frozen ViT backbone with learnable memories and task specific head
# yet another task to finetune on, this time with 4 classes
adapter2 = Adapter(
vit = v,
num_classes = 4,
num_memories_per_layer = 10
)
logits2 = adapter2(img) # (4, 4) - predict 4 classes off frozen ViT backbone with learnable memories and task specific head
```
## Dino
<img src="./images/dino.png" width="350px"></img>
You can train `ViT` with the recent SOTA self-supervised learning technique, <a href="https://arxiv.org/abs/2104.14294">Dino</a>, with the following code.
<a href="https://www.youtube.com/watch?v=h3ij3F3cPIk">Yannic Kilcher</a> video
```python
import torch
from vit_pytorch import ViT, Dino
model = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 8,
mlp_dim = 2048
)
learner = Dino(
model,
image_size = 256,
hidden_layer = 'to_latent', # hidden layer name or index, from which to extract the embedding
projection_hidden_size = 256, # projector network hidden dimension
projection_layers = 4, # number of layers in projection network
num_classes_K = 65336, # output logits dimensions (referenced as K in paper)
student_temp = 0.9, # student temperature
teacher_temp = 0.04, # teacher temperature, needs to be annealed from 0.04 to 0.07 over 30 epochs
local_upper_crop_scale = 0.4, # upper bound for local crop - 0.4 was recommended in the paper
global_lower_crop_scale = 0.5, # lower bound for global crop - 0.5 was recommended in the paper
moving_average_decay = 0.9, # moving average of encoder - paper showed anywhere from 0.9 to 0.999 was ok
center_moving_average_decay = 0.9, # moving average of teacher centers - paper showed anywhere from 0.9 to 0.999 was ok
)
opt = torch.optim.Adam(learner.parameters(), lr = 3e-4)
def sample_unlabelled_images():
return torch.randn(20, 3, 256, 256)
for _ in range(100):
images = sample_unlabelled_images()
loss = learner(images)
opt.zero_grad()
loss.backward()
opt.step()
learner.update_moving_average() # update moving average of teacher encoder and teacher centers
# save your improved network
torch.save(model.state_dict(), './pretrained-net.pt')
```
## EsViT
<img src="./images/esvit.png" width="350px"></img>
<a href="https://arxiv.org/abs/2106.09785">`EsViT`</a> is a variant of Dino (from above) re-engineered to support efficient `ViT`s with patch merging / downsampling by taking into an account an extra regional loss between the augmented views. To quote the abstract, it `outperforms its supervised counterpart on 17 out of 18 datasets` at 3 times higher throughput.
Even though it is named as though it were a new `ViT` variant, it actually is just a strategy for training any multistage `ViT` (in the paper, they focused on Swin). The example below will show how to use it with `CvT`. You'll need to set the `hidden_layer` to the name of the layer within your efficient ViT that outputs the non-average pooled visual representations, just before the global pooling and projection to logits.
```python
import torch
from vit_pytorch.cvt import CvT
from vit_pytorch.es_vit import EsViTTrainer
cvt = CvT(
num_classes = 1000,
s1_emb_dim = 64,
s1_emb_kernel = 7,
s1_emb_stride = 4,
s1_proj_kernel = 3,
s1_kv_proj_stride = 2,
s1_heads = 1,
s1_depth = 1,
s1_mlp_mult = 4,
s2_emb_dim = 192,
s2_emb_kernel = 3,
s2_emb_stride = 2,
s2_proj_kernel = 3,
s2_kv_proj_stride = 2,
s2_heads = 3,
s2_depth = 2,
s2_mlp_mult = 4,
s3_emb_dim = 384,
s3_emb_kernel = 3,
s3_emb_stride = 2,
s3_proj_kernel = 3,
s3_kv_proj_stride = 2,
s3_heads = 4,
s3_depth = 10,
s3_mlp_mult = 4,
dropout = 0.
)
learner = EsViTTrainer(
cvt,
image_size = 256,
hidden_layer = 'layers', # hidden layer name or index, from which to extract the embedding
projection_hidden_size = 256, # projector network hidden dimension
projection_layers = 4, # number of layers in projection network
num_classes_K = 65336, # output logits dimensions (referenced as K in paper)
student_temp = 0.9, # student temperature
teacher_temp = 0.04, # teacher temperature, needs to be annealed from 0.04 to 0.07 over 30 epochs
local_upper_crop_scale = 0.4, # upper bound for local crop - 0.4 was recommended in the paper
global_lower_crop_scale = 0.5, # lower bound for global crop - 0.5 was recommended in the paper
moving_average_decay = 0.9, # moving average of encoder - paper showed anywhere from 0.9 to 0.999 was ok
center_moving_average_decay = 0.9, # moving average of teacher centers - paper showed anywhere from 0.9 to 0.999 was ok
)
opt = torch.optim.AdamW(learner.parameters(), lr = 3e-4)
def sample_unlabelled_images():
return torch.randn(8, 3, 256, 256)
for _ in range(1000):
images = sample_unlabelled_images()
loss = learner(images)
opt.zero_grad()
loss.backward()
opt.step()
learner.update_moving_average() # update moving average of teacher encoder and teacher centers
# save your improved network
torch.save(cvt.state_dict(), './pretrained-net.pt')
```
## Accessing Attention
If you would like to visualize the attention weights (post-softmax) for your research, just follow the procedure below
```python
import torch
from vit_pytorch.vit import ViT
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
# import Recorder and wrap the ViT
from vit_pytorch.recorder import Recorder
v = Recorder(v)
# forward pass now returns predictions and the attention maps
img = torch.randn(1, 3, 256, 256)
preds, attns = v(img)
# there is one extra patch due to the CLS token
attns # (1, 6, 16, 65, 65) - (batch x layers x heads x patch x patch)
```
to cleanup the class and the hooks once you have collected enough data
```python
v = v.eject() # wrapper is discarded and original ViT instance is returned
```
## Accessing Embeddings
You can similarly access the embeddings with the `Extractor` wrapper
```python
import torch
from vit_pytorch.vit import ViT
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
# import Recorder and wrap the ViT
from vit_pytorch.extractor import Extractor
v = Extractor(v)
# forward pass now returns predictions and the attention maps
img = torch.randn(1, 3, 256, 256)
logits, embeddings = v(img)
# there is one extra token due to the CLS token
embeddings # (1, 65, 1024) - (batch x patches x model dim)
```
Or say for `CrossViT`, which has a multi-scale encoder that outputs two sets of embeddings for 'large' and 'small' scales
```python
import torch
from vit_pytorch.cross_vit import CrossViT
v = CrossViT(
image_size = 256,
num_classes = 1000,
depth = 4,
sm_dim = 192,
sm_patch_size = 16,
sm_enc_depth = 2,
sm_enc_heads = 8,
sm_enc_mlp_dim = 2048,
lg_dim = 384,
lg_patch_size = 64,
lg_enc_depth = 3,
lg_enc_heads = 8,
lg_enc_mlp_dim = 2048,
cross_attn_depth = 2,
cross_attn_heads = 8,
dropout = 0.1,
emb_dropout = 0.1
)
# wrap the CrossViT
from vit_pytorch.extractor import Extractor
v = Extractor(v, layer_name = 'multi_scale_encoder') # take embedding coming from the output of multi-scale-encoder
# forward pass now returns predictions and the attention maps
img = torch.randn(1, 3, 256, 256)
logits, embeddings = v(img)
# there is one extra token due to the CLS token
embeddings # ((1, 257, 192), (1, 17, 384)) - (batch x patches x dimension) <- large and small scales respectively
```
## Research Ideas
### Efficient Attention
There may be some coming from computer vision who think attention still suffers from quadratic costs. Fortunately, we have a lot of new techniques that may help. This repository offers a way for you to plugin your own sparse attention transformer.
An example with <a href="https://arxiv.org/abs/2102.03902">Nystromformer</a>
```bash
$ pip install nystrom-attention
```
```python
import torch
from vit_pytorch.efficient import ViT
from nystrom_attention import Nystromformer
efficient_transformer = Nystromformer(
dim = 512,
depth = 12,
heads = 8,
num_landmarks = 256
)
v = ViT(
dim = 512,
image_size = 2048,
patch_size = 32,
num_classes = 1000,
transformer = efficient_transformer
)
img = torch.randn(1, 3, 2048, 2048) # your high resolution picture
v(img) # (1, 1000)
```
Other sparse attention frameworks I would highly recommend is <a href="https://github.com/lucidrains/routing-transformer">Routing Transformer</a> or <a href="https://github.com/lucidrains/sinkhorn-transformer">Sinkhorn Transformer</a>
### Combining with other Transformer improvements
This paper purposely used the most vanilla of attention networks to make a statement. If you would like to use some of the latest improvements for attention nets, please use the `Encoder` from <a href="https://github.com/lucidrains/x-transformers">this repository</a>.
ex.
```bash
$ pip install x-transformers
```
```python
import torch
from vit_pytorch.efficient import ViT
from x_transformers import Encoder
v = ViT(
dim = 512,
image_size = 224,
patch_size = 16,
num_classes = 1000,
transformer = Encoder(
dim = 512, # set to be the same as the wrapper
depth = 12,
heads = 8,
ff_glu = True, # ex. feed forward GLU variant https://arxiv.org/abs/2002.05202
residual_attn = True # ex. residual attention https://arxiv.org/abs/2012.11747
)
)
img = torch.randn(1, 3, 224, 224)
v(img) # (1, 1000)
```
## FAQ
- How do I pass in non-square images?
You can already pass in non-square images - you just have to make sure your height and width is less than or equal to the `image_size`, and both divisible by the `patch_size`
ex.
```python
import torch
from vit_pytorch import ViT
v = ViT(
image_size = 256,
patch_size = 32,
num_classes = 1000,
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(1, 3, 256, 128) # <-- not a square
preds = v(img) # (1, 1000)
```
- How do I pass in non-square patches?
```python
import torch
from vit_pytorch import ViT
v = ViT(
num_classes = 1000,
image_size = (256, 128), # image size is a tuple of (height, width)
patch_size = (32, 16), # patch size is a tuple of (height, width)
dim = 1024,
depth = 6,
heads = 16,
mlp_dim = 2048,
dropout = 0.1,
emb_dropout = 0.1
)
img = torch.randn(1, 3, 256, 128)
preds = v(img)
```
## Resources
Coming from computer vision and new to transformers? Here are some resources that greatly accelerated my learning.
1. <a href="http://jalammar.github.io/illustrated-transformer/">Illustrated Transformer</a> - Jay Alammar
2. <a href="http://peterbloem.nl/blog/transformers">Transformers from Scratch</a> - Peter Bloem
3. <a href="https://nlp.seas.harvard.edu/2018/04/03/attention.html">The Annotated Transformer</a> - Harvard NLP
## Citations
```bibtex
@article{hassani2021escaping,
title = {Escaping the Big Data Paradigm with Compact Transformers},
author = {Ali Hassani and Steven Walton and Nikhil Shah and Abulikemu Abuduweili and Jiachen Li and Humphrey Shi},
year = 2021,
url = {https://arxiv.org/abs/2104.05704},
eprint = {2104.05704},
archiveprefix = {arXiv},
primaryclass = {cs.CV}
}
```
```bibtex
@misc{dosovitskiy2020image,
title = {An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale},
author = {Alexey Dosovitskiy and Lucas Beyer and Alexander Kolesnikov and Dirk Weissenborn and Xiaohua Zhai and Thomas Unterthiner and Mostafa Dehghani and Matthias Minderer and Georg Heigold and Sylvain Gelly and Jakob Uszkoreit and Neil Houlsby},
year = {2020},
eprint = {2010.11929},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{touvron2020training,
title = {Training data-efficient image transformers & distillation through attention},
author = {Hugo Touvron and Matthieu Cord and Matthijs Douze and Francisco Massa and Alexandre Sablayrolles and Hervé Jégou},
year = {2020},
eprint = {2012.12877},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{yuan2021tokenstotoken,
title = {Tokens-to-Token ViT: Training Vision Transformers from Scratch on ImageNet},
author = {Li Yuan and Yunpeng Chen and Tao Wang and Weihao Yu and Yujun Shi and Francis EH Tay and Jiashi Feng and Shuicheng Yan},
year = {2021},
eprint = {2101.11986},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{zhou2021deepvit,
title = {DeepViT: Towards Deeper Vision Transformer},
author = {Daquan Zhou and Bingyi Kang and Xiaojie Jin and Linjie Yang and Xiaochen Lian and Qibin Hou and Jiashi Feng},
year = {2021},
eprint = {2103.11886},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{touvron2021going,
title = {Going deeper with Image Transformers},
author = {Hugo Touvron and Matthieu Cord and Alexandre Sablayrolles and Gabriel Synnaeve and Hervé Jégou},
year = {2021},
eprint = {2103.17239},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{chen2021crossvit,
title = {CrossViT: Cross-Attention Multi-Scale Vision Transformer for Image Classification},
author = {Chun-Fu Chen and Quanfu Fan and Rameswar Panda},
year = {2021},
eprint = {2103.14899},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{wu2021cvt,
title = {CvT: Introducing Convolutions to Vision Transformers},
author = {Haiping Wu and Bin Xiao and Noel Codella and Mengchen Liu and Xiyang Dai and Lu Yuan and Lei Zhang},
year = {2021},
eprint = {2103.15808},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{heo2021rethinking,
title = {Rethinking Spatial Dimensions of Vision Transformers},
author = {Byeongho Heo and Sangdoo Yun and Dongyoon Han and Sanghyuk Chun and Junsuk Choe and Seong Joon Oh},
year = {2021},
eprint = {2103.16302},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{graham2021levit,
title = {LeViT: a Vision Transformer in ConvNet's Clothing for Faster Inference},
author = {Ben Graham and Alaaeldin El-Nouby and Hugo Touvron and Pierre Stock and Armand Joulin and Hervé Jégou and Matthijs Douze},
year = {2021},
eprint = {2104.01136},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{li2021localvit,
title = {LocalViT: Bringing Locality to Vision Transformers},
author = {Yawei Li and Kai Zhang and Jiezhang Cao and Radu Timofte and Luc Van Gool},
year = {2021},
eprint = {2104.05707},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{chu2021twins,
title = {Twins: Revisiting Spatial Attention Design in Vision Transformers},
author = {Xiangxiang Chu and Zhi Tian and Yuqing Wang and Bo Zhang and Haibing Ren and Xiaolin Wei and Huaxia Xia and Chunhua Shen},
year = {2021},
eprint = {2104.13840},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{su2021roformer,
title = {RoFormer: Enhanced Transformer with Rotary Position Embedding},
author = {Jianlin Su and Yu Lu and Shengfeng Pan and Bo Wen and Yunfeng Liu},
year = {2021},
eprint = {2104.09864},
archivePrefix = {arXiv},
primaryClass = {cs.CL}
}
```
```bibtex
@misc{zhang2021aggregating,
title = {Aggregating Nested Transformers},
author = {Zizhao Zhang and Han Zhang and Long Zhao and Ting Chen and Tomas Pfister},
year = {2021},
eprint = {2105.12723},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{chen2021regionvit,
title = {RegionViT: Regional-to-Local Attention for Vision Transformers},
author = {Chun-Fu Chen and Rameswar Panda and Quanfu Fan},
year = {2021},
eprint = {2106.02689},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{wang2021crossformer,
title = {CrossFormer: A Versatile Vision Transformer Hinging on Cross-scale Attention},
author = {Wenxiao Wang and Lu Yao and Long Chen and Binbin Lin and Deng Cai and Xiaofei He and Wei Liu},
year = {2021},
eprint = {2108.00154},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{caron2021emerging,
title = {Emerging Properties in Self-Supervised Vision Transformers},
author = {Mathilde Caron and Hugo Touvron and Ishan Misra and Hervé Jégou and Julien Mairal and Piotr Bojanowski and Armand Joulin},
year = {2021},
eprint = {2104.14294},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{he2021masked,
title = {Masked Autoencoders Are Scalable Vision Learners},
author = {Kaiming He and Xinlei Chen and Saining Xie and Yanghao Li and Piotr Dollár and Ross Girshick},
year = {2021},
eprint = {2111.06377},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{xie2021simmim,
title = {SimMIM: A Simple Framework for Masked Image Modeling},
author = {Zhenda Xie and Zheng Zhang and Yue Cao and Yutong Lin and Jianmin Bao and Zhuliang Yao and Qi Dai and Han Hu},
year = {2021},
eprint = {2111.09886},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{fayyaz2021ats,
title = {ATS: Adaptive Token Sampling For Efficient Vision Transformers},
author = {Mohsen Fayyaz and Soroush Abbasi Kouhpayegani and Farnoush Rezaei Jafari and Eric Sommerlade and Hamid Reza Vaezi Joze and Hamed Pirsiavash and Juergen Gall},
year = {2021},
eprint = {2111.15667},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{mehta2021mobilevit,
title = {MobileViT: Light-weight, General-purpose, and Mobile-friendly Vision Transformer},
author = {Sachin Mehta and Mohammad Rastegari},
year = {2021},
eprint = {2110.02178},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{lee2021vision,
title = {Vision Transformer for Small-Size Datasets},
author = {Seung Hoon Lee and Seunghyun Lee and Byung Cheol Song},
year = {2021},
eprint = {2112.13492},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{renggli2022learning,
title = {Learning to Merge Tokens in Vision Transformers},
author = {Cedric Renggli and André Susano Pinto and Neil Houlsby and Basil Mustafa and Joan Puigcerver and Carlos Riquelme},
year = {2022},
eprint = {2202.12015},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@misc{yang2022scalablevit,
title = {ScalableViT: Rethinking the Context-oriented Generalization of Vision Transformer},
author = {Rui Yang and Hailong Ma and Jie Wu and Yansong Tang and Xuefeng Xiao and Min Zheng and Xiu Li},
year = {2022},
eprint = {2203.10790},
archivePrefix = {arXiv},
primaryClass = {cs.CV}
}
```
```bibtex
@inproceedings{Touvron2022ThreeTE,
title = {Three things everyone should know about Vision Transformers},
author = {Hugo Touvron and Matthieu Cord and Alaaeldin El-Nouby and Jakob Verbeek and Herv'e J'egou},
year = {2022}
}
```
```bibtex
@inproceedings{Sandler2022FinetuningIT,
title = {Fine-tuning Image Transformers using Learnable Memory},
author = {Mark Sandler and Andrey Zhmoginov and Max Vladymyrov and Andrew Jackson},
year = {2022}
}
```
```bibtex
@inproceedings{Li2022SepViTSV,
title = {SepViT: Separable Vision Transformer},
author = {Wei Li and Xing Wang and Xin Xia and Jie Wu and Xuefeng Xiao and Minghang Zheng and Shiping Wen},
year = {2022}
}
```
```bibtex
@inproceedings{Tu2022MaxViTMV,
title = {MaxViT: Multi-Axis Vision Transformer},
author = {Zhengzhong Tu and Hossein Talebi and Han Zhang and Feng Yang and Peyman Milanfar and Alan Conrad Bovik and Yinxiao Li},
year = {2022}
}
```
```bibtex
@article{Li2021EfficientSV,
title = {Efficient Self-supervised Vision Transformers for Representation Learning},
author = {Chunyuan Li and Jianwei Yang and Pengchuan Zhang and Mei Gao and Bin Xiao and Xiyang Dai and Lu Yuan and Jianfeng Gao},
journal = {ArXiv},
year = {2021},
volume = {abs/2106.09785}
}
```
```bibtex
@misc{Beyer2022BetterPlainViT
title = {Better plain ViT baselines for ImageNet-1k},
author = {Beyer, Lucas and Zhai, Xiaohua and Kolesnikov, Alexander},
publisher = {arXiv},
year = {2022}
}
```
```bibtex
@article{Arnab2021ViViTAV,
title = {ViViT: A Video Vision Transformer},
author = {Anurag Arnab and Mostafa Dehghani and Georg Heigold and Chen Sun and Mario Lucic and Cordelia Schmid},
journal = {2021 IEEE/CVF International Conference on Computer Vision (ICCV)},
year = {2021},
pages = {6816-6826}
}
```
```bibtex
@article{Liu2022PatchDropoutEV,
title = {PatchDropout: Economizing Vision Transformers Using Patch Dropout},
author = {Yue Liu and Christos Matsoukas and Fredrik Strand and Hossein Azizpour and Kevin Smith},
journal = {ArXiv},
year = {2022},
volume = {abs/2208.07220}
}
```
```bibtex
@misc{https://doi.org/10.48550/arxiv.2302.01327,
doi = {10.48550/ARXIV.2302.01327},
url = {https://arxiv.org/abs/2302.01327},
author = {Kumar, Manoj and Dehghani, Mostafa and Houlsby, Neil},
title = {Dual PatchNorm},
publisher = {arXiv},
year = {2023},
copyright = {Creative Commons Attribution 4.0 International}
}
```
```bibtex
@inproceedings{Dehghani2023PatchNP,
title = {Patch n' Pack: NaViT, a Vision Transformer for any Aspect Ratio and Resolution},
author = {Mostafa Dehghani and Basil Mustafa and Josip Djolonga and Jonathan Heek and Matthias Minderer and Mathilde Caron and Andreas Steiner and Joan Puigcerver and Robert Geirhos and Ibrahim M. Alabdulmohsin and Avital Oliver and Piotr Padlewski and Alexey A. Gritsenko and Mario Luvci'c and Neil Houlsby},
year = {2023}
}
```
```bibtex
@misc{vaswani2017attention,
title = {Attention Is All You Need},
author = {Ashish Vaswani and Noam Shazeer and Niki Parmar and Jakob Uszkoreit and Llion Jones and Aidan N. Gomez and Lukasz Kaiser and Illia Polosukhin},
year = {2017},
eprint = {1706.03762},
archivePrefix = {arXiv},
primaryClass = {cs.CL}
}
```
```bibtex
@inproceedings{dao2022flashattention,
title = {Flash{A}ttention: Fast and Memory-Efficient Exact Attention with {IO}-Awareness},
author = {Dao, Tri and Fu, Daniel Y. and Ermon, Stefano and Rudra, Atri and R{\'e}, Christopher},
booktitle = {Advances in Neural Information Processing Systems},
year = {2022}
}
```
```bibtex
@inproceedings{Darcet2023VisionTN,
title = {Vision Transformers Need Registers},
author = {Timoth'ee Darcet and Maxime Oquab and Julien Mairal and Piotr Bojanowski},
year = {2023},
url = {https://api.semanticscholar.org/CorpusID:263134283}
}
```
```bibtex
@inproceedings{ElNouby2021XCiTCI,
title = {XCiT: Cross-Covariance Image Transformers},
author = {Alaaeldin El-Nouby and Hugo Touvron and Mathilde Caron and Piotr Bojanowski and Matthijs Douze and Armand Joulin and Ivan Laptev and Natalia Neverova and Gabriel Synnaeve and Jakob Verbeek and Herv{\'e} J{\'e}gou},
booktitle = {Neural Information Processing Systems},
year = {2021},
url = {https://api.semanticscholar.org/CorpusID:235458262}
}
```
```bibtex
@inproceedings{Koner2024LookupViTCV,
title = {LookupViT: Compressing visual information to a limited number of tokens},
author = {Rajat Koner and Gagan Jain and Prateek Jain and Volker Tresp and Sujoy Paul},
year = {2024},
url = {https://api.semanticscholar.org/CorpusID:271244592}
}
```
```bibtex
@article{Bao2022AllAW,
title = {All are Worth Words: A ViT Backbone for Diffusion Models},
author = {Fan Bao and Shen Nie and Kaiwen Xue and Yue Cao and Chongxuan Li and Hang Su and Jun Zhu},
journal = {2023 IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},
year = {2022},
pages = {22669-22679},
url = {https://api.semanticscholar.org/CorpusID:253581703}
}
```
```bibtex
@misc{Rubin2024,
author = {Ohad Rubin},
url = {https://medium.com/@ohadrubin/exploring-weight-decay-in-layer-normalization-challenges-and-a-reparameterization-solution-ad4d12c24950}
}
```
```bibtex
@inproceedings{Loshchilov2024nGPTNT,
title = {nGPT: Normalized Transformer with Representation Learning on the Hypersphere},
author = {Ilya Loshchilov and Cheng-Ping Hsieh and Simeng Sun and Boris Ginsburg},
year = {2024},
url = {https://api.semanticscholar.org/CorpusID:273026160}
}
```
```bibtex
@inproceedings{Liu2017DeepHL,
title = {Deep Hyperspherical Learning},
author = {Weiyang Liu and Yanming Zhang and Xingguo Li and Zhen Liu and Bo Dai and Tuo Zhao and Le Song},
booktitle = {Neural Information Processing Systems},
year = {2017},
url = {https://api.semanticscholar.org/CorpusID:5104558}
}
```
```bibtex
@inproceedings{Zhou2024ValueRL,
title = {Value Residual Learning For Alleviating Attention Concentration In Transformers},
author = {Zhanchao Zhou and Tianyi Wu and Zhiyun Jiang and Zhenzhong Lan},
year = {2024},
url = {https://api.semanticscholar.org/CorpusID:273532030}
}
```
*I visualise a time when we will be to robots what dogs are to humans, and I’m rooting for the machines.* — Claude Shannon
Raw data
{
"_id": null,
"home_page": "https://github.com/lucidrains/vit-pytorch",
"name": "vit-pytorch",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "artificial intelligence, attention mechanism, image recognition",
"author": "Phil Wang",
"author_email": "lucidrains@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/58/e5/59af62af485f99e4cefc5c8a30f01253bcaae80f233e3261db41e5ec3455/vit_pytorch-1.8.7.tar.gz",
"platform": null,
"description": "<img src=\"./images/vit.gif\" width=\"500px\"></img>\n\n## Table of Contents\n\n- [Vision Transformer - Pytorch](#vision-transformer---pytorch)\n- [Install](#install)\n- [Usage](#usage)\n- [Parameters](#parameters)\n- [Simple ViT](#simple-vit)\n- [NaViT](#navit)\n- [Distillation](#distillation)\n- [Deep ViT](#deep-vit)\n- [CaiT](#cait)\n- [Token-to-Token ViT](#token-to-token-vit)\n- [CCT](#cct)\n- [Cross ViT](#cross-vit)\n- [PiT](#pit)\n- [LeViT](#levit)\n- [CvT](#cvt)\n- [Twins SVT](#twins-svt)\n- [CrossFormer](#crossformer)\n- [RegionViT](#regionvit)\n- [ScalableViT](#scalablevit)\n- [SepViT](#sepvit)\n- [MaxViT](#maxvit)\n- [NesT](#nest)\n- [MobileViT](#mobilevit)\n- [XCiT](#xcit)\n- [Masked Autoencoder](#masked-autoencoder)\n- [Simple Masked Image Modeling](#simple-masked-image-modeling)\n- [Masked Patch Prediction](#masked-patch-prediction)\n- [Masked Position Prediction](#masked-position-prediction)\n- [Adaptive Token Sampling](#adaptive-token-sampling)\n- [Patch Merger](#patch-merger)\n- [Vision Transformer for Small Datasets](#vision-transformer-for-small-datasets)\n- [3D Vit](#3d-vit)\n- [ViVit](#vivit)\n- [Parallel ViT](#parallel-vit)\n- [Learnable Memory ViT](#learnable-memory-vit)\n- [Dino](#dino)\n- [EsViT](#esvit)\n- [Accessing Attention](#accessing-attention)\n- [Research Ideas](#research-ideas)\n * [Efficient Attention](#efficient-attention)\n * [Combining with other Transformer improvements](#combining-with-other-transformer-improvements)\n- [FAQ](#faq)\n- [Resources](#resources)\n- [Citations](#citations)\n\n## Vision Transformer - Pytorch\n\nImplementation of <a href=\"https://openreview.net/pdf?id=YicbFdNTTy\">Vision Transformer</a>, a simple way to achieve SOTA in vision classification with only a single transformer encoder, in Pytorch. Significance is further explained in <a href=\"https://www.youtube.com/watch?v=TrdevFK_am4\">Yannic Kilcher's</a> video. There's really not much to code here, but may as well lay it out for everyone so we expedite the attention revolution.\n\nFor a Pytorch implementation with pretrained models, please see Ross Wightman's repository <a href=\"https://github.com/rwightman/pytorch-image-models\">here</a>.\n\nThe official Jax repository is <a href=\"https://github.com/google-research/vision_transformer\">here</a>.\n\nA tensorflow2 translation also exists <a href=\"https://github.com/taki0112/vit-tensorflow\">here</a>, created by research scientist <a href=\"https://github.com/taki0112\">Junho Kim</a>! \ud83d\ude4f\n\n<a href=\"https://github.com/conceptofmind/vit-flax\">Flax translation</a> by <a href=\"https://github.com/conceptofmind\">Enrico Shippole</a>!\n\n## Install\n\n```bash\n$ pip install vit-pytorch\n```\n\n## Usage\n\n```python\nimport torch\nfrom vit_pytorch import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\n## Parameters\n\n- `image_size`: int. \nImage size. If you have rectangular images, make sure your image size is the maximum of the width and height\n- `patch_size`: int. \nSize of patches. `image_size` must be divisible by `patch_size`. \nThe number of patches is: ` n = (image_size // patch_size) ** 2` and `n` **must be greater than 16**.\n- `num_classes`: int. \nNumber of classes to classify.\n- `dim`: int. \nLast dimension of output tensor after linear transformation `nn.Linear(..., dim)`.\n- `depth`: int. \nNumber of Transformer blocks.\n- `heads`: int. \nNumber of heads in Multi-head Attention layer. \n- `mlp_dim`: int. \nDimension of the MLP (FeedForward) layer. \n- `channels`: int, default `3`. \nNumber of image's channels. \n- `dropout`: float between `[0, 1]`, default `0.`. \nDropout rate. \n- `emb_dropout`: float between `[0, 1]`, default `0`. \nEmbedding dropout rate.\n- `pool`: string, either `cls` token pooling or `mean` pooling\n\n\n## Simple ViT\n\n<a href=\"https://arxiv.org/abs/2205.01580\">An update</a> from some of the same authors of the original paper proposes simplifications to `ViT` that allows it to train faster and better.\n\nAmong these simplifications include 2d sinusoidal positional embedding, global average pooling (no CLS token), no dropout, batch sizes of 1024 rather than 4096, and use of RandAugment and MixUp augmentations. They also show that a simple linear at the end is not significantly worse than the original MLP head\n\nYou can use it by importing the `SimpleViT` as shown below\n\n```python\nimport torch\nfrom vit_pytorch import SimpleViT\n\nv = SimpleViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\n## NaViT\n\n<img src=\"./images/navit.png\" width=\"450px\"></img>\n\n<a href=\"https://arxiv.org/abs/2307.06304\">This paper</a> proposes to leverage the flexibility of attention and masking for variable lengthed sequences to train images of multiple resolution, packed into a single batch. They demonstrate much faster training and improved accuracies, with the only cost being extra complexity in the architecture and dataloading. They use factorized 2d positional encodings, token dropping, as well as query-key normalization.\n\nYou can use it as follows\n\n```python\nimport torch\nfrom vit_pytorch.na_vit import NaViT\n\nv = NaViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1,\n token_dropout_prob = 0.1 # token dropout of 10% (keep 90% of tokens)\n)\n\n# 5 images of different resolutions - List[List[Tensor]]\n\n# for now, you'll have to correctly place images in same batch element as to not exceed maximum allowed sequence length for self-attention w/ masking\n\nimages = [\n [torch.randn(3, 256, 256), torch.randn(3, 128, 128)],\n [torch.randn(3, 128, 256), torch.randn(3, 256, 128)],\n [torch.randn(3, 64, 256)]\n]\n\npreds = v(images) # (5, 1000) - 5, because 5 images of different resolution above\n\n```\n\nOr if you would rather that the framework auto group the images into variable lengthed sequences that do not exceed a certain max length\n\n```python\nimages = [\n torch.randn(3, 256, 256),\n torch.randn(3, 128, 128),\n torch.randn(3, 128, 256),\n torch.randn(3, 256, 128),\n torch.randn(3, 64, 256)\n]\n\npreds = v(\n images,\n group_images = True,\n group_max_seq_len = 64\n) # (5, 1000)\n```\n\nFinally, if you would like to make use of a flavor of NaViT using <a href=\"https://pytorch.org/tutorials/prototype/nestedtensor.html\">nested tensors</a> (which will omit a lot of the masking and padding altogether), make sure you are on version `2.4` and import as follows\n\n```python\nimport torch\nfrom vit_pytorch.na_vit_nested_tensor import NaViT\n\nv = NaViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.,\n emb_dropout = 0.,\n token_dropout_prob = 0.1\n)\n\n# 5 images of different resolutions - List[Tensor]\n\nimages = [\n torch.randn(3, 256, 256), torch.randn(3, 128, 128),\n torch.randn(3, 128, 256), torch.randn(3, 256, 128),\n torch.randn(3, 64, 256)\n]\n\npreds = v(images)\n\nassert preds.shape == (5, 1000)\n```\n\n## Distillation\n\n<img src=\"./images/distill.png\" width=\"300px\"></img>\n\nA recent <a href=\"https://arxiv.org/abs/2012.12877\">paper</a> has shown that use of a distillation token for distilling knowledge from convolutional nets to vision transformer can yield small and efficient vision transformers. This repository offers the means to do distillation easily.\n\nex. distilling from Resnet50 (or any teacher) to a vision transformer\n\n```python\nimport torch\nfrom torchvision.models import resnet50\n\nfrom vit_pytorch.distill import DistillableViT, DistillWrapper\n\nteacher = resnet50(pretrained = True)\n\nv = DistillableViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\ndistiller = DistillWrapper(\n student = v,\n teacher = teacher,\n temperature = 3, # temperature of distillation\n alpha = 0.5, # trade between main loss and distillation loss\n hard = False # whether to use soft or hard distillation\n)\n\nimg = torch.randn(2, 3, 256, 256)\nlabels = torch.randint(0, 1000, (2,))\n\nloss = distiller(img, labels)\nloss.backward()\n\n# after lots of training above ...\n\npred = v(img) # (2, 1000)\n```\n\nThe `DistillableViT` class is identical to `ViT` except for how the forward pass is handled, so you should be able to load the parameters back to `ViT` after you have completed distillation training.\n\nYou can also use the handy `.to_vit` method on the `DistillableViT` instance to get back a `ViT` instance.\n\n```python\nv = v.to_vit()\ntype(v) # <class 'vit_pytorch.vit_pytorch.ViT'>\n```\n\n\n## Deep ViT\n\nThis <a href=\"https://arxiv.org/abs/2103.11886\">paper</a> notes that ViT struggles to attend at greater depths (past 12 layers), and suggests mixing the attention of each head post-softmax as a solution, dubbed Re-attention. The results line up with the <a href=\"https://github.com/lucidrains/x-transformers#talking-heads-attention\">Talking Heads</a> paper from NLP.\n\nYou can use it as follows\n\n```python\nimport torch\nfrom vit_pytorch.deepvit import DeepViT\n\nv = DeepViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\n## CaiT\n\n<a href=\"https://arxiv.org/abs/2103.17239\">This paper</a> also notes difficulty in training vision transformers at greater depths and proposes two solutions. First it proposes to do per-channel multiplication of the output of the residual block. Second, it proposes to have the patches attend to one another, and only allow the CLS token to attend to the patches in the last few layers.\n\nThey also add <a href=\"https://github.com/lucidrains/x-transformers#talking-heads-attention\">Talking Heads</a>, noting improvements\n\nYou can use this scheme as follows\n\n```python\nimport torch\nfrom vit_pytorch.cait import CaiT\n\nv = CaiT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 12, # depth of transformer for patch to patch attention only\n cls_depth = 2, # depth of cross attention of CLS tokens to patch\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1,\n layer_dropout = 0.05 # randomly dropout 5% of the layers\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\n## Token-to-Token ViT\n\n<img src=\"./images/t2t.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2101.11986\">This paper</a> proposes that the first couple layers should downsample the image sequence by unfolding, leading to overlapping image data in each token as shown in the figure above. You can use this variant of the `ViT` as follows.\n\n```python\nimport torch\nfrom vit_pytorch.t2t import T2TViT\n\nv = T2TViT(\n dim = 512,\n image_size = 224,\n depth = 5,\n heads = 8,\n mlp_dim = 512,\n num_classes = 1000,\n t2t_layers = ((7, 4), (3, 2), (3, 2)) # tuples of the kernel size and stride of each consecutive layers of the initial token to token module\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npreds = v(img) # (1, 1000)\n```\n\n## CCT\n\n<img src=\"https://raw.githubusercontent.com/SHI-Labs/Compact-Transformers/main/images/model_sym.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2104.05704\">CCT</a> proposes compact transformers\nby using convolutions instead of patching and performing sequence pooling. This\nallows for CCT to have high accuracy and a low number of parameters.\n\nYou can use this with two methods\n```python\nimport torch\nfrom vit_pytorch.cct import CCT\n\ncct = CCT(\n img_size = (224, 448),\n embedding_dim = 384,\n n_conv_layers = 2,\n kernel_size = 7,\n stride = 2,\n padding = 3,\n pooling_kernel_size = 3,\n pooling_stride = 2,\n pooling_padding = 1,\n num_layers = 14,\n num_heads = 6,\n mlp_ratio = 3.,\n num_classes = 1000,\n positional_embedding = 'learnable', # ['sine', 'learnable', 'none']\n)\n\nimg = torch.randn(1, 3, 224, 448)\npred = cct(img) # (1, 1000)\n```\n\nAlternatively you can use one of several pre-defined models `[2,4,6,7,8,14,16]`\nwhich pre-define the number of layers, number of attention heads, the mlp ratio,\nand the embedding dimension.\n\n```python\nimport torch\nfrom vit_pytorch.cct import cct_14\n\ncct = cct_14(\n img_size = 224,\n n_conv_layers = 1,\n kernel_size = 7,\n stride = 2,\n padding = 3,\n pooling_kernel_size = 3,\n pooling_stride = 2,\n pooling_padding = 1,\n num_classes = 1000,\n positional_embedding = 'learnable', # ['sine', 'learnable', 'none']\n)\n```\n\n<a href=\"https://github.com/SHI-Labs/Compact-Transformers\">Official\nRepository</a> includes links to pretrained model checkpoints.\n\n## Cross ViT\n\n<img src=\"./images/cross_vit.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2103.14899\">This paper</a> proposes to have two vision transformers processing the image at different scales, cross attending to one every so often. They show improvements on top of the base vision transformer.\n\n```python\nimport torch\nfrom vit_pytorch.cross_vit import CrossViT\n\nv = CrossViT(\n image_size = 256,\n num_classes = 1000,\n depth = 4, # number of multi-scale encoding blocks\n sm_dim = 192, # high res dimension\n sm_patch_size = 16, # high res patch size (should be smaller than lg_patch_size)\n sm_enc_depth = 2, # high res depth\n sm_enc_heads = 8, # high res heads\n sm_enc_mlp_dim = 2048, # high res feedforward dimension\n lg_dim = 384, # low res dimension\n lg_patch_size = 64, # low res patch size\n lg_enc_depth = 3, # low res depth\n lg_enc_heads = 8, # low res heads\n lg_enc_mlp_dim = 2048, # low res feedforward dimensions\n cross_attn_depth = 2, # cross attention rounds\n cross_attn_heads = 8, # cross attention heads\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npred = v(img) # (1, 1000)\n```\n\n## PiT\n\n<img src=\"./images/pit.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2103.16302\">This paper</a> proposes to downsample the tokens through a pooling procedure using depth-wise convolutions.\n\n```python\nimport torch\nfrom vit_pytorch.pit import PiT\n\nv = PiT(\n image_size = 224,\n patch_size = 14,\n dim = 256,\n num_classes = 1000,\n depth = (3, 3, 3), # list of depths, indicating the number of rounds of each stage before a downsample\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\n# forward pass now returns predictions and the attention maps\n\nimg = torch.randn(1, 3, 224, 224)\n\npreds = v(img) # (1, 1000)\n```\n\n## LeViT\n\n<img src=\"./images/levit.png\" width=\"300px\"></img>\n\n<a href=\"https://arxiv.org/abs/2104.01136\">This paper</a> proposes a number of changes, including (1) convolutional embedding instead of patch-wise projection (2) downsampling in stages (3) extra non-linearity in attention (4) 2d relative positional biases instead of initial absolute positional bias (5) batchnorm in place of layernorm.\n\n<a href=\"https://github.com/facebookresearch/LeViT\">Official repository</a>\n\n```python\nimport torch\nfrom vit_pytorch.levit import LeViT\n\nlevit = LeViT(\n image_size = 224,\n num_classes = 1000,\n stages = 3, # number of stages\n dim = (256, 384, 512), # dimensions at each stage\n depth = 4, # transformer of depth 4 at each stage\n heads = (4, 6, 8), # heads at each stage\n mlp_mult = 2,\n dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\nlevit(img) # (1, 1000)\n```\n\n## CvT\n\n<img src=\"./images/cvt.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2103.15808\">This paper</a> proposes mixing convolutions and attention. Specifically, convolutions are used to embed and downsample the image / feature map in three stages. Depthwise-convoltion is also used to project the queries, keys, and values for attention.\n\n```python\nimport torch\nfrom vit_pytorch.cvt import CvT\n\nv = CvT(\n num_classes = 1000,\n s1_emb_dim = 64, # stage 1 - dimension\n s1_emb_kernel = 7, # stage 1 - conv kernel\n s1_emb_stride = 4, # stage 1 - conv stride\n s1_proj_kernel = 3, # stage 1 - attention ds-conv kernel size\n s1_kv_proj_stride = 2, # stage 1 - attention key / value projection stride\n s1_heads = 1, # stage 1 - heads\n s1_depth = 1, # stage 1 - depth\n s1_mlp_mult = 4, # stage 1 - feedforward expansion factor\n s2_emb_dim = 192, # stage 2 - (same as above)\n s2_emb_kernel = 3,\n s2_emb_stride = 2,\n s2_proj_kernel = 3,\n s2_kv_proj_stride = 2,\n s2_heads = 3,\n s2_depth = 2,\n s2_mlp_mult = 4,\n s3_emb_dim = 384, # stage 3 - (same as above)\n s3_emb_kernel = 3,\n s3_emb_stride = 2,\n s3_proj_kernel = 3,\n s3_kv_proj_stride = 2,\n s3_heads = 4,\n s3_depth = 10,\n s3_mlp_mult = 4,\n dropout = 0.\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npred = v(img) # (1, 1000)\n```\n\n## Twins SVT\n\n<img src=\"./images/twins_svt.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2104.13840\">paper</a> proposes mixing local and global attention, along with position encoding generator (proposed in <a href=\"https://arxiv.org/abs/2102.10882\">CPVT</a>) and global average pooling, to achieve the same results as <a href=\"https://arxiv.org/abs/2103.14030\">Swin</a>, without the extra complexity of shifted windows, CLS tokens, nor positional embeddings.\n\n```python\nimport torch\nfrom vit_pytorch.twins_svt import TwinsSVT\n\nmodel = TwinsSVT(\n num_classes = 1000, # number of output classes\n s1_emb_dim = 64, # stage 1 - patch embedding projected dimension\n s1_patch_size = 4, # stage 1 - patch size for patch embedding\n s1_local_patch_size = 7, # stage 1 - patch size for local attention\n s1_global_k = 7, # stage 1 - global attention key / value reduction factor, defaults to 7 as specified in paper\n s1_depth = 1, # stage 1 - number of transformer blocks (local attn -> ff -> global attn -> ff)\n s2_emb_dim = 128, # stage 2 (same as above)\n s2_patch_size = 2,\n s2_local_patch_size = 7,\n s2_global_k = 7,\n s2_depth = 1,\n s3_emb_dim = 256, # stage 3 (same as above)\n s3_patch_size = 2,\n s3_local_patch_size = 7,\n s3_global_k = 7,\n s3_depth = 5,\n s4_emb_dim = 512, # stage 4 (same as above)\n s4_patch_size = 2,\n s4_local_patch_size = 7,\n s4_global_k = 7,\n s4_depth = 4,\n peg_kernel_size = 3, # positional encoding generator kernel size\n dropout = 0. # dropout\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npred = model(img) # (1, 1000)\n```\n\n## RegionViT\n\n<img src=\"./images/regionvit.png\" width=\"400px\"></img>\n\n<img src=\"./images/regionvit2.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2106.02689\">This paper</a> proposes to divide up the feature map into local regions, whereby the local tokens attend to each other. Each local region has its own regional token which then attends to all its local tokens, as well as other regional tokens.\n\nYou can use it as follows\n\n```python\nimport torch\nfrom vit_pytorch.regionvit import RegionViT\n\nmodel = RegionViT(\n dim = (64, 128, 256, 512), # tuple of size 4, indicating dimension at each stage\n depth = (2, 2, 8, 2), # depth of the region to local transformer at each stage\n window_size = 7, # window size, which should be either 7 or 14\n num_classes = 1000, # number of output classes\n tokenize_local_3_conv = False, # whether to use a 3 layer convolution to encode the local tokens from the image. the paper uses this for the smaller models, but uses only 1 conv (set to False) for the larger models\n use_peg = False, # whether to use positional generating module. they used this for object detection for a boost in performance\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npred = model(img) # (1, 1000)\n```\n\n## CrossFormer\n\n<img src=\"./images/crossformer.png\" width=\"400px\"></img>\n\n<img src=\"./images/crossformer2.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2108.00154\">paper</a> beats PVT and Swin using alternating local and global attention. The global attention is done across the windowing dimension for reduced complexity, much like the scheme used for axial attention.\n\nThey also have cross-scale embedding layer, which they shown to be a generic layer that can improve all vision transformers. Dynamic relative positional bias was also formulated to allow the net to generalize to images of greater resolution.\n\n```python\nimport torch\nfrom vit_pytorch.crossformer import CrossFormer\n\nmodel = CrossFormer(\n num_classes = 1000, # number of output classes\n dim = (64, 128, 256, 512), # dimension at each stage\n depth = (2, 2, 8, 2), # depth of transformer at each stage\n global_window_size = (8, 4, 2, 1), # global window sizes at each stage\n local_window_size = 7, # local window size (can be customized for each stage, but in paper, held constant at 7 for all stages)\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npred = model(img) # (1, 1000)\n```\n\n## ScalableViT\n\n<img src=\"./images/scalable-vit-1.png\" width=\"400px\"></img>\n\n<img src=\"./images/scalable-vit-2.png\" width=\"400px\"></img>\n\nThis Bytedance AI <a href=\"https://arxiv.org/abs/2203.10790\">paper</a> proposes the Scalable Self Attention (SSA) and the Interactive Windowed Self Attention (IWSA) modules. The SSA alleviates the computation needed at earlier stages by reducing the key / value feature map by some factor (`reduction_factor`), while modulating the dimension of the queries and keys (`ssa_dim_key`). The IWSA performs self attention within local windows, similar to other vision transformer papers. However, they add a residual of the values, passed through a convolution of kernel size 3, which they named Local Interactive Module (LIM).\n\nThey make the claim in this paper that this scheme outperforms Swin Transformer, and also demonstrate competitive performance against Crossformer.\n\nYou can use it as follows (ex. ScalableViT-S)\n\n```python\nimport torch\nfrom vit_pytorch.scalable_vit import ScalableViT\n\nmodel = ScalableViT(\n num_classes = 1000,\n dim = 64, # starting model dimension. at every stage, dimension is doubled\n heads = (2, 4, 8, 16), # number of attention heads at each stage\n depth = (2, 2, 20, 2), # number of transformer blocks at each stage\n ssa_dim_key = (40, 40, 40, 32), # the dimension of the attention keys (and queries) for SSA. in the paper, they represented this as a scale factor on the base dimension per key (ssa_dim_key / dim_key)\n reduction_factor = (8, 4, 2, 1), # downsampling of the key / values in SSA. in the paper, this was represented as (reduction_factor ** -2)\n window_size = (64, 32, None, None), # window size of the IWSA at each stage. None means no windowing needed\n dropout = 0.1, # attention and feedforward dropout\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = model(img) # (1, 1000)\n```\n\n## SepViT\n\n<img src=\"./images/sep-vit.png\" width=\"400px\"></img>\n\nAnother <a href=\"https://arxiv.org/abs/2203.15380\">Bytedance AI paper</a>, it proposes a depthwise-pointwise self-attention layer that seems largely inspired by mobilenet's depthwise-separable convolution. The most interesting aspect is the reuse of the feature map from the depthwise self-attention stage as the values for the pointwise self-attention, as shown in the diagram above.\n\nI have decided to include only the version of `SepViT` with this specific self-attention layer, as the grouped attention layers are not remarkable nor novel, and the authors were not clear on how they treated the window tokens for the group self-attention layer. Besides, it seems like with `DSSA` layer alone, they were able to beat Swin.\n\nex. SepViT-Lite\n\n```python\nimport torch\nfrom vit_pytorch.sep_vit import SepViT\n\nv = SepViT(\n num_classes = 1000,\n dim = 32, # dimensions of first stage, which doubles every stage (32, 64, 128, 256) for SepViT-Lite\n dim_head = 32, # attention head dimension\n heads = (1, 2, 4, 8), # number of heads per stage\n depth = (1, 2, 6, 2), # number of transformer blocks per stage\n window_size = 7, # window size of DSS Attention block\n dropout = 0.1 # dropout\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npreds = v(img) # (1, 1000)\n```\n\n## MaxViT\n\n<img src=\"./images/max-vit.png\" width=\"400px\"></img>\n\n<a href=\"https://arxiv.org/abs/2204.01697\">This paper</a> proposes a hybrid convolutional / attention network, using MBConv from the convolution side, and then block / grid axial sparse attention.\n\nThey also claim this specific vision transformer is good for generative models (GANs).\n\nex. MaxViT-S\n\n```python\nimport torch\nfrom vit_pytorch.max_vit import MaxViT\n\nv = MaxViT(\n num_classes = 1000,\n dim_conv_stem = 64, # dimension of the convolutional stem, would default to dimension of first layer if not specified\n dim = 96, # dimension of first layer, doubles every layer\n dim_head = 32, # dimension of attention heads, kept at 32 in paper\n depth = (2, 2, 5, 2), # number of MaxViT blocks per stage, which consists of MBConv, block-like attention, grid-like attention\n window_size = 7, # window size for block and grids\n mbconv_expansion_rate = 4, # expansion rate of MBConv\n mbconv_shrinkage_rate = 0.25, # shrinkage rate of squeeze-excitation in MBConv\n dropout = 0.1 # dropout\n)\n\nimg = torch.randn(2, 3, 224, 224)\n\npreds = v(img) # (2, 1000)\n```\n\n## NesT\n\n<img src=\"./images/nest.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2105.12723\">paper</a> decided to process the image in hierarchical stages, with attention only within tokens of local blocks, which aggregate as it moves up the hierarchy. The aggregation is done in the image plane, and contains a convolution and subsequent maxpool to allow it to pass information across the boundary.\n\nYou can use it with the following code (ex. NesT-T)\n\n```python\nimport torch\nfrom vit_pytorch.nest import NesT\n\nnest = NesT(\n image_size = 224,\n patch_size = 4,\n dim = 96,\n heads = 3,\n num_hierarchies = 3, # number of hierarchies\n block_repeats = (2, 2, 8), # the number of transformer blocks at each hierarchy, starting from the bottom\n num_classes = 1000\n)\n\nimg = torch.randn(1, 3, 224, 224)\n\npred = nest(img) # (1, 1000)\n```\n\n## MobileViT\n\n<img src=\"./images/mbvit.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2110.02178\">paper</a> introduce MobileViT, a light-weight and general purpose vision transformer for mobile devices. MobileViT presents a different\nperspective for the global processing of information with transformers.\n\nYou can use it with the following code (ex. mobilevit_xs)\n\n```python\nimport torch\nfrom vit_pytorch.mobile_vit import MobileViT\n\nmbvit_xs = MobileViT(\n image_size = (256, 256),\n dims = [96, 120, 144],\n channels = [16, 32, 48, 48, 64, 64, 80, 80, 96, 96, 384],\n num_classes = 1000\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npred = mbvit_xs(img) # (1, 1000)\n```\n\n## XCiT\n\n<img src=\"./images/xcit.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2106.09681\">paper</a> introduces the cross covariance attention (abbreviated XCA). One can think of it as doing attention across the features dimension rather than the spatial one (another perspective would be a dynamic 1x1 convolution, the kernel being attention map defined by spatial correlations).\n\nTechnically, this amounts to simply transposing the query, key, values before executing cosine similarity attention with learned temperature.\n\n```python\nimport torch\nfrom vit_pytorch.xcit import XCiT\n\nv = XCiT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 12, # depth of xcit transformer\n cls_depth = 2, # depth of cross attention of CLS tokens to patch, attention pool at end\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1,\n layer_dropout = 0.05, # randomly dropout 5% of the layers\n local_patch_kernel_size = 3 # kernel size of the local patch interaction module (depthwise convs)\n)\n\nimg = torch.randn(1, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\n## Simple Masked Image Modeling\n\n<img src=\"./images/simmim.png\" width=\"400px\"/>\n\nThis <a href=\"https://arxiv.org/abs/2111.09886\">paper</a> proposes a simple masked image modeling (SimMIM) scheme, using only a linear projection off the masked tokens into pixel space followed by an L1 loss with the pixel values of the masked patches. Results are competitive with other more complicated approaches.\n\nYou can use this as follows\n\n```python\nimport torch\nfrom vit_pytorch import ViT\nfrom vit_pytorch.simmim import SimMIM\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048\n)\n\nmim = SimMIM(\n encoder = v,\n masking_ratio = 0.5 # they found 50% to yield the best results\n)\n\nimages = torch.randn(8, 3, 256, 256)\n\nloss = mim(images)\nloss.backward()\n\n# that's all!\n# do the above in a for loop many times with a lot of images and your vision transformer will learn\n\ntorch.save(v.state_dict(), './trained-vit.pt')\n```\n\n\n## Masked Autoencoder\n\n<img src=\"./images/mae.png\" width=\"400px\"/>\n\nA new <a href=\"https://arxiv.org/abs/2111.06377\">Kaiming He paper</a> proposes a simple autoencoder scheme where the vision transformer attends to a set of unmasked patches, and a smaller decoder tries to reconstruct the masked pixel values.\n\n<a href=\"https://www.youtube.com/watch?v=LKixq2S2Pz8\">DeepReader quick paper review</a>\n\n<a href=\"https://www.youtube.com/watch?v=Dp6iICL2dVI\">AI Coffeebreak with Letitia</a>\n\nYou can use it with the following code\n\n```python\nimport torch\nfrom vit_pytorch import ViT, MAE\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048\n)\n\nmae = MAE(\n encoder = v,\n masking_ratio = 0.75, # the paper recommended 75% masked patches\n decoder_dim = 512, # paper showed good results with just 512\n decoder_depth = 6 # anywhere from 1 to 8\n)\n\nimages = torch.randn(8, 3, 256, 256)\n\nloss = mae(images)\nloss.backward()\n\n# that's all!\n# do the above in a for loop many times with a lot of images and your vision transformer will learn\n\n# save your improved vision transformer\ntorch.save(v.state_dict(), './trained-vit.pt')\n```\n\n## Masked Patch Prediction\n\nThanks to <a href=\"https://github.com/zankner\">Zach</a>, you can train using the original masked patch prediction task presented in the paper, with the following code.\n\n```python\nimport torch\nfrom vit_pytorch import ViT\nfrom vit_pytorch.mpp import MPP\n\nmodel = ViT(\n image_size=256,\n patch_size=32,\n num_classes=1000,\n dim=1024,\n depth=6,\n heads=8,\n mlp_dim=2048,\n dropout=0.1,\n emb_dropout=0.1\n)\n\nmpp_trainer = MPP(\n transformer=model,\n patch_size=32,\n dim=1024,\n mask_prob=0.15, # probability of using token in masked prediction task\n random_patch_prob=0.30, # probability of randomly replacing a token being used for mpp\n replace_prob=0.50, # probability of replacing a token being used for mpp with the mask token\n)\n\nopt = torch.optim.Adam(mpp_trainer.parameters(), lr=3e-4)\n\ndef sample_unlabelled_images():\n return torch.FloatTensor(20, 3, 256, 256).uniform_(0., 1.)\n\nfor _ in range(100):\n images = sample_unlabelled_images()\n loss = mpp_trainer(images)\n opt.zero_grad()\n loss.backward()\n opt.step()\n\n# save your improved network\ntorch.save(model.state_dict(), './pretrained-net.pt')\n```\n\n## Masked Position Prediction\n\n<img src=\"./images/mp3.png\" width=\"400px\"></img>\n\nNew <a href=\"https://arxiv.org/abs/2207.07611\">paper</a> that introduces masked position prediction pre-training criteria. This strategy is more efficient than the Masked Autoencoder strategy and has comparable performance. \n\n```python\nimport torch\nfrom vit_pytorch.mp3 import ViT, MP3\n\nv = ViT(\n num_classes = 1000,\n image_size = 256,\n patch_size = 8,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048,\n dropout = 0.1,\n)\n\nmp3 = MP3(\n vit = v,\n masking_ratio = 0.75\n)\n\nimages = torch.randn(8, 3, 256, 256)\n\nloss = mp3(images)\nloss.backward()\n\n# that's all!\n# do the above in a for loop many times with a lot of images and your vision transformer will learn\n\n# save your improved vision transformer\ntorch.save(v.state_dict(), './trained-vit.pt')\n```\n\n## Adaptive Token Sampling\n\n<img src=\"./images/ats.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2111.15667\">paper</a> proposes to use the CLS attention scores, re-weighed by the norms of the value heads, as means to discard unimportant tokens at different layers.\n\n```python\nimport torch\nfrom vit_pytorch.ats_vit import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 16,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n max_tokens_per_depth = (256, 128, 64, 32, 16, 8), # a tuple that denotes the maximum number of tokens that any given layer should have. if the layer has greater than this amount, it will undergo adaptive token sampling\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(4, 3, 256, 256)\n\npreds = v(img) # (4, 1000)\n\n# you can also get a list of the final sampled patch ids\n# a value of -1 denotes padding\n\npreds, token_ids = v(img, return_sampled_token_ids = True) # (4, 1000), (4, <=8)\n```\n\n## Patch Merger\n\n\n<img src=\"./images/patch_merger.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2202.12015\">paper</a> proposes a simple module (Patch Merger) for reducing the number of tokens at any layer of a vision transformer without sacrificing performance.\n\n```python\nimport torch\nfrom vit_pytorch.vit_with_patch_merger import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 16,\n num_classes = 1000,\n dim = 1024,\n depth = 12,\n heads = 8,\n patch_merge_layer = 6, # at which transformer layer to do patch merging\n patch_merge_num_tokens = 8, # the output number of tokens from the patch merge\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(4, 3, 256, 256)\n\npreds = v(img) # (4, 1000)\n```\n\nOne can also use the `PatchMerger` module by itself\n\n```python\nimport torch\nfrom vit_pytorch.vit_with_patch_merger import PatchMerger\n\nmerger = PatchMerger(\n dim = 1024,\n num_tokens_out = 8 # output number of tokens\n)\n\nfeatures = torch.randn(4, 256, 1024) # (batch, num tokens, dimension)\n\nout = merger(features) # (4, 8, 1024)\n```\n\n## Vision Transformer for Small Datasets\n\n<img src=\"./images/vit_for_small_datasets.png\" width=\"400px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2112.13492\">paper</a> proposes a new image to patch function that incorporates shifts of the image, before normalizing and dividing the image into patches. I have found shifting to be extremely helpful in some other transformers work, so decided to include this for further explorations. It also includes the `LSA` with the learned temperature and masking out of a token's attention to itself.\n\nYou can use as follows:\n\n```python\nimport torch\nfrom vit_pytorch.vit_for_small_dataset import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 16,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(4, 3, 256, 256)\n\npreds = v(img) # (1, 1000)\n```\n\nYou can also use the `SPT` from this paper as a standalone module\n\n```python\nimport torch\nfrom vit_pytorch.vit_for_small_dataset import SPT\n\nspt = SPT(\n dim = 1024,\n patch_size = 16,\n channels = 3\n)\n\nimg = torch.randn(4, 3, 256, 256)\n\ntokens = spt(img) # (4, 256, 1024)\n```\n\n## 3D ViT\n\nBy popular request, I will start extending a few of the architectures in this repository to 3D ViTs, for use with video, medical imaging, etc.\n\nYou will need to pass in two additional hyperparameters: (1) the number of frames `frames` and (2) patch size along the frame dimension `frame_patch_size`\n\nFor starters, 3D ViT\n\n```python\nimport torch\nfrom vit_pytorch.vit_3d import ViT\n\nv = ViT(\n image_size = 128, # image size\n frames = 16, # number of frames\n image_patch_size = 16, # image patch size\n frame_patch_size = 2, # frame patch size\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nvideo = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)\n\npreds = v(video) # (4, 1000)\n```\n\n3D Simple ViT\n\n```python\nimport torch\nfrom vit_pytorch.simple_vit_3d import SimpleViT\n\nv = SimpleViT(\n image_size = 128, # image size\n frames = 16, # number of frames\n image_patch_size = 16, # image patch size\n frame_patch_size = 2, # frame patch size\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048\n)\n\nvideo = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)\n\npreds = v(video) # (4, 1000)\n```\n\n3D version of <a href=\"https://github.com/lucidrains/vit-pytorch#cct\">CCT</a>\n\n```python\nimport torch\nfrom vit_pytorch.cct_3d import CCT\n\ncct = CCT(\n img_size = 224,\n num_frames = 8,\n embedding_dim = 384,\n n_conv_layers = 2,\n frame_kernel_size = 3,\n kernel_size = 7,\n stride = 2,\n padding = 3,\n pooling_kernel_size = 3,\n pooling_stride = 2,\n pooling_padding = 1,\n num_layers = 14,\n num_heads = 6,\n mlp_ratio = 3.,\n num_classes = 1000,\n positional_embedding = 'learnable'\n)\n\nvideo = torch.randn(1, 3, 8, 224, 224) # (batch, channels, frames, height, width)\npred = cct(video)\n```\n\n## ViViT\n\n<img src=\"./images/vivit.png\" width=\"350px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2103.15691\">paper</a> offers 3 different types of architectures for efficient attention of videos, with the main theme being factorizing the attention across space and time. This repository includes the factorized encoder and the factorized self-attention variant.\nThe factorized encoder variant is a spatial transformer followed by a temporal one. The factorized self-attention variant is a spatio-temporal transformer with alternating spatial and temporal self-attention layers.\n\n```python\nimport torch\nfrom vit_pytorch.vivit import ViT\n\nv = ViT(\n image_size = 128, # image size\n frames = 16, # number of frames\n image_patch_size = 16, # image patch size\n frame_patch_size = 2, # frame patch size\n num_classes = 1000,\n dim = 1024,\n spatial_depth = 6, # depth of the spatial transformer\n temporal_depth = 6, # depth of the temporal transformer\n heads = 8,\n mlp_dim = 2048,\n variant = 'factorized_encoder', # or 'factorized_self_attention'\n)\n\nvideo = torch.randn(4, 3, 16, 128, 128) # (batch, channels, frames, height, width)\n\npreds = v(video) # (4, 1000)\n```\n\n## Parallel ViT\n\n<img src=\"./images/parallel-vit.png\" width=\"350px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2203.09795\">paper</a> propose parallelizing multiple attention and feedforward blocks per layer (2 blocks), claiming that it is easier to train without loss of performance.\n\nYou can try this variant as follows\n\n```python\nimport torch\nfrom vit_pytorch.parallel_vit import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 16,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048,\n num_parallel_branches = 2, # in paper, they claimed 2 was optimal\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(4, 3, 256, 256)\n\npreds = v(img) # (4, 1000)\n```\n\n## Learnable Memory ViT\n\n<img src=\"./images/learnable-memory-vit.png\" width=\"350px\"></img>\n\nThis <a href=\"https://arxiv.org/abs/2203.15243\">paper</a> shows that adding learnable memory tokens at each layer of a vision transformer can greatly enhance fine-tuning results (in addition to learnable task specific CLS token and adapter head).\n\nYou can use this with a specially modified `ViT` as follows\n\n```python\nimport torch\nfrom vit_pytorch.learnable_memory_vit import ViT, Adapter\n\n# normal base ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 16,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(4, 3, 256, 256)\nlogits = v(img) # (4, 1000)\n\n# do your usual training with ViT\n# ...\n\n\n# then, to finetune, just pass the ViT into the Adapter class\n# you can do this for multiple Adapters, as shown below\n\nadapter1 = Adapter(\n vit = v,\n num_classes = 2, # number of output classes for this specific task\n num_memories_per_layer = 5 # number of learnable memories per layer, 10 was sufficient in paper\n)\n\nlogits1 = adapter1(img) # (4, 2) - predict 2 classes off frozen ViT backbone with learnable memories and task specific head\n\n# yet another task to finetune on, this time with 4 classes\n\nadapter2 = Adapter(\n vit = v,\n num_classes = 4,\n num_memories_per_layer = 10\n)\n\nlogits2 = adapter2(img) # (4, 4) - predict 4 classes off frozen ViT backbone with learnable memories and task specific head\n\n```\n\n## Dino\n\n<img src=\"./images/dino.png\" width=\"350px\"></img>\n\nYou can train `ViT` with the recent SOTA self-supervised learning technique, <a href=\"https://arxiv.org/abs/2104.14294\">Dino</a>, with the following code.\n\n<a href=\"https://www.youtube.com/watch?v=h3ij3F3cPIk\">Yannic Kilcher</a> video\n\n```python\nimport torch\nfrom vit_pytorch import ViT, Dino\n\nmodel = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 8,\n mlp_dim = 2048\n)\n\nlearner = Dino(\n model,\n image_size = 256,\n hidden_layer = 'to_latent', # hidden layer name or index, from which to extract the embedding\n projection_hidden_size = 256, # projector network hidden dimension\n projection_layers = 4, # number of layers in projection network\n num_classes_K = 65336, # output logits dimensions (referenced as K in paper)\n student_temp = 0.9, # student temperature\n teacher_temp = 0.04, # teacher temperature, needs to be annealed from 0.04 to 0.07 over 30 epochs\n local_upper_crop_scale = 0.4, # upper bound for local crop - 0.4 was recommended in the paper \n global_lower_crop_scale = 0.5, # lower bound for global crop - 0.5 was recommended in the paper\n moving_average_decay = 0.9, # moving average of encoder - paper showed anywhere from 0.9 to 0.999 was ok\n center_moving_average_decay = 0.9, # moving average of teacher centers - paper showed anywhere from 0.9 to 0.999 was ok\n)\n\nopt = torch.optim.Adam(learner.parameters(), lr = 3e-4)\n\ndef sample_unlabelled_images():\n return torch.randn(20, 3, 256, 256)\n\nfor _ in range(100):\n images = sample_unlabelled_images()\n loss = learner(images)\n opt.zero_grad()\n loss.backward()\n opt.step()\n learner.update_moving_average() # update moving average of teacher encoder and teacher centers\n\n# save your improved network\ntorch.save(model.state_dict(), './pretrained-net.pt')\n```\n\n## EsViT\n\n<img src=\"./images/esvit.png\" width=\"350px\"></img>\n\n<a href=\"https://arxiv.org/abs/2106.09785\">`EsViT`</a> is a variant of Dino (from above) re-engineered to support efficient `ViT`s with patch merging / downsampling by taking into an account an extra regional loss between the augmented views. To quote the abstract, it `outperforms its supervised counterpart on 17 out of 18 datasets` at 3 times higher throughput.\n\nEven though it is named as though it were a new `ViT` variant, it actually is just a strategy for training any multistage `ViT` (in the paper, they focused on Swin). The example below will show how to use it with `CvT`. You'll need to set the `hidden_layer` to the name of the layer within your efficient ViT that outputs the non-average pooled visual representations, just before the global pooling and projection to logits.\n\n```python\nimport torch\nfrom vit_pytorch.cvt import CvT\nfrom vit_pytorch.es_vit import EsViTTrainer\n\ncvt = CvT(\n num_classes = 1000,\n s1_emb_dim = 64,\n s1_emb_kernel = 7,\n s1_emb_stride = 4,\n s1_proj_kernel = 3,\n s1_kv_proj_stride = 2,\n s1_heads = 1,\n s1_depth = 1,\n s1_mlp_mult = 4,\n s2_emb_dim = 192,\n s2_emb_kernel = 3,\n s2_emb_stride = 2,\n s2_proj_kernel = 3,\n s2_kv_proj_stride = 2,\n s2_heads = 3,\n s2_depth = 2,\n s2_mlp_mult = 4,\n s3_emb_dim = 384,\n s3_emb_kernel = 3,\n s3_emb_stride = 2,\n s3_proj_kernel = 3,\n s3_kv_proj_stride = 2,\n s3_heads = 4,\n s3_depth = 10,\n s3_mlp_mult = 4,\n dropout = 0.\n)\n\nlearner = EsViTTrainer(\n cvt,\n image_size = 256,\n hidden_layer = 'layers', # hidden layer name or index, from which to extract the embedding\n projection_hidden_size = 256, # projector network hidden dimension\n projection_layers = 4, # number of layers in projection network\n num_classes_K = 65336, # output logits dimensions (referenced as K in paper)\n student_temp = 0.9, # student temperature\n teacher_temp = 0.04, # teacher temperature, needs to be annealed from 0.04 to 0.07 over 30 epochs\n local_upper_crop_scale = 0.4, # upper bound for local crop - 0.4 was recommended in the paper\n global_lower_crop_scale = 0.5, # lower bound for global crop - 0.5 was recommended in the paper\n moving_average_decay = 0.9, # moving average of encoder - paper showed anywhere from 0.9 to 0.999 was ok\n center_moving_average_decay = 0.9, # moving average of teacher centers - paper showed anywhere from 0.9 to 0.999 was ok\n)\n\nopt = torch.optim.AdamW(learner.parameters(), lr = 3e-4)\n\ndef sample_unlabelled_images():\n return torch.randn(8, 3, 256, 256)\n\nfor _ in range(1000):\n images = sample_unlabelled_images()\n loss = learner(images)\n opt.zero_grad()\n loss.backward()\n opt.step()\n learner.update_moving_average() # update moving average of teacher encoder and teacher centers\n\n# save your improved network\ntorch.save(cvt.state_dict(), './pretrained-net.pt')\n```\n\n## Accessing Attention\n\nIf you would like to visualize the attention weights (post-softmax) for your research, just follow the procedure below\n\n```python\nimport torch\nfrom vit_pytorch.vit import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\n# import Recorder and wrap the ViT\n\nfrom vit_pytorch.recorder import Recorder\nv = Recorder(v)\n\n# forward pass now returns predictions and the attention maps\n\nimg = torch.randn(1, 3, 256, 256)\npreds, attns = v(img)\n\n# there is one extra patch due to the CLS token\n\nattns # (1, 6, 16, 65, 65) - (batch x layers x heads x patch x patch)\n```\n\nto cleanup the class and the hooks once you have collected enough data\n\n```python\nv = v.eject() # wrapper is discarded and original ViT instance is returned\n```\n\n## Accessing Embeddings\n\nYou can similarly access the embeddings with the `Extractor` wrapper\n\n```python\nimport torch\nfrom vit_pytorch.vit import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\n# import Recorder and wrap the ViT\n\nfrom vit_pytorch.extractor import Extractor\nv = Extractor(v)\n\n# forward pass now returns predictions and the attention maps\n\nimg = torch.randn(1, 3, 256, 256)\nlogits, embeddings = v(img)\n\n# there is one extra token due to the CLS token\n\nembeddings # (1, 65, 1024) - (batch x patches x model dim)\n```\n\nOr say for `CrossViT`, which has a multi-scale encoder that outputs two sets of embeddings for 'large' and 'small' scales\n\n```python\nimport torch\nfrom vit_pytorch.cross_vit import CrossViT\n\nv = CrossViT(\n image_size = 256,\n num_classes = 1000,\n depth = 4,\n sm_dim = 192,\n sm_patch_size = 16,\n sm_enc_depth = 2,\n sm_enc_heads = 8,\n sm_enc_mlp_dim = 2048,\n lg_dim = 384,\n lg_patch_size = 64,\n lg_enc_depth = 3,\n lg_enc_heads = 8,\n lg_enc_mlp_dim = 2048,\n cross_attn_depth = 2,\n cross_attn_heads = 8,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\n# wrap the CrossViT\n\nfrom vit_pytorch.extractor import Extractor\nv = Extractor(v, layer_name = 'multi_scale_encoder') # take embedding coming from the output of multi-scale-encoder\n\n# forward pass now returns predictions and the attention maps\n\nimg = torch.randn(1, 3, 256, 256)\nlogits, embeddings = v(img)\n\n# there is one extra token due to the CLS token\n\nembeddings # ((1, 257, 192), (1, 17, 384)) - (batch x patches x dimension) <- large and small scales respectively\n```\n\n## Research Ideas\n\n### Efficient Attention\n\nThere may be some coming from computer vision who think attention still suffers from quadratic costs. Fortunately, we have a lot of new techniques that may help. This repository offers a way for you to plugin your own sparse attention transformer.\n\nAn example with <a href=\"https://arxiv.org/abs/2102.03902\">Nystromformer</a>\n\n```bash\n$ pip install nystrom-attention\n```\n\n```python\nimport torch\nfrom vit_pytorch.efficient import ViT\nfrom nystrom_attention import Nystromformer\n\nefficient_transformer = Nystromformer(\n dim = 512,\n depth = 12,\n heads = 8,\n num_landmarks = 256\n)\n\nv = ViT(\n dim = 512,\n image_size = 2048,\n patch_size = 32,\n num_classes = 1000,\n transformer = efficient_transformer\n)\n\nimg = torch.randn(1, 3, 2048, 2048) # your high resolution picture\nv(img) # (1, 1000)\n```\n\nOther sparse attention frameworks I would highly recommend is <a href=\"https://github.com/lucidrains/routing-transformer\">Routing Transformer</a> or <a href=\"https://github.com/lucidrains/sinkhorn-transformer\">Sinkhorn Transformer</a>\n\n### Combining with other Transformer improvements\n\nThis paper purposely used the most vanilla of attention networks to make a statement. If you would like to use some of the latest improvements for attention nets, please use the `Encoder` from <a href=\"https://github.com/lucidrains/x-transformers\">this repository</a>.\n\nex.\n\n```bash\n$ pip install x-transformers\n```\n\n```python\nimport torch\nfrom vit_pytorch.efficient import ViT\nfrom x_transformers import Encoder\n\nv = ViT(\n dim = 512,\n image_size = 224,\n patch_size = 16,\n num_classes = 1000,\n transformer = Encoder(\n dim = 512, # set to be the same as the wrapper\n depth = 12,\n heads = 8,\n ff_glu = True, # ex. feed forward GLU variant https://arxiv.org/abs/2002.05202\n residual_attn = True # ex. residual attention https://arxiv.org/abs/2012.11747\n )\n)\n\nimg = torch.randn(1, 3, 224, 224)\nv(img) # (1, 1000)\n```\n\n## FAQ\n\n- How do I pass in non-square images?\n\nYou can already pass in non-square images - you just have to make sure your height and width is less than or equal to the `image_size`, and both divisible by the `patch_size`\n\nex.\n\n```python\nimport torch\nfrom vit_pytorch import ViT\n\nv = ViT(\n image_size = 256,\n patch_size = 32,\n num_classes = 1000,\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 256, 128) # <-- not a square\n\npreds = v(img) # (1, 1000)\n```\n\n- How do I pass in non-square patches?\n\n```python\nimport torch\nfrom vit_pytorch import ViT\n\nv = ViT(\n num_classes = 1000,\n image_size = (256, 128), # image size is a tuple of (height, width)\n patch_size = (32, 16), # patch size is a tuple of (height, width)\n dim = 1024,\n depth = 6,\n heads = 16,\n mlp_dim = 2048,\n dropout = 0.1,\n emb_dropout = 0.1\n)\n\nimg = torch.randn(1, 3, 256, 128)\n\npreds = v(img)\n```\n\n## Resources\n\nComing from computer vision and new to transformers? Here are some resources that greatly accelerated my learning.\n\n1. <a href=\"http://jalammar.github.io/illustrated-transformer/\">Illustrated Transformer</a> - Jay Alammar\n\n2. <a href=\"http://peterbloem.nl/blog/transformers\">Transformers from Scratch</a> - Peter Bloem\n\n3. <a href=\"https://nlp.seas.harvard.edu/2018/04/03/attention.html\">The Annotated Transformer</a> - Harvard NLP\n\n\n## Citations\n```bibtex\n@article{hassani2021escaping,\n title = {Escaping the Big Data Paradigm with Compact Transformers},\n author = {Ali Hassani and Steven Walton and Nikhil Shah and Abulikemu Abuduweili and Jiachen Li and Humphrey Shi},\n year = 2021,\n url = {https://arxiv.org/abs/2104.05704},\n eprint = {2104.05704},\n archiveprefix = {arXiv},\n primaryclass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{dosovitskiy2020image,\n title = {An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale},\n author = {Alexey Dosovitskiy and Lucas Beyer and Alexander Kolesnikov and Dirk Weissenborn and Xiaohua Zhai and Thomas Unterthiner and Mostafa Dehghani and Matthias Minderer and Georg Heigold and Sylvain Gelly and Jakob Uszkoreit and Neil Houlsby},\n year = {2020},\n eprint = {2010.11929},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{touvron2020training,\n title = {Training data-efficient image transformers & distillation through attention}, \n author = {Hugo Touvron and Matthieu Cord and Matthijs Douze and Francisco Massa and Alexandre Sablayrolles and Herv\u00e9 J\u00e9gou},\n year = {2020},\n eprint = {2012.12877},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{yuan2021tokenstotoken,\n title = {Tokens-to-Token ViT: Training Vision Transformers from Scratch on ImageNet},\n author = {Li Yuan and Yunpeng Chen and Tao Wang and Weihao Yu and Yujun Shi and Francis EH Tay and Jiashi Feng and Shuicheng Yan},\n year = {2021},\n eprint = {2101.11986},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{zhou2021deepvit,\n title = {DeepViT: Towards Deeper Vision Transformer},\n author = {Daquan Zhou and Bingyi Kang and Xiaojie Jin and Linjie Yang and Xiaochen Lian and Qibin Hou and Jiashi Feng},\n year = {2021},\n eprint = {2103.11886},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{touvron2021going,\n title = {Going deeper with Image Transformers}, \n author = {Hugo Touvron and Matthieu Cord and Alexandre Sablayrolles and Gabriel Synnaeve and Herv\u00e9 J\u00e9gou},\n year = {2021},\n eprint = {2103.17239},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{chen2021crossvit,\n title = {CrossViT: Cross-Attention Multi-Scale Vision Transformer for Image Classification},\n author = {Chun-Fu Chen and Quanfu Fan and Rameswar Panda},\n year = {2021},\n eprint = {2103.14899},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{wu2021cvt,\n title = {CvT: Introducing Convolutions to Vision Transformers},\n author = {Haiping Wu and Bin Xiao and Noel Codella and Mengchen Liu and Xiyang Dai and Lu Yuan and Lei Zhang},\n year = {2021},\n eprint = {2103.15808},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{heo2021rethinking,\n title = {Rethinking Spatial Dimensions of Vision Transformers}, \n author = {Byeongho Heo and Sangdoo Yun and Dongyoon Han and Sanghyuk Chun and Junsuk Choe and Seong Joon Oh},\n year = {2021},\n eprint = {2103.16302},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{graham2021levit,\n title = {LeViT: a Vision Transformer in ConvNet's Clothing for Faster Inference},\n author = {Ben Graham and Alaaeldin El-Nouby and Hugo Touvron and Pierre Stock and Armand Joulin and Herv\u00e9 J\u00e9gou and Matthijs Douze},\n year = {2021},\n eprint = {2104.01136},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{li2021localvit,\n title = {LocalViT: Bringing Locality to Vision Transformers},\n author = {Yawei Li and Kai Zhang and Jiezhang Cao and Radu Timofte and Luc Van Gool},\n year = {2021},\n eprint = {2104.05707},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{chu2021twins,\n title = {Twins: Revisiting Spatial Attention Design in Vision Transformers},\n author = {Xiangxiang Chu and Zhi Tian and Yuqing Wang and Bo Zhang and Haibing Ren and Xiaolin Wei and Huaxia Xia and Chunhua Shen},\n year = {2021},\n eprint = {2104.13840},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{su2021roformer,\n title = {RoFormer: Enhanced Transformer with Rotary Position Embedding}, \n author = {Jianlin Su and Yu Lu and Shengfeng Pan and Bo Wen and Yunfeng Liu},\n year = {2021},\n eprint = {2104.09864},\n archivePrefix = {arXiv},\n primaryClass = {cs.CL}\n}\n```\n\n```bibtex\n@misc{zhang2021aggregating,\n title = {Aggregating Nested Transformers},\n author = {Zizhao Zhang and Han Zhang and Long Zhao and Ting Chen and Tomas Pfister},\n year = {2021},\n eprint = {2105.12723},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{chen2021regionvit,\n title = {RegionViT: Regional-to-Local Attention for Vision Transformers}, \n author = {Chun-Fu Chen and Rameswar Panda and Quanfu Fan},\n year = {2021},\n eprint = {2106.02689},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{wang2021crossformer,\n title = {CrossFormer: A Versatile Vision Transformer Hinging on Cross-scale Attention}, \n author = {Wenxiao Wang and Lu Yao and Long Chen and Binbin Lin and Deng Cai and Xiaofei He and Wei Liu},\n year = {2021},\n eprint = {2108.00154},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{caron2021emerging,\n title = {Emerging Properties in Self-Supervised Vision Transformers},\n author = {Mathilde Caron and Hugo Touvron and Ishan Misra and Herv\u00e9 J\u00e9gou and Julien Mairal and Piotr Bojanowski and Armand Joulin},\n year = {2021},\n eprint = {2104.14294},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{he2021masked,\n title = {Masked Autoencoders Are Scalable Vision Learners}, \n author = {Kaiming He and Xinlei Chen and Saining Xie and Yanghao Li and Piotr Doll\u00e1r and Ross Girshick},\n year = {2021},\n eprint = {2111.06377},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{xie2021simmim,\n title = {SimMIM: A Simple Framework for Masked Image Modeling}, \n author = {Zhenda Xie and Zheng Zhang and Yue Cao and Yutong Lin and Jianmin Bao and Zhuliang Yao and Qi Dai and Han Hu},\n year = {2021},\n eprint = {2111.09886},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{fayyaz2021ats,\n title = {ATS: Adaptive Token Sampling For Efficient Vision Transformers},\n author = {Mohsen Fayyaz and Soroush Abbasi Kouhpayegani and Farnoush Rezaei Jafari and Eric Sommerlade and Hamid Reza Vaezi Joze and Hamed Pirsiavash and Juergen Gall},\n year = {2021},\n eprint = {2111.15667},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{mehta2021mobilevit,\n title = {MobileViT: Light-weight, General-purpose, and Mobile-friendly Vision Transformer},\n author = {Sachin Mehta and Mohammad Rastegari},\n year = {2021},\n eprint = {2110.02178},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{lee2021vision,\n title = {Vision Transformer for Small-Size Datasets}, \n author = {Seung Hoon Lee and Seunghyun Lee and Byung Cheol Song},\n year = {2021},\n eprint = {2112.13492},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{renggli2022learning,\n title = {Learning to Merge Tokens in Vision Transformers},\n author = {Cedric Renggli and Andr\u00e9 Susano Pinto and Neil Houlsby and Basil Mustafa and Joan Puigcerver and Carlos Riquelme},\n year = {2022},\n eprint = {2202.12015},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@misc{yang2022scalablevit,\n title = {ScalableViT: Rethinking the Context-oriented Generalization of Vision Transformer}, \n author = {Rui Yang and Hailong Ma and Jie Wu and Yansong Tang and Xuefeng Xiao and Min Zheng and Xiu Li},\n year = {2022},\n eprint = {2203.10790},\n archivePrefix = {arXiv},\n primaryClass = {cs.CV}\n}\n```\n\n```bibtex\n@inproceedings{Touvron2022ThreeTE,\n title = {Three things everyone should know about Vision Transformers},\n author = {Hugo Touvron and Matthieu Cord and Alaaeldin El-Nouby and Jakob Verbeek and Herv'e J'egou},\n year = {2022}\n}\n```\n\n```bibtex\n@inproceedings{Sandler2022FinetuningIT,\n title = {Fine-tuning Image Transformers using Learnable Memory},\n author = {Mark Sandler and Andrey Zhmoginov and Max Vladymyrov and Andrew Jackson},\n year = {2022}\n}\n```\n\n```bibtex\n@inproceedings{Li2022SepViTSV,\n title = {SepViT: Separable Vision Transformer},\n author = {Wei Li and Xing Wang and Xin Xia and Jie Wu and Xuefeng Xiao and Minghang Zheng and Shiping Wen},\n year = {2022}\n}\n```\n\n```bibtex\n@inproceedings{Tu2022MaxViTMV,\n title = {MaxViT: Multi-Axis Vision Transformer},\n author = {Zhengzhong Tu and Hossein Talebi and Han Zhang and Feng Yang and Peyman Milanfar and Alan Conrad Bovik and Yinxiao Li},\n year = {2022}\n}\n```\n\n```bibtex\n@article{Li2021EfficientSV,\n title = {Efficient Self-supervised Vision Transformers for Representation Learning},\n author = {Chunyuan Li and Jianwei Yang and Pengchuan Zhang and Mei Gao and Bin Xiao and Xiyang Dai and Lu Yuan and Jianfeng Gao},\n journal = {ArXiv},\n year = {2021},\n volume = {abs/2106.09785}\n}\n```\n\n```bibtex\n@misc{Beyer2022BetterPlainViT\n title = {Better plain ViT baselines for ImageNet-1k},\n author = {Beyer, Lucas and Zhai, Xiaohua and Kolesnikov, Alexander},\n publisher = {arXiv},\n year = {2022}\n}\n\n```\n\n```bibtex\n@article{Arnab2021ViViTAV,\n title = {ViViT: A Video Vision Transformer},\n author = {Anurag Arnab and Mostafa Dehghani and Georg Heigold and Chen Sun and Mario Lucic and Cordelia Schmid},\n journal = {2021 IEEE/CVF International Conference on Computer Vision (ICCV)},\n year = {2021},\n pages = {6816-6826}\n}\n```\n\n```bibtex\n@article{Liu2022PatchDropoutEV,\n title = {PatchDropout: Economizing Vision Transformers Using Patch Dropout},\n author = {Yue Liu and Christos Matsoukas and Fredrik Strand and Hossein Azizpour and Kevin Smith},\n journal = {ArXiv},\n year = {2022},\n volume = {abs/2208.07220}\n}\n```\n\n```bibtex\n@misc{https://doi.org/10.48550/arxiv.2302.01327,\n doi = {10.48550/ARXIV.2302.01327},\n url = {https://arxiv.org/abs/2302.01327},\n author = {Kumar, Manoj and Dehghani, Mostafa and Houlsby, Neil},\n title = {Dual PatchNorm},\n publisher = {arXiv},\n year = {2023},\n copyright = {Creative Commons Attribution 4.0 International}\n}\n```\n\n```bibtex\n@inproceedings{Dehghani2023PatchNP,\n title = {Patch n' Pack: NaViT, a Vision Transformer for any Aspect Ratio and Resolution},\n author = {Mostafa Dehghani and Basil Mustafa and Josip Djolonga and Jonathan Heek and Matthias Minderer and Mathilde Caron and Andreas Steiner and Joan Puigcerver and Robert Geirhos and Ibrahim M. Alabdulmohsin and Avital Oliver and Piotr Padlewski and Alexey A. Gritsenko and Mario Luvci'c and Neil Houlsby},\n year = {2023}\n}\n```\n\n```bibtex\n@misc{vaswani2017attention,\n title = {Attention Is All You Need},\n author = {Ashish Vaswani and Noam Shazeer and Niki Parmar and Jakob Uszkoreit and Llion Jones and Aidan N. Gomez and Lukasz Kaiser and Illia Polosukhin},\n year = {2017},\n eprint = {1706.03762},\n archivePrefix = {arXiv},\n primaryClass = {cs.CL}\n}\n```\n\n```bibtex\n@inproceedings{dao2022flashattention,\n title = {Flash{A}ttention: Fast and Memory-Efficient Exact Attention with {IO}-Awareness},\n author = {Dao, Tri and Fu, Daniel Y. and Ermon, Stefano and Rudra, Atri and R{\\'e}, Christopher},\n booktitle = {Advances in Neural Information Processing Systems},\n year = {2022}\n}\n```\n\n```bibtex\n@inproceedings{Darcet2023VisionTN,\n title = {Vision Transformers Need Registers},\n author = {Timoth'ee Darcet and Maxime Oquab and Julien Mairal and Piotr Bojanowski},\n year = {2023},\n url = {https://api.semanticscholar.org/CorpusID:263134283}\n}\n```\n\n```bibtex\n@inproceedings{ElNouby2021XCiTCI,\n title = {XCiT: Cross-Covariance Image Transformers},\n author = {Alaaeldin El-Nouby and Hugo Touvron and Mathilde Caron and Piotr Bojanowski and Matthijs Douze and Armand Joulin and Ivan Laptev and Natalia Neverova and Gabriel Synnaeve and Jakob Verbeek and Herv{\\'e} J{\\'e}gou},\n booktitle = {Neural Information Processing Systems},\n year = {2021},\n url = {https://api.semanticscholar.org/CorpusID:235458262}\n}\n```\n\n```bibtex\n@inproceedings{Koner2024LookupViTCV,\n title = {LookupViT: Compressing visual information to a limited number of tokens},\n author = {Rajat Koner and Gagan Jain and Prateek Jain and Volker Tresp and Sujoy Paul},\n year = {2024},\n url = {https://api.semanticscholar.org/CorpusID:271244592}\n}\n```\n\n```bibtex\n@article{Bao2022AllAW,\n title = {All are Worth Words: A ViT Backbone for Diffusion Models},\n author = {Fan Bao and Shen Nie and Kaiwen Xue and Yue Cao and Chongxuan Li and Hang Su and Jun Zhu},\n journal = {2023 IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},\n year = {2022},\n pages = {22669-22679},\n url = {https://api.semanticscholar.org/CorpusID:253581703}\n}\n```\n\n```bibtex\n@misc{Rubin2024,\n author = {Ohad Rubin},\n url = {https://medium.com/@ohadrubin/exploring-weight-decay-in-layer-normalization-challenges-and-a-reparameterization-solution-ad4d12c24950}\n}\n```\n\n```bibtex\n@inproceedings{Loshchilov2024nGPTNT,\n title = {nGPT: Normalized Transformer with Representation Learning on the Hypersphere},\n author = {Ilya Loshchilov and Cheng-Ping Hsieh and Simeng Sun and Boris Ginsburg},\n year = {2024},\n url = {https://api.semanticscholar.org/CorpusID:273026160}\n}\n```\n\n```bibtex\n@inproceedings{Liu2017DeepHL,\n title = {Deep Hyperspherical Learning},\n author = {Weiyang Liu and Yanming Zhang and Xingguo Li and Zhen Liu and Bo Dai and Tuo Zhao and Le Song},\n booktitle = {Neural Information Processing Systems},\n year = {2017},\n url = {https://api.semanticscholar.org/CorpusID:5104558}\n}\n```\n\n```bibtex\n@inproceedings{Zhou2024ValueRL,\n title = {Value Residual Learning For Alleviating Attention Concentration In Transformers},\n author = {Zhanchao Zhou and Tianyi Wu and Zhiyun Jiang and Zhenzhong Lan},\n year = {2024},\n url = {https://api.semanticscholar.org/CorpusID:273532030}\n}\n```\n\n*I visualise a time when we will be to robots what dogs are to humans, and I\u2019m rooting for the machines.* \u2014 Claude Shannon\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Vision Transformer (ViT) - Pytorch",
"version": "1.8.7",
"project_urls": {
"Homepage": "https://github.com/lucidrains/vit-pytorch"
},
"split_keywords": [
"artificial intelligence",
" attention mechanism",
" image recognition"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e3bab878afe7fd3ae6523a7e323c7f818e04182bdd76a3060746e4d1d185cf28",
"md5": "51a9a5545099bc36223a2d2827bc772b",
"sha256": "e5a779a13063fee4ef48317f654ad91241fead5412ae97b46674747f64906439"
},
"downloads": -1,
"filename": "vit_pytorch-1.8.7-py3-none-any.whl",
"has_sig": false,
"md5_digest": "51a9a5545099bc36223a2d2827bc772b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 135743,
"upload_time": "2024-10-31T13:49:07",
"upload_time_iso_8601": "2024-10-31T13:49:07.167133Z",
"url": "https://files.pythonhosted.org/packages/e3/ba/b878afe7fd3ae6523a7e323c7f818e04182bdd76a3060746e4d1d185cf28/vit_pytorch-1.8.7-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "58e559af62af485f99e4cefc5c8a30f01253bcaae80f233e3261db41e5ec3455",
"md5": "78acc788b64cf2ada5961f54d3496193",
"sha256": "84f3798622b6891ca80f2e8e87949a24e339e1c3a4c67bb242e3f24af7288f2b"
},
"downloads": -1,
"filename": "vit_pytorch-1.8.7.tar.gz",
"has_sig": false,
"md5_digest": "78acc788b64cf2ada5961f54d3496193",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 112156,
"upload_time": "2024-10-31T13:49:09",
"upload_time_iso_8601": "2024-10-31T13:49:09.298224Z",
"url": "https://files.pythonhosted.org/packages/58/e5/59af62af485f99e4cefc5c8a30f01253bcaae80f233e3261db41e5ec3455/vit_pytorch-1.8.7.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-31 13:49:09",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "lucidrains",
"github_project": "vit-pytorch",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "vit-pytorch"
}