Home >Backend Development >Python Tutorial >Vision Transformers (ViTs): Computer Vision with Transformer Models
Over the past few years, tranformers have transformed the NLP domain in machine learning. Models like GPT and BERT have set new benchmarks in understanding and generating human language. Now the same principle is been applied to computer vision domain. A recent development in the field of computer vision are vision transformers or ViTs. As detailed in the paper “An Image is Worth 16x16 Words: Transformers for Image Recognition at Scale”, ViTs and transformer-based models are designed to replace convolutional neural networks (CNNs). Vision Transformers are a fresh take on solving problems in computer vision. Instead of relying on traditional convolutional neural networks (CNNs), which have been the backbone of Vision Transformers (ViTs): Computer Vision with Transformer Models-related tasks for decades, ViTs use the transformer architecture to process Vision Transformers (ViTs): Computer Vision with Transformer Modelss. They treat Vision Transformers (ViTs): Computer Vision with Transformer Models patches like words in a sentence, allowing the model to learn the relationships between these patches, just like it learns the context in a paragraph of text.
Unlike CNNs, ViTs divide input Vision Transformers (ViTs): Computer Vision with Transformer Modelss into patches, serialize them into vectors, and reduce their dimensionality using matrix multiplication. A transformer encoder then processes these vectors as token embeddings. In this article, we’ll explore vision transformers and their main differences from convolutional neural networks. What makes them particularly interesting is their ability to understand global patterns in an Vision Transformers (ViTs): Computer Vision with Transformer Models, which is something CNNs can struggle with.
Vision transformers use the concept of attention and transformers to process Vision Transformers (ViTs): Computer Vision with Transformer Modelss—this is similar to transformers in a natural language processing (NLP) context. However, instead of using tokens, the Vision Transformers (ViTs): Computer Vision with Transformer Models is split into patches and provided as a sequence of linear embedded. These patches are treated the same way tokens or words are treated in NLP.
Instead of looking at the whole picture simultaneously, a ViT cuts the Vision Transformers (ViTs): Computer Vision with Transformer Models into small pieces like a jigsaw puzzle. Each piece is turned into a list of numbers (a vector) that describes its features, and then the model looks at all the pieces and figures out how they relate to each other using a transformer mechanism.
Unlike CNNs, ViTs works by applying specific filters or kernels over
an Vision Transformers (ViTs): Computer Vision with Transformer Models to detect specific features, such as edge patterns. This is the
convolution process which is very similar to a printer scanning an
Vision Transformers (ViTs): Computer Vision with Transformer Models. These filters slide through the entire Vision Transformers (ViTs): Computer Vision with Transformer Models and highlight
significant features. The network then stacks up multiple layers of
these filters, gradually identifying more complex patterns.
With CNNs, pooling layers reduce the size of the feature maps. These
layers analyze the extracted features to make predictions useful for
Vision Transformers (ViTs): Computer Vision with Transformer Models recognition, object detection, etc. However, CNNs have a fixed
receptive field, thereby limiting the ability to model long-range
dependencies.
How CNN views Vision Transformers (ViTs): Computer Vision with Transformer Modelss?
ViTs, despite having more parameters, use self-attention mechanisms for better feature representation and reduce the need for deeper layers. CNNs require significantly deeper architecture to achieve a similar representational power, which leads to increased computational cost.
Additionally, CNNs cannot capture global-level Vision Transformers (ViTs): Computer Vision with Transformer Models patterns because their filters focus on local regions of an Vision Transformers (ViTs): Computer Vision with Transformer Models. To understand the entire Vision Transformers (ViTs): Computer Vision with Transformer Models or distant relationships, CNNs rely on stacking many layers and pooling, expanding the field of view. However, this process can lose global information as it aggregates details step-by-step.
ViTs, on the other hand, divide the Vision Transformers (ViTs): Computer Vision with Transformer Models into patches that are treated as individual input tokens. Using self-attention, ViTs compare all patches simultaneously and learn how they relate. This allows them to capture patterns and dependencies across the whole Vision Transformers (ViTs): Computer Vision with Transformer Models without building them up layer by layer.
Before going further, it’s important to understand the concept of inductive bias. Inductive bias refers to the assumption a model makes about data structure; during training, this helps the model be more generalized and reduce bias. In CNNs, inductive biases include:
These biases make CNNs highly efficient for Vision Transformers (ViTs): Computer Vision with Transformer Models tasks, as they are inherently designed to exploit Vision Transformers (ViTs): Computer Vision with Transformer Modelss’ spatial and structural properties.
Vision Transformers (ViTs) have significantly less Vision Transformers (ViTs): Computer Vision with Transformer Models-specific inductive bias than CNNs. In ViTs:
Vision Transformers uses the standard Transformer architecture developed for 1D text sequences. To process the 2D Vision Transformers (ViTs): Computer Vision with Transformer Modelss, they are divided into smaller patches of fixed size, such as P P pixels, which are flattened into vectors. If the Vision Transformers (ViTs): Computer Vision with Transformer Models has dimensions H W with C channels, the total number of patches is N = H W / P P the effective input sequence length for the Transformer. These flattened patches are then linearly projected into a fixed-dimensional space D, called the patch embeddings.
A special learnable token, similar to the [CLS] token in BERT, is prepended to the sequence of patch embeddings. This token learns a global Vision Transformers (ViTs): Computer Vision with Transformer Models representation that is later used for classification. Additionally, positional embeddings are added to the patch embeddings to encode positional information, helping the model understand the spatial structure of the Vision Transformers (ViTs): Computer Vision with Transformer Models.
The sequence of embeddings is passed through the Transformer encoder, which alternates between two main operations: Multi-Headed Self-Attention (MSA) and a feedforward neural network, also called an MLP block. Each layer includes Layer Normalization (LN) applied before these operations and residual connections added afterward to stabilize training. The output of the Transformer encoder, specifically the state of the [CLS] token, is used as the Vision Transformers (ViTs): Computer Vision with Transformer Models’s representation.
A simple head is added to the final [CLS] token for classification tasks. During pretraining, this head is a small multi-layer perceptron (MLP), while in fine-tuning, it is typically a single linear layer. This architecture allows ViTs to effectively model global relationships between patches and utilize the full power of self-attention for Vision Transformers (ViTs): Computer Vision with Transformer Models understanding.
In a hybrid Vision Transformer model, instead of directly dividing raw Vision Transformers (ViTs): Computer Vision with Transformer Modelss into patches, the input sequence is derived from feature maps generated by a CNN. The CNN processes the Vision Transformers (ViTs): Computer Vision with Transformer Models first, extracting meaningful spatial features, which are then used to create patches. These patches are flattened and projected into a fixed-dimensional space using the same trainable linear projection as in standard Vision Transformers. A special case of this approach is using patches of size 1×1, where each patch corresponds to a single spatial location in the CNN’s feature map.
In this case, the spatial dimensions of the feature map are flattened, and the resulting sequence is projected into the Transformer’s input dimension. As with the standard ViT, a classification token and positional embeddings are added to retain positional information and to enable global Vision Transformers (ViTs): Computer Vision with Transformer Models understanding. This hybrid approach leverages the local feature extraction strengths of CNNs while combining them with the global modeling capabilities of Transformers.
Here is the code block on how to use the vision transformers on Vision Transformers (ViTs): Computer Vision with Transformer Modelss.
# Install the necessary libraries pip install -q transformers
from transformers import ViTForImageClassification from PIL import Image from transformers import ViTImageProcessor
import requests import torch
# Load the model and move it to ‘GPU’ device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')model = ViTForImageClassification.from_pretrained('google/vit-base-patch16-224') model.to(device)
# Load the Vision Transformers (ViTs): Computer Vision with Transformer Models to perform predictions url = 'link to your Vision Transformers (ViTs): Computer Vision with Transformer Models' Vision Transformers (ViTs): Computer Vision with Transformer Models = Image.open(requests.get(url, stream=True).raw)processor = ViTImageProcessor.from_pretrained('google/vit-base-patch16-224') inputs = processor(Vision Transformers (ViTs): Computer Vision with Transformer Modelss=Vision Transformers (ViTs): Computer Vision with Transformer Models, return_tensors="pt").to(device) pixel_values = inputs.pixel_values # print(pixel_values.shape)
The ViT model processes the Vision Transformers (ViTs): Computer Vision with Transformer Models. It comprises a BERT-like encoder and a linear classification head situated on top of the final hidden state of the [CLS] token.
with torch.no_grad(): outputs = model(pixel_values) logits = outputs.logits# logits.shapeprediction = logits.argmax(-1) print("Predicted class:", model.config.id2label[prediction.item()])
Here’s a basic Vision Transformer (ViT) implementation using PyTorch. This code includes the core components: patch embedding, positional encoding, and the Transformer encoder.This can be used for simple classification tasks.
import torchimport torch.nn as nnimport torch.nn.functional as Fclass VisionTransformer(nn.Module): def __init__(self, img_size=224, patch_size=16, num_classes=1000, dim=768, depth=12, heads=12, mlp_dim=3072, dropout=0.1): super(VisionTransformer, self).__init__() # Image and patch dimensions assert img_size % patch_size == 0, "Image size must be divisible by patch size" self.num_patches = (img_size // patch_size) ** 2 self.patch_dim = (3 * patch_size ** 2) # Assuming 3 channels (RGB) # Layers self.patch_embeddings = nn.Linear(self.patch_dim, dim) self.position_embeddings = nn.Parameter(torch.randn(1, self.num_patches 1, dim)) self.cls_token = nn.Parameter(torch.randn(1, 1, dim)) self.dropout = nn.Dropout(dropout) # Transformer Encoder self.transformer = nn.TransformerEncoder( nn.TransformerEncoderLayer(d_model=dim, nhead=heads, dim_feedforward=mlp_dim, dropout=dropout), num_layers=depth ) # MLP Head for classification self.mlp_head = nn.Sequential( nn.LayerNorm(dim), nn.Linear(dim, num_classes) ) def forward(self, x): # Flatten patches and embed batch_size, channels, height, width = x.shape patch_size = height // int(self.num_patches ** 0.5) x = x.unfold(2, patch_size, patch_size).unfold(3, patch_size, patch_size) x = x.contiguous().view(batch_size, 3, patch_size, patch_size, -1) x = x.permute(0, 4, 1, 2, 3).flatten(2).permute(0, 2, 1) x = self.patch_embeddings(x) # Add positional embeddings cls_tokens = self.cls_token.expand(batch_size, -1, -1) x = torch.cat((cls_tokens, x), dim=1) x = x self.position_embeddings x = self.dropout(x) # Transformer Encoder x = self.transformer(x) # Classification Head x = x[:, 0] # CLS token return self.mlp_head(x)# Example usageif __name__ == "__main__": model = VisionTransformer(img_size=224, patch_size=16, num_classes=10, dim=768, depth=12, heads=12, mlp_dim=3072) print(model) dummy_img = torch.randn(8, 3, 224, 224) # Batch of 8 Vision Transformers (ViTs): Computer Vision with Transformer Modelss, 3 channels, 224x224 size preds = model(dummy_img) print(preds.shape) # Output: [8, 10] (Batch size, Number of classes)
The above is the detailed content of Vision Transformers (ViTs): Computer Vision with Transformer Models. For more information, please follow other related articles on the PHP Chinese website!