- VisualStudio2022插件的安装及使用-编程手把手系列文章
- pprof-在现网场景怎么用
- C#实现的下拉多选框,下拉多选树,多级节点
- 【学习笔记】基础数据结构:猫树
Vision Transformer(ViT) 架构传统上采用基于网格的方法进行标记化,而不考虑图像的语义内容。论文提出了一种模块化的超像素非规则标记化策略,该策略将标记化和特征提取解耦,与当前将两者视为不可分割整体的方法形成了对比。通过使用在线内容感知标记化以及尺度和形状不变的位置嵌入,与基于图像块的标记化和随机分区作为基准进行了对比。展示了在提升归因的真实性方面的显著改进,在零样本无监督密集预测任务中提供了像素级的粒度,同时在分类任务中保持了预测性能.
来源:晓飞的算法工程笔记 公众号,转载请注明出处 。
论文: A Spitting Image: Modular Superpixel Tokenization in Vision Transformers 。
在卷积架构之后,Vision Transformers(ViTs) 已成为视觉任务的焦点。在最初的语言模型的Transformer中,标记化是一个至关重要的预处理步骤,旨在基于预定的熵度量最佳地分割数据。随着模型被适配于视觉任务,标记化简化为将图像分割为正方形的图像块。这种方法被证明是有效的,很快成为了标准方法,成为架构的一个重要组成部分.
尽管取得了明显的成功,论文认为基于图像块的标记化存在固有的局限性。首先,标记的尺度通过固定的图像块大小与模型架构严格绑定,忽视了原始图像中的冗余。这些局限性导致在较高分辨率下计算量显著增加,因为复杂度和内存随标记数量呈平方级增长。此外,规则的分割假设了语义内容分布的固有均匀性,从而高效地降低了空间分辨率.
随后,若干研究利用注意力图来可视化类标记的归因,以提高可解释性,这常应用于密集预测任务。然而,正方形分割产生的注意力图在图像块表示中会引起分辨率的丧失,进而无法本质上捕捉原始图像的分辨率。对于像素级粒度的密集预测,需要一个单独的解码器进行放大处理.
论文从原始的ViT架构中退一步,重新评估基于图像块的标记化的作用。通过关注架构中这个被忽视的组件,将图像分割定义为一个自适应模块化标记器的角色,这是ViTs中未被充分利用的潜力.
与正方形分割相比,超像素提供了一个机会,通过允许尺度和形状的适应性,同时利用视觉数据中的固有冗余来缓解基于图像块的标记化的缺陷。超像素已被证明与图像中的语义结构更好地对齐,这为在视觉Transformer架构中的潜在用途提供了依据。论文将标准ViTs中的经典正方形标记化与超像素标记化模型(SPiT)进行比较,并使用随机Voronoi标记化(RViT)(明确定义的数学对象,用于镶嵌平面)作为对照,后者因其作为平面镶嵌的数学对象而被选中,三种标记化方案在图1中进行了说明.
论文的研究引出了三个具体的问题:(a)对正方形图像块的严格遵守是否必要?(b)不规则分割对标记化表示有什么影响?(c)标记化方案是否可以设计为视觉模型中的一个模块化组件?
经过实验验证,论文得到了以下结论:
Generalized Framework
:超像素标记化作为模块化方案中推广到了ViTs
,为视觉任务提供更丰富的Transformer
空间,其中Transformer
主干与标记化框架是独立的。Efficient Tokenization
:提出了一种高效的在线标记化方法,该方法在训练和推理时间上具有竞争力,同时在分类任务中表现出色。Refined Spatial Resolution
:超像素标记化提供了语义对齐的标记,具有像素级的粒度。与现有的可解释性方法相比,论文的方法得到更显著的归因,并且在无监督分割中表现出色。Visual Tokenization
:论文的主要贡献是引入了一种新颖的方法来思考ViTs
中的标记化问题,这是建模过程中的一个被忽视但核心的组成部分。论文的主要目标是评估ViTs的标记化方案,强调不同标记化方法的内在特性。为了进行公平的比较分析,使用基础的ViT架构和既定的训练协议进行研究。因此,论文设计实验以确保与知名基线进行公平比较,且不进行架构优化。这种受控的比较对于将观察到的差异归因于标记化策略至关重要,并消除了特定架构或训练方案带来的混杂因素.
为了评估和对比不同的标记化策略,需要对图像进行分割并从这些分割中提取有意义的特征。虽然可以使用多种深度架构来完成这些任务,但这些方法会给最终模型增加一层复杂性,从而使任何直接比较标记化策略的尝试失效。此外,这也会使架构之间的有效迁移学习变得复杂。基于这一原因,论文构建了一个有效的启发式超像素标记化器,并提出了一种与经典ViT架构一致的非侵入性特征提取方法,以便进行直接比较.
定义 \(H {\mkern1mu\times\mkern1mu} W = \big\{(y, x) : 1 \leq y \leq h, 1 \leq x \leq w\big\}\) 表示一个空间维度为 \((h, w)\) 的图像的坐标,并让 \(\mathcal I\) 为映射 \(i \mapsto (y, x)\) 的索引集。将一个 \(C\) 通道的图像视为信号 \({\xi\colon \mathcal I \to \mathbb R^C}\) ,定义向量化操作符 \(\mathrm{vec}\colon \mathbb{R}^{d_1 {\mkern1mu\times\mkern1mu} \dots {\mkern1mu\times\mkern1mu} d_n} \to \mathbb{R}^{d_1 \dots d_n}\) ,并用 \(f(g(x)) = (f \circ g)(x)\) 表示函数的组合.
论文通过允许模块化的标记化器和不同的特征提取方法,来对经典ViT架构进行泛化。值得注意的是,经典的ViT通常被呈现为一个由三部分组成的系统,包括一个标记嵌入器 \(g\) 、一个由一系列注意力块组成的主干网络 \(f\) ,以及一个后续的预测头 \(h\) 。实际上,可以将图像块嵌入模块重写为一个由三个部分组成的模块化系统,包含一个标记化器 \(\tau\) 、一个特征提取器 \(\phi\) 和一个嵌入器 \(\gamma\) ,使得 \(g = \gamma \circ \phi \circ \tau\) .
这些是原始架构中的固有组件,但在简化的标记化策略下被掩盖了。这为模型作为一个五部分系统提供了更完整的评估.
其中 \(\theta\) 表示模型的可学习参数集合。在标准的ViT模型中,标记化器 \(\tau\) 将图像分割为固定大小的方形区域。这直接提供了向量化的特征,因为这些图像块具有统一的维度和顺序,因此在标准的ViT架构中, \(\phi = \mathrm{vec}\) 。嵌入器 \(\gamma\) 通常是一个可学习的线性层,将特征映射到特定架构的嵌入维度。另一种做法是,将 \(g\) 视为一个卷积操作,其卷积核大小和步幅等于所需的图像块大小 \(\rho\) .
语言任务中的标记化需要将文本分割为最优信息量的标记,这类似于超像素将空间数据分割为离散的连通区域。层级超像素是一种高度可并行化的基于图的方法,适合用于在线标记化。基于此,论文提出了一种新方法,该方法在每一步 \(t\) 中进行批量图片图的完全并行聚合,此外还包括对大小和紧凑性的正则化。在每一步产生不同数量的超像素,动态适应图像的复杂性.
设 \(E^{(0)} \subset \mathcal I {\mkern1mu\times\mkern1mu} \mathcal I\) 表示在 \(H {\mkern1mu\times\mkern1mu} W\) 下的四向邻接边。将超像素视为一个集合 \(S \subset \mathcal I\) ,并且如果对于 \(S\) 中的任意两个像素 \(p\) 和 \(q\) ,存在一个边的序列 \(\big((i_j, i_{j+1}) \in E^{(0)}\big)_{j=1}^{k-1}\) ,使得 \(i_1 = p\) 和 \(i_k = q\) ,则认为 \(S\) 是连通的。如果对于任意两个不同的超像素 \(S\) 和 \(S' \in \pi\) ,它们的交集 \(S \cap S' = \emptyset\) ,并且所有超像素的并集等于图像中所有像素位置的集合,即 \(\bigcup_{S \in \pi^{(t)}} S = \mathcal I\) ,那么一组超像素就形成了图像的分割 \(\pi\) .
设 \(\Pi(\mathcal I) \subset 2^{2^{\mathcal I}}\) 表示图像的所有分割的空间,并且有一系列分割 \((\pi^{(t)})_{t=0}^T\) 。如果对于 \(\pi^{(t)}\) 中的所有超像素 \(S\) ,存在一个超像素 \(S' \in \pi^{(t+1)}\) 使得 \(S \subseteq S'\) ,则认为分割 \(\pi^{(t)}\) 是另分割 \(\pi^{(t+1)}\) 的细化,用 \(\pi^{(t)} \sqsubseteq \pi^{(t+1)}\) 来表示。目标是构造一个 像素索引的 \(T\) 级层级分割 \({\mathcal H = \big( \pi^{(t)} \in \Pi(\mathcal I) : \pi^{(t)} \sqsubseteq \pi^{(t+1)} \big)_{t=0}^T}\) ,使得每个超像素都是连通的.
为了构造 \(\mathcal H\) ,通过并行边收缩(用一个顶点代替多个顶点,被代替的点的内部边去掉,外部边由代替的顶点继承)的方式逐步连接顶点,以更新分割 \({\pi^{(t)} \mapsto \pi^{(t+1)}}\) 。通过将每个层级视为图 \(G^{(t)} = (V^{(t)}, E^{(t)})\) 来实现,其中每个顶点 \(v \in V^{(t)}\) 是分割 \(\pi^{(t)}\) 中一个超像素的索引,每条边 \((u, v) \in E^{(t)}\) 代表在 \(t = 0, \dots, T\) 层级中相邻的超像素。因此,初始图像可以表示为一个网格图 \({G^{(0)} = (V^{(0)}, E^{(0)})}\) ,对应于单像素分割 \({\pi^{(0)} = \big\{\{i\} : i \in \mathcal I \big\}}\) .
为了应用边收缩,定义一个边权重函数 \(w_\xi^{(t)}\colon E^{(t)} \to \mathbb R\) 。保留图中的自环(超像素包含的节点互指,合并后表现为超像素指向自身。这里保留自环是因为不一定每一次都需要加入新像素,自环权重高于其它节点时则不加),通过相对大小对自环边进行加权作为正则化器,对区域大小的方差进行约束。对于非自环边,使用平均特征 \(\mu_\xi^{(t)}(v) = \sum_{i \in \pi^{(t)}_v} \xi(i) / \lvert \pi^{(t)}_v \rvert\) 并应用相似性函数 \(\mathrm{sim}\colon E^{(t)} \to \mathbb{R}\) 作为权重。自环的权重使用在层级 \(t\) 时,区域大小的特征均值 \(\mu^{(t)}_{\lvert \pi \rvert}\) 和特征标准差 \(\sigma^{(t)}_{\lvert \pi \rvert}\) 进行加权.
整体权重计算如下:
紧凑性可以通过计算无穷范数密度来选择性地进行调节:
其中 \(\mathrm{per}_\infty\) 是包围超像素 \(u\) 和 \(v\) 的边界框的周长。这突出了两个相邻的超像素 \(u\) 和 \(v\) 在其边界框内的紧密程度,从而得出了一个正则化的权重函数.
其中 \(\lambda \in [0,1]\) 作为紧凑性的超参数.
使用贪婪的并行更新规则进行边收缩,使得每个超像素与具有最高边权重的相邻超像素连接,包括所有 \(G^{(t)}\) 中的自环,适用于 \(t \geq 1\) 。设 \(\mathfrak{N}^{(t)}(v)\) 表示在第 \(t\) 层中索引为 \(v\) 的超像素的相邻顶点的邻域,构造一个中间边集:
然后,传递闭包 \(\hat E_+^{(t)}\) (传递闭包是指多个二元关系存在传递性,通过该传递性推导出更多的关系,比如可从A->B和B->C中推导出A->C,这里即是 \(\hat E^{(t)}\) 的连通分量)可明确地得出一个映射 \({V^{(t)} \mapsto V^{(t+1)}}\) ,使得 。
其中 \(\hat{\mathfrak{N}}_+^{(t)}(v)\) 表示在 \(\hat E_+^{(t)}\) 中顶点 \(v\) 的连通分量。这个分区更新规则确保了在 \((t+1)\) 层的每个分区都是一个连通区域,因为它是通过合并具有最高边权重的相邻超像素形成的,如图3中所示.
重复计算聚合映射、正则化边权重和边收缩的步骤,直到达到所需的层级数 \(T\) 。在每一层,分区变得更加粗糙,表示图像中更大的同质区域。层级结构提供了图像的多尺度表示,捕捉了局部和全局结构。在第 \(T\) 层,即可获得一系列分区 \((\pi^{(t)})_{t=0}^T\) ,其中每一层的分区在层级 \(t\) 时是一个连通区域,并且对所有 \(t\) 有 \({\pi^{(t)} \sqsubseteq \pi^{(t+1)}}\) .
在经典的ViT分词器中,论文尝试验证不同的 \(T\) 和图像块大小 \(\rho\) 分别产生的标记数量之间的关系。设 \(N_\mathrm{SPiT}\) 和 \(N_\mathrm{ViT}\) 分别表示SPiT分词器和ViT分词器的标记数量,这种关系为 \(\mathbb{E}(T \mid N_\mathrm{SPiT} = N_\mathrm{ViT}) = \log_2 \rho\) ,无论图像大小如何.
虽然ViT架构中选择正方形图像块是出于简洁性的考虑,但这自然也反映了替代方案所带来的挑战。非规则的图像块是不对齐的,表现出不同的形状和维度,并且通常是非凸的(形状非常不规则)。这些因素使得将非规则图像块嵌入到一个共同的内积空间中变得不容易。除了保持一致性和统一的维度外,论文还提出任何此类特征需要捕捉的最小属性集;即颜色、纹理、形状、尺度和位置.
ViTs通常为图像网格中的每个图像块使用可学习的位置嵌入。论文注意到这对应于下采样图像的位置直方图,可以通过使用核化方法将可学习的位置嵌入扩展到处理更复杂的形状、尺度和位置,对每个 \(n=1,\dots,N\) 分区的超像素 \(S_n\) 的坐标应用联合直方图。首先,将位置归一化,使得所有 \((y', x') \in S_n\) 都落在 \([-1, 1]^2\) 范围内。设定固定 \(\beta\) 为每个空间方向上的特征维度,特征由高斯核 \(K_\sigma\) 提取:
通常,带宽 \(\sigma\) 取值较低,范围为 \([0.01, 0.05]\) 。这样,实际上就编码了图像块在图像中的位置,以及其形状和尺度.
为了将原始像素数据中的光强信息编码到特征中,使用双线性插值将每个图像块的边界框插值到固定分辨率 \(\beta {\mkern1mu\times\mkern1mu} \beta\) ,同时屏蔽其他周围图像块中的像素信息。这些特征本质上捕捉了原始图像块的原始像素信息,但经过重采样并缩放到统一的维度。将特征提取器 \(\phi\) 称为插值特征提取器,RGB特征也被归一化到 \([-1, 1]\) 并向量化,使得 \(\hat\xi^{\text{col}} \in \mathbb{R}^{3\beta^2}\) .
梯度算子提供了一种简单而稳健的纹理信息提取方法。基于改进的旋转对称性和离散化误差,论文选择使用Scharr提出的梯度算子。将该算子归一化,使得 \(\nabla \xi \in [-1, 1]^{H{\mkern1mu\times\mkern1mu} W{\mkern1mu\times\mkern1mu} 2}\) ,其中最后两个维度对应于梯度方向 \(\nabla y\) 和 \(\nabla x\) 。与位置特征的处理过程类似,在每个超像素 \(S_n\) 内部对梯度应用高斯核构建联合直方图,使得 \(\hat\xi^{\text{grad}}_n \in \mathbb{R}^{\beta^2}\) .
最终特征模态被拼接为 \(\hat\xi_n = [\hat\xi^{\text{col}}_n, \hat\xi^{\text{pos}}_n, \hat\xi^{\text{grad}}_n] \in \mathbb{R}^{5\beta^2}\) 。虽然论文提出的梯度特征与标准的ViT架构相同,但它们代表了额外的信息维度。因此,论文评估了包括或省略梯度特征的效果。对于那些省略这些特征的模型,即 \(\hat\xi_n \setminus \hat\xi^{\text{grad}}_n = [\hat\xi^{\text{col}}_n, \hat\xi^{\text{pos}}_n] \in \mathbb{R}^{4\beta^2}\) ,称该提取器 \(\phi\) 为不包括梯度的提取器.
在设计上,论文的框架是对标准ViT标记化的一个概括,等同于使用固定图像块大小 \(\rho\) 和排除梯度的插值特征提取的标准图像块嵌入器.
设 \(\tau^*\) 表示一个固定图像块大小 \(\rho\) 的标准ViT标记化器, \(\phi\) 表示一个排除梯度的插值特征提取器, \(\gamma^*\) 和 \(\gamma\) 表示具有等效线性投影的嵌入层,其中 \(L^*_\theta = L_\theta\) 。设 \(\hat\xi^{\text{pos}} \in \mathbb{R}^{N {\mkern1mu\times\mkern1mu} \beta^2}\) 表示在 \(\tau^*\) 分割下的联合直方图位置嵌入矩阵。那么,对于维度 \(H = W = \beta^2 = \rho^2\) ,由 \(\gamma \circ \phi \circ \tau^*\) 给出的嵌入与由 \(\gamma^* \circ \phi^* \circ \tau^*\) 给出的标准ViT嵌入在数量上是等效的.
如果本文对你有帮助,麻烦点个赞或在看呗~ 更多内容请关注 微信公众号【晓飞的算法工程笔记】 。
最后此篇关于SPiT:超像素驱动的非规则ViT标记化,实现更真实的图像理解|ECCV2024的文章就讲到这里了,如果你想了解更多关于SPiT:超像素驱动的非规则ViT标记化,实现更真实的图像理解|ECCV2024的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我需要在 nginx-ingress 版本上允许来自多个来源的请求:http://localhost:4200、http://localhost:4242 等1.7.1.但我无法对多个来源执行此操作,
我正在部署我使用 APIGILITY 开发的 API到 IIS。由于 IIS 不支持 .htaccess,我试图从 .htaccess 文件的内容创建 web.config 文件。我使用 IISv7.
我正在尝试更改上面 css 样式中的“宽度”规则。在“inspect element”中你可以看到宽度是1008px。我不希望它是 1008px 但它不会让我在 css 样式中更改它你可以看到它被“删
外部css赋值有2种方法,我用的是第一种;大多数网站使用第二种方法。我想知道我是否做错了! 第一种方法: 为几乎每个 css 规则创建一个类并在任何地方使用它们。 blah blah .f_
RDF使用 WEB 标识符 (URIs) 来标识资源,使用属性和属性值来描述资源 RDF 资源、属性和属性值 RDF使用 WEB 标识符来标识事物,并通过属性和属性值来描述资源。 关于资源、属性
我想挖掘特定的 rhs 规则。文档中有一个示例证明这是可能的,但仅适用于特定情况(如下所示)。先来一个数据集来说明我的问题: input {b=100002} 0.2500000 0.250000
我想让 nginx 从网站根目录(:http://localhost:8080/)提供一个静态文件,但它为我的代理通行证提供服务;它提供“/”规则而不是“=/”。 这是我的 nginx 配置的样子:
根据gnu make documentation , 如果一个规则通过一次调用生成多个目标(例如,一个配方执行一个带有多个输出文件的工具),你可以使用 '&:' 规则语法来告诉 make。但是,当在多
我已阅读Firebase Documentation并且不明白什么是 .contains()。 以下是文档中 Firebase 数据库的示例规则: { "rules": { "rooms"
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我正在尝试做一些多态性练习,但我无法弄清楚这种多态性是如何工作的。我没有找到任何关于这种练习的深入信息。希望大家能给我一些解释。 练习1: class Top { public void m(
为了调试复杂的 XSLT 转换,我将其分为几个部分:首先构建 %.1.xml,然后使用它构建 %.2.xml ,最后构建 %.3.xml。一切正常,但如果我要求 Make 构建最后一个,Make 总是
我尝试了 hacerrank 的 slove 练习 Click我不知道如何添加这些规则: ► 它可以包含 4 个一组的数字,并用一个连字符“-”分隔。 ► 不得有 4 个或更多连续重复数字。 这是我的
我正在尝试编写一个小测验,我希望“再试一次”按钮遵循与“else”之前的“if”语句相同的规则 using System; public class Program { public stat
在我的 Spring/Boot Java 项目中,我有一组服务方法,例如以下一个: @Override public Decision create(String name, String descr
我正在阅读 Covariant virtual function .上面写着 假设 B::f 覆盖了虚函数 A::f。如果满足以下所有条件,A::f 和 B::f 的返回类型可能不同: 1) The
我工作的公司想要分发(在公共(public)链接中)具有内部签名的应用程序。我很确定 Apple 否认这种事情,但我在官方文档/契约(Contract)中没有找到任何相关信息。 有谁知道它到底是如何工
我是 CSS 新手。我观察到一个奇怪的 CSS 行为,其中一个元素具有以下 CSS 属性 .container .header{ color: #FFFFFF; font-size: 2em;
这个问题在这里已经有了答案: Is there a CSS selector for elements containing certain text? (21 个答案) 关闭 7 年前。
我有以下 CSS: workoutcal.css: .errorlist{ color:red; } 以下基本模板: base.html: {% load static %} {
我是一名优秀的程序员,十分优秀!