灵活视图变换器:为扩散模型设计的革新图像生成架构

news2025/1/5 8:54:22

在自然界中,图像的分辨率是无限的,而现有的图像生成模型在跨任意分辨率泛化方面存在困难。虽然扩散变换器(DiT)在特定分辨率范围内表现出色,但在处理不同分辨率的图像时却力不从心。为了克服这一限制,来自上海人工智能实验室的研究团队及其合作者提出了灵活视图变换器(Flexible Vision Transformer,简称FiT),这是一种专为生成任意分辨率和纵横比的图像而设计的变换器架构。与传统方法不同,FiT将图像视为动态大小的令牌序列,这种视角使得FiT在训练和推理阶段都能灵活适应不同的纵横比,从而促进分辨率的泛化,并消除了由图像裁剪引入的偏见。

FiT-XL/2模型在不同分辨率下生成的图像样本

方法

论文首先介绍了一些关键的预备概念和技术,特别强调了1-D Rotary Positional Embedding(1-D旋转位置嵌入,简称RoPE)的概念。RoPE是一种新颖的位置编码方式,它通过将绝对位置编码和相对位置编码结合在一起,为大型语言模型(LLMs)提供了一定程度的序列长度外推能力。

RoPE通过在复数向量空间中对关键向量和查询向量应用偏置,实现了位置编码。这种方法利用了一个旋转频率矩阵,该矩阵定义了一系列的旋转角度,这些角度与位置编码的维度有关。在实际空间中,这种旋转矩阵可以被看作是一个由余弦和正弦函数组成的矩阵,它能够根据位置信息调整关键向量和查询向量。

其次注意力分数的计算方式也很重要,即如何结合使用RoPE的查询向量和关键向量来得到注意力分数。这涉及到利用RoPE编码后的查询向量和关键向量之间的复数实部内积,以确定模型在不同位置编码下的注意力权重。

最后是NTK-aware Interpolation(NTK感知插值)和YaRN(Yet another RoPE extensioN,另一种RoPE扩展)插值技术。这些技术主要用于处理大型语言模型在面对测试时上下文长度超过训练时最大长度的情况。通过调整RoPE的旋转基,NTK-aware Interpolation能够适应更长的上下文。而YaRN技术则引入了一个额外的超参数来调整旋转频率,从而更有效地扩展上下文窗口。

为了处理不同分辨率的图像,FiT采用了一个灵活的预处理步骤。与传统的将所有图像调整到固定分辨率的方法不同,FiT在预处理阶段避免了裁剪或过度缩放图像。FiT仅将高分辨率图像调整到一个预设的最大分辨率限制,确保图像的原始纵横比不变,从而避免了引入不必要的失真或信息损失。

接下来,FiT的训练流程包括将图像编码为潜在代码,然后将这些潜在代码分割成固定大小的潜在令牌。由于不同图像的潜在令牌序列长度可能不同,FiT通过填充令牌将所有序列统一到一个最大长度,这样就可以将不同长度的序列打包到同一个批次中进行并行处理。在训练过程中,模型只计算去噪输出令牌的损失,而忽略填充令牌。

在推理阶段,FiT首先根据目标图像的分辨率定义一个位置图,然后从高斯分布中采样噪声令牌作为输入。通过一系列的去噪步骤,模型逐步改善这些噪声令牌,最终根据位置图将去噪后的令牌重塑并解码成最终的图像。

FiT的训练和推理流程还特别考虑了GPU硬件的特性,确保数据以统一形状的批次进行处理,以优化并行计算效率。这种灵活的训练和推理流程使得FiT能够生成各种分辨率和纵横比的高质量图像,同时保持了图像的细节和完整性。

为了评估FiT生成的图像质量,研究者们采用了多种评估指标,如Frechet Inception Distance(FID)、Inception Score(IS)、以及改进的精确度和召回率等。这些指标能够全面评估生成图像的质量和多样性,确保FiT在不同分辨率下都能产生高保真度的图像输出。通过这些评估,研究者们能够验证FiT在训练分布内外的分辨率上都具有出色的图像生成能力。

DiT和FiT在处理数据时的流程差异。(a)部分展示了DiT的流程,包括固定分辨率的处理方式;(b)部分展示了FiT的流程,突出了其灵活处理不同分辨率的能力

FiT模型视图:
(a) 灵活的训练流程,展示了如何将图像编码、分块、填充和计算损失。(b) 灵活的推理流程,展示了如何定义生成图像的位置、去噪和重塑。(c) FiT块,展示了模型的基本构成元素,包括2D位置嵌入、掩码多头自注意力(Masked MHSA)、SwiGLU等

FiT模型的架构基于DiT(Diffusion Transformer)进行了改进,特别是针对分辨率外推的局限性进行了优化。为了适应不同大小的图像,FiT采用了2D Rotary Positional Embedding(2D旋转位置嵌入,简称2D RoPE),这是从1D RoPE演变而来的技术,它通过在两个维度上分别应用旋转频率,增强了模型对空间位置信息的编码能力。

FiT模型中传统的多层感知器(MLP)被替换为Swish-Gated Linear Unit(SwiGLU),这是一种新型的激活函数,它结合了Sigmoid线性单元(SiLU)和Hadamard乘积,能够提供更有效的非线性变换,有助于提高模型的表达能力。

为了更有效地处理填充令牌,FiT使用了Masked Multi-Head Self-Attention(Masked MHSA)机制。这种机制通过掩码操作,区分了实际的令牌和填充令牌,确保在自注意力计算过程中,只有实际的令牌之间进行交互,而忽略填充令牌,从而避免了不必要的计算和潜在的错误信息传播。

FiT模型还引入了一种灵活的训练策略,允许模型在训练过程中动态调整序列长度,以适应不同分辨率的图像。这种策略通过将图像编码为不同长度的潜在令牌序列,并使用填充操作将它们统一到最大序列长度,使得模型能够处理任意长度的输入。

FiT模型的设计还包括了对网络架构的细致调整,如层数、隐藏尺寸和注意力头数的配置,以及对训练过程中的正则化和优化策略的选择。这些细节共同构成了FiT模型的核心,使其能够在保持高效率的同时,生成高质量的图像。

FiT模型在设计时考虑到了在不同分辨率下生成图像的能力,特别是在训练数据中未出现的分辨率。为了实现这一点,研究者们采用了一种无需额外训练的方法来扩展模型的分辨率适应性。

FiT模型在训练期间能够处理各种分辨率和纵横比的图像,但为了在推理时生成更高或更低分辨率的图像,需要一种有效的外推技术。论文提出了几种不同的外推方法,包括但不限于:

  • Vanilla NTK和YaRN实现:直接将大型语言模型中的外推技术应用于2D RoPE,通过调整旋转基来适应不同的分辨率。
  • VisionNTK和VisionYaRN:这是两种针对视觉任务改进的外推方法,它们利用了2D RoPE的解耦特性,分别对高度和宽度的旋转频率进行独立调整,以适应不同的纵横比。

这些方法通过修改模型的位置编码来适应新的分辨率,而不需要对模型权重进行任何调整或额外的训练。这样,FiT模型能够灵活地在不同的分辨率下生成图像,即使是在训练时未曾遇到的分辨率。

实验

研究者们遵循DiT-B和DiT-XL的设置,为基本模型FiT-B和xlarge模型FiT-XL设置了相同的层数、隐藏尺寸和注意力头数。研究者们采用了与DiT相同的预训练VAE编码器来编码和解码图像/潜在令牌。

研究者们通过一系列消融实验来检验和优化FiT模型的各个组成部分。这些实验包括对位置编码方式、前馈网络(FFN)中的激活函数,以及多头自注意力(MHSA)机制的调整。通过在特定的训练步骤后评估不同模型变体在多个分辨率上的性能,研究者们确定了哪些架构设计对于提升模型在不同分辨率图像生成任务上的表现最为关键。结果表明,引入2D旋转位置编码(2D RoPE)和SwiGLU激活函数,以及使用Masked MHSA代替传统的MHSA,能够有效提高模型对分辨率变化的适应性和生成图像的质量。

从DiT-B/2到FiT-B/2模型的消融研究结果

研究者们评估和改进了FiT模型在生成训练分布之外分辨率图像的能力。他们探索了多种分辨率外推技术,包括基于RoPE的插值方法,如NTK和YaRN,以及为FiT专门设计的VisionNTK和VisionYaRN方法。这些方法允许模型在不经过额外训练的情况下,有效地生成不同分辨率的图像,从而显著提高了模型的灵活性和应用范围。通过这些技术,FiT能够在保持图像质量的同时,处理更广泛的分辨率,包括那些在训练时未遇到的分辨率。

在分布外分辨率下,不同模型在ImageNet数据集上生成图像的性能比较。它包括了使用不同插值方法的FiT-B/2和DiT-B/2模型

研究者们训练了最高Gflops的模型FiT-XL/2,并在1.8M步数下进行了实验,以评估FiT在三种训练分布内的分辨率下的表现:256×256、160×320和128×384。他们将FiT与其他最先进的类条件生成模型进行了比较,包括BigGAN、StyleGAN-XL、MaskGIT、CDM、U-ViT、ADM、LDM、MDT和DiT。

实验结果表明,FiT-XL/2在所有评估的分辨率上都展现出了卓越的性能,超越了其他所有模型,特别是在160×320和128×384分辨率上,FiT-XL/2显著降低了FID得分,显示出其在生成高质量图像方面的显著优势。FiT-XL/2在256×256分辨率上尽管训练步数较少,但与其他经过更长时间训练的模型相比,仍显示出了竞争力。

在ImageNet数据集上,使用类条件图像生成模型在分布内和分布外分辨率生成图像的性能比较。表格中列出了不同模型在不同分辨率下的性能指标,如FID、sFID、IS、Precision和Recall

究者们评估了FiT-XL/2在三种训练分布外的分辨率下的表现:320×320、224×448和160×480,并与U-ViT、ADM、LDM-4、MDT和DiT等其他最先进的类条件生成模型进行了比较。他们发现FiT-XL/2在所有评估的分辨率和纵横比设置下都实现了最佳性能。

通过这些实验,研究者们展示了FiT模型在不同分辨率和纵横比下生成高质量图像的能力,证明了其在图像生成任务中的优越性和灵活性。

论文链接:https://arxiv.org/abs/2402.12376

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

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

相关文章

MySQL篇三:数据类型

文章目录 前言1. 数值类型1.1 tinyint类型1.2 bit类型1.3 小数类型1.3.1 float1.3.2 decimal 2. 字符串类型2.1 char2.2 varchar2.3 char和varchar比较 3. 日期类型4. enum和set 前言 数据类型分类: 1. 数值类型 1.1 tinyint类型 在MySQL中,整型可以指…

MPS---MPQ86960芯片layout设计总结

MPQ86960 是一款内置功率 MOSFET 和栅极驱动的单片半桥。它可以在宽输入电压 (VIN) 范围内实现高达 50A 的连续输出电流 (IOUT),通过集成MOSFET 和驱动可优化死区时间 (DT) 并降低寄生电感,从而实现高效率。 MPQ86960 兼容三态输出控制器,另…

[附源码]基于Flask的演唱会购票系统

摘要 随着互联网技术的普及和发展,传统购票方式因其效率低下、流程繁琐等问题已难以满足现代社会的需求。本文设计并实现了一个基于Flask框架的演唱会购票系统,该系统集成了用户管理、演唱会信息管理、票务管理以及数据统计与分析等功能模块&#xff0c…

如何让代码兼容 Python 2 和 Python 3?Future 库助你一臂之力

目录 01Future 是什么? 为什么选择 Future? 安装与配置 02Future 的基本用法 1、兼容 print 函数 2、兼容整数除法 3、兼容 Unicode 字符串 03Future 的高级功能 1. 处理字符串与字节 2. 统一异常处理…

nullptr和NULL

nullptr 既不是整型类型,也不是指针类型,nullptr 的类型是 std::nullptr_t(空指针类型),能转换成任意的指针类型。 NULL是被定义为0的常量,当遇到函数重载时,就会出现问题。避免歧义 函数重载…

Django QuerySet对象,filter()方法

filter()方法 用于实现数据过滤功能&#xff0c;相当于sql语句中的where子句。 filter(字段名__exact10) 或 filter(字段名10)类似sql 中的 10 filter(字段名__gt10) 类似SQL中的 >10 filter(price__lt29.99) 类似sql中的 <29.99 filter(字段名__gte10, 字段名__lte20…

ELFK简介

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;CSDN博客专家   &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01…

初识java—jdk17的一些新增特性

文章目录 前言一 &#xff1a; yield关键字二 &#xff1a;var关键字三 &#xff1a;密封类四 &#xff1a;空指针异常&#xff1a;五&#xff1a;接口中的私有方法&#xff1a;六&#xff1a;instanceof关键字 前言 这里介绍jdk17相对于jdk1.8的部分新增特性。 一 &#xff…

python集成Bartender实现二维码打印

本文摘录于&#xff1a;https://blog.csdn.net/mynameisJW/article/details/105500773只是做学习备份之用&#xff0c;绝无抄袭之意&#xff0c;有疑惑请联系本人&#xff01; 这里上传我优化了一下的代码:https://download.csdn.net/download/chengdong1314/89522026 我这里弄…

GuLi商城-商品服务-API-品牌管理-OSS整合测试

各语言SDK参考文档_对象存储(OSS)-阿里云帮助中心 安装SDK&#xff1a; <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.17.4</version> </dependency> 测试上传文件流&…

【leetcode周赛记录——405】

405周赛记录 #1.leetcode100339_找出加密后的字符串2.leetcode100328_生成不含相邻零的二进制字符串3.leetcode100359_统计X和Y频数相等的子矩阵数量4.leetcode100350_最小代价构造字符串 刷了一段时间算法了&#xff0c;打打周赛看看什么水平了 #1.leetcode100339_找出加密后的…

【微服务网关——服务发现】

1.服务发现 1.1 介绍 服务发现是指用注册中心来记录服务信息&#xff0c;以便其他服务快速查找已注册服务服务发现分类: 客户端服务发现服务端服务发现 1.2 客户端服务发现 客户端服务发现&#xff08;Client-side Service Discovery&#xff09;是一种微服务架构中的模式…

RAID的实现

软RAID&#xff0c;在实际工作中使用较少&#xff0c;性能太次。 mdadm工具&#xff0c;主要在虚拟机上使用&#xff0c; 硬RAID 用一个单独的芯片&#xff0c;这个芯片的名字叫做RAID卡&#xff0c;数据在RAID中进行分散的时候&#xff0c;用的就是RAID卡。 模拟RAID-5工作…

Http Json参数到x-www-form-urlencoded参数的在线转换工具

Json参数到x-www-form-urlencoded参数的在线转换工具

vue学习笔记之组件传值

说起组件传值&#xff0c;首先要介绍再vue中什么是组件。 组件&#xff08;Component&#xff09;&#xff0c;是vue中很强大的一个功能&#xff0c;可以将一些可重用的代码进行重用。所有的vue组件同时也是vue实例&#xff0c;可以接受使用相同的选项对象和提供相同的生命周期…

cf 7.7

Problem - C - Codeforces 大致意思&#xff1a; 找前缀&#xff0c;排序后使得本位之前数字和等于该位 &#xff08;以下代码超时了&#xff09; #include<bits/stdc.h> typedef long long ll;#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0) const ll …

哈希表——C语言

哈希表&#xff08;Hash Table&#xff09;是一种高效的数据结构&#xff0c;能够在平均情况下实现常数时间的查找、插入和删除操作。 哈希表的核心是哈希函数&#xff0c;哈希函数是一个将输入数据&#xff08;通常称为“键”或“key”&#xff09;转换为固定长度的整数的函数…

Linux--V4L2摄像头驱动框架及UVC浅析

一、前言 对于一个usb摄像头&#xff0c;它的内核驱动源码位于/drivers/media/usb/uvc/ 核心层&#xff1a;V4L2_dev.c文件 硬件相关层&#xff1a; uvc_driver.c文件 本篇记录基于对6.8.8.8内核下vivid-core.c文件&#xff08;虚拟视频驱动程序&#xff09;的分析&#xff…

人工智能项目论文复现

文章目录 &#xff08;一&#xff09;技术学习任务Ⅰ、机器学习之聚类1、基本介绍概念2、聚类分析基本介绍3、K均值聚类4、K近邻分类模型(KNN)5、均值漂移聚类6、代码实现7、上述三种算法总结 Ⅱ、机器学习其他常用技术1、决策树基本知识2、异常检测概念3、主成分分析4、决策树…

【SpringCloud应用框架】Nacos服务配置中心

第四章 Spring Cloud Alibaba Nacos之服务配置中心 文章目录 一、基础配置二、新建子项目1.pom文件2.YML配置3.启动类4.业务类5.Nacos配置规则 三、Nacos平台创建配置操作四、自动配置更新五、测试 一、基础配置 Nacos不仅仅可以作为注册中心来使用&#xff0c;同时它支持作为…