【Transformer系列(5)】vision transformer(ViT)带来的思考?

一、ViT的意义

Vision Transformer(ViT)是一种基于Transformer架构的图像分类模型,它通过将图像划分为一系列的图像块(patches),并将这些块转换为向量序列,然后通过Transformer的自注意力机制对这些序列进行处理,最后通过全连接层进行分类。

与传统的卷积神经网络(CNN)相比,ViT的主要意义在于:
(1)消除了传统卷积神经网络对于图像尺寸的限制。传统的CNN需要固定大小的输入图像,而ViT可以处理任意尺寸的图像,将其划分为块并进行处理,大大提高了模型的灵活性。
(2)提供了一种新的处理序列数据的思路。Transformer最初是针对自然语言处理任务设计的,而ViT将其成功应用于图像分类任务,验证了Transformer在处理序列数据方面的广泛适用性。
(3)可以处理长程依赖关系。由于自注意力机制的存在,ViT可以捕捉图像中任意两个位置之间的关系,从而更好地处理长程依赖关系的问题,如目标检测、图像分割等任务。

因此,Vision Transformer的意义在于为图像分类任务带来了一种全新的模型架构,打破了传统的卷积神经网络对图像尺寸的限制,并且展示了Transformer在图像处理领域的潜力。它为研究人员提供了一种全新的思路,可以进一步探索Transformer模型在计算机视觉领域的应用。

二、使用Position Embedding实现了图像和文本的向量尺度统一

由于多头自注意力是针对NLP提出的,它的输入尺度为[batch size, num token , dim_token] ,而CV中图像输入尺度通常为[batch_size, num_channel, height, width]ViT通过Patch Embedding将其尺度转换至期望的形式。
说白了,就是CV中空间(height*width)对应NLP中的num_tokenCV中的通道num_channel对应NLP中的dim_token
在这里插入图片描述

如上图所示,假设一张图像的尺寸为[ 3 , 224 , 224 ],ViT会将其均分为多个Patch(上图是3 ∗ 3 = 9个,ViT结构图中是14 ∗ 14 = 196个),于是每个Patch的尺度为[ 3 , 16 , 16 ](16 = 224 ÷ 14)。对于每个PatchViT使用一层2D卷积进行特征提取可以得到尺度为[ 768 , 14 , 14 ]的特征(卷积核大小和步长均与Patch一致,输出通道数为768)。之后将[ 768 , 14 , 14 ]的特征转置为[ 14 , 14 , 768 ]的并将其展平即可得到[ 196 , 768 ]的特征。
此时转换完成,其中:
(1)196即为token的数量,对应文本输入尺度[batch size, num token , dim_token] 中的num_token
(2)768token的向量长度,对应文本输入尺度[batch size, num token , dim_token] 中的dim_token
如下图所示。
在这里插入图片描述

由于ViT处理的是分类任务,所以它参考BERT特地拼接上了一个大小为[ 1 , 768 ]Class token,于是现在token的大小变成[ 197 , 768 ]ViTClass token是一个初始化为0的可学习参数向量。通常Class token会被单独拿出来作为ViT提取出来的图像特征用于下游任务。

另外,ViT保留了Transformer中的位置编码(Position Embedding),它也是初始化为0的可学习参数,不过不是拼接而是加入,所以其大小为[ 197 , 768 ],与当前token的大小一致。

此时,所以token的准备完成,一个批次的图像转换为token后尺度是[batch_size, num_token, dim_token] (num_token=197, dim_token=768)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/7751.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构】C/C++ 带头双向循环链表保姆级教程(图例详解!!)

目录 一、前言 二、链表的分类 🥝单链表 🥝双链表 🥝循环链表 🥝带头双向循环链表 🍍头节点(哨兵位)的作用 ✨定义: ✨作用: 🍇总结 三、带头双向循环链表 …

[JUCE]从一个有关右值引用的bug,探幽移动语义

一、问题 当我尝试在\JUCE\extras\WindowsDLL\Builds\VisualStudio2022目录下编译JUCE库的时候,提示报错如下: 报错提示如下: 这里涉及到两个问题 一、这个std::move是干嘛用的 二、为什么这里会报错? 另外,我在实…

详细讲解lua中string.gsub的使用

string.gsub 是 Lua 标准库中的一个函数,用于全局替换字符串中的某些部分。string.gsub 是 Lua 中非常实用的一个函数,它可以用来进行字符串的处理和替换操作。 它的基本语法如下: string.gsub(s, pattern, replacement [, n])s 是要处理的…

题解:CF1954D(Colored Balls)

题解:CF1954D(Colored Balls) CF1954D,是 CodeForces 难得一见的“非多测”题目,我们来看一下。 题意简述:有 n n n 种不同的球,第 i i i 种球有 a i a_i ai​ 个( 1 ≤ i ≤ n…

栈的磁盘优化:降低存取成本的算法与实现

栈的磁盘优化:降低存取成本的算法与实现 问题背景简单实现方法的分析实现方法PUSH操作POP操作成本分析渐近分析 优化实现方法实现方法成本分析渐近分析 进一步优化:双页管理策略实现方法管理策略成本分析 伪代码示例C代码示例结论 问题背景 在具有有限快…

【vulhub靶场】Tomcat中间件漏洞复现

【vulhub靶场】Tomcat中间件漏洞复现 一、Tomcat AJP 任意文件读取/包含漏洞 (CVE-2020-1938)1. 漏洞描述2. 影响版本3. 漏洞原理4. 漏洞复现 二、任意文件写入漏洞 (CVE-2017-12615)1. 漏洞原理2. 影响版本3. 漏洞复现 三、Tomca…

Java面试题:解释CountDownLatch, CyclicBarrier和Semaphore在并发编程中的使用

在并发编程中,CountDownLatch、CyclicBarrier 和 Semaphore 是 Java 提供的同步辅助类,它们用于控制线程之间的协调。以下是每个类的基本用法和特点: CountDownLatch(倒计时门闩): CountDownLatch 是一个同…

C语言程序的编译与链接过程

在编写C语言程序时,我们通常只是编写源代码(.c文件),但要让计算机真正执行这些代码,还需要经过编译和链接两个主要步骤。下面,我们将详细解析这两个过程。 一、编译过程 编译是将源代码(.c文件…

unity华为sdk接入指路指南

目前比较靠谱的几个方案:试过几个仅供参考 温馨提示:最高目前可支持方案到unity2021版本以下,以上请联系华为官方寻求技术支持 Unity集成华为游戏服务SDK方式(一):集成Unity官方游戏SDK: 华为…

数据倾斜常见的解决办法

造成数据倾斜的原因主要有2种:在map端读取不可分割的大文件、处理大量相同的key 解决办法一般有以下几种: 1、对于空值引发的数据倾斜 (1)在sql语句中单独处理空值的数据,最后union all (2)…

关于多态~

多态的基本概念 多态是c面向对象的三大特性之一 多态分为两类:静态多态和动态多态 静态多态:函数重载,运算符重载,复用函数名 动态多态:派生类和虚函数实现运行时多态 静态多态和动态多态的区别: 静态…

基于CLAHE算法的图像增强及评价

摘要: 本研究旨在探讨对比度限制自适应直方图均衡化(CLAHE)算法在数字图像处理中的应用。CLAHE算法通过在局部区域内进行直方图均衡化,有效地增强了图像的对比度,并在保持图像细节的同时避免了过度增强的问题。本文通过…

Eclipse 开创性地集成 Neon Stack,将 EVM 兼容性带到 SVM 网络

2024年5月2日,全球——在塑造区块链网络的战略联盟的过程中,Eclipse 通过集成 Neon EVM 核心团队开发的技术堆栈 Neon Stack,成为首个打破 EVM-SVM 兼容性障碍的生态。 Eclipse 旨在通过结合以太坊和 Solana 的最佳特性,来重构区…

mksh静态编译

代码来源:https://github.com/MirBSD/mksh.git 需求,基于musl库编译一个静态可执行文件,验证 musl库是否正常 根据 Build.sh文件定义,可以设置 LDFLAGS, CFLAGS,LIBS等参数 1. 首先编译musl ./configure --enable-debugyes --…

java 继承和静态属性或方法

目录 继承 静态属性和方法 继承与静态属性或方法的关系: 示例: 注意: PS:如有错漏之处,敬请指正 在Java中,继承和静态属性或方法是面向对象编程中的两个重要概念。它们在类设计和使用中扮演着不同的角…

数据结构(c):队列

目录 🍺0.前言 1.什么是队列 2. 队列的实现 2.1定义队列节点 2.2定义队列 2.3队尾入队列 2.4判断队列是否为空 2.5队头出队列 2.6 队列首元素 2.7队尾元素 2.8队列内的元素个数 2.9销毁队列 3.试运行 💎4.结束语 🍺0.前言 言C之…

Partisia Blockchain 生态首个zk跨链DEX现已上线

在5月1日,由Partisia Blockchain与zkCross创建合作推出的Partisia zkCrossDEX在Partisia Blockchain生态正式上线。Partisia zkCrossDEX是Partisia Blockchain上重要的互操作枢纽,其融合了zkCross的zk技术跨链互操作方案,并利用Partisia Bloc…

【SSM进阶学习系列丨分页篇】PageHelper 分页插件集成实践

文章目录 一、说明什么是分页PageHelper介绍 二、导入依赖三、集成Spring框架中四、编写Service五、编写Controller六、编写queryAllByPage页面展示数据 一、说明 什么是分页 ​ 针对分页,使用的是PageHelper分页插件,版本使用的是5.1.8 。 ​ 参考文档…

Linux命名管道的创建及应用

目录 一、命名管道的定义即功能 1.1创建命名管道 1.2匿名管道和命名管道的区别 1.3命名管道的打开规则 1.4系统调用unlink 二、进程间命名管道的创建及使用 2.1Comm.hhp 2.2PipeServer.cc 2.3PipeClient.cc 一、命名管道的定义即功能 管道应用的一个限制就是只能在具有…

[报错解决]SpringBoot子项目打jar包启动报 XXX--1.0-SNAPSHOT.jar中没有主清单属性

目录 报错信息解决原因原因分析解决方案 报错信息 解决 原因 在使用SpringBoot架构搭建父子工程时,使用IDEA可以正常启动,对子项目打成jar包后使用jar方式启动时,会报错xx.jar中没有主清单属性。 原因分析 原因主要是在使用jar方式启动时…