cvpr 2024|注意力校准用于解缠结的文本到图像个性化
moboyou 2025-05-13 22:12 36 浏览
Attention Calibration for Disentangled Text-to-Image Personalization
研究背景
近年来,大规模文本到图像(T2I)模型取得了显著进展,能够生成高质量和多样化的图像内容。个性化技术进一步允许用户仅通过几张参考图像来定制新概念的生成。然而,一个有趣且未解决的问题是:是否可以从单个参考图像中捕获多个新颖概念?现有方法通常无法保持与参考图像的视觉一致性,并消除概念之间的相互影响。
研究意义
本文提出了一种注意力校准机制,旨在提高T2I模型在概念级别的理解能力。该方法能够从单个图像中学习多个解缠结的概念,并生成具有这些学习概念的定制图像。这不仅能够增强T2I模型的灵活性和个性化能力,还能在图像编辑、艺术创作等领域具有广泛的应用前景。
文献综述
文本到图像生成模型
T2I模型的目标是根据给定的文本描述生成对应的图像。随着大规模数据集和先进语言模型的发展,T2I模型取得了显著进步。特别是扩散模型,在图像生成质量上领先其他方法。然而,这些模型在生成特定对象(如定制家具)时仍面临挑战。
文本引导的图像编辑
随着强大的T2I模型的出现,众多研究致力于增强扩散模型的可控性以满足用户的多样化需求。这些方法通过优化交叉注意力单元、使用区域控制或结合预训练的扩散模型来实现图像的局部或全局修改。
T2I个性化
个性化技术通过用户提供的图像使扩散模型学习新概念。这些方法通常依赖于包含3-5张图像的小数据集,甚至单张图像。然而,现有方法在处理单张图像以获取多个概念时仍面临挑战。
具体方法
本文提出了DisenDiff方法,通过注意力校准机制来优化T2I模型,使其能够从单个图像中理解多个概念。具体方法如下:
引入新的可学习修饰符:与类别绑定以捕获多个概念的属性。
注意力校准:
绑定约束:通过最小化修饰符和对应类别之间的注意力图交集,使修饰符聚焦于相关概念。
分离与加强策略:通过最小化不同类别注意力图的重叠区域,确保概念的独立性和完整性。
抑制技术:通过抑制不重要的激活区域,获得更清晰的类别注意力图。
训练损失:包括基础损失、绑定损失和分离与加强损失,共同优化模型的注意力图。
图1
标题:给定单个用户图像,提出的方法能够为每个包含的概念生成定制图像
描述:
- 输入:单个图像,包含多个概念(例如,一个男人和一个女人)。
- 输出:独立概念:分别为每个概念生成定制图像(例如,单独的男人和女人)。组合概念:将多个概念组合在一起生成定制图像(例如,男人和女人在一起)。
- 特点:保持与输入图像的高保真度和身份一致性。根据不同的文本提示实现满意的交互式生成。
图2
标题:Custom Diffusion的失败案例
描述:
- 输入:包含椅子和台灯的图像。
- 目标文本:“一盏V*2台灯”。
- 结果:Custom Diffusion生成的图像不仅包含不匹配的台灯,还错误地包含了椅子。
- 对比:提出的方法能够准确生成只包含指定台灯且外观与输入图像一致的图像。
图3
标题:方法概述
描述:
- 关键组件:文本编码器:将输入文本编码为键(K)和值(V)矩阵。扩散U-Net:预测添加的噪声,并通过交叉注意力机制整合文本特征。
- 约束:对关键令牌(如修饰符和类令牌)的交叉注意力图施加约束,以确保准确表示多个概念。
公式1,是扩散模型的训练目标函数,用于预测添加的噪声。其中,x是输入图像,y是输入文本,ε是随机噪声,z_t是在时间步t的潜在噪声代码,εθ是扩散模型预测的噪声,τθ是文本编码器的输出。
图4
标题:生成的注意力图和图像比较
描述:
- 第一行:Custom Diffusion生成的注意力图和图像,注意力图混乱,导致生成的图像不准确。
- 第二行:提出的方法生成的注意力图和图像,注意力图清晰准确,生成的图像与输入图像高度一致。
- 关键点:修饰符令牌(V*i)的注意力图通过与类令牌的绑定约束得到校正。通过分离和加强(s&s)策略减少不同类令牌注意力图的重叠。
公式2,是计算交叉注意力图的公式。Q是查询矩阵,K是键矩阵,d是键和查询的投影维度。通过Softmax函数将点积结果归一化,得到注意力图A_t。
公式3,是绑定约束的损失函数,用于将修饰符令牌V*i的注意力图A_{m_i_t}与其对应的类令牌注意力图A_{c_i_t}绑定在一起。通过计算两个注意力图的交并比(IoU)的补数来鼓励它们之间的紧密对齐。
公式4,是用于最小化不同类令牌注意力图重叠的损失函数。通过直接计算两个注意力图的交集来防止它们的激活区域重叠。
公式5,是分离和加强(s&s)策略的损失函数,用于在避免重叠的同时保持类令牌的完整性。通过计算两个注意力图的交并比来平衡这两个目标。
公式6,总训练损失由三部分组成:基础损失(L_{base})、绑定损失(L_{bind})和分离与加强损失(L_{s&s})。绑定损失用于将新修饰符与其对应的类别绑定,分离与加强损失用于分离不同类别的注意力图并加强其完整性。G表示高斯滤波,f_m表示元素乘法操作。
图5
标题:独立和组合概念的定性结果
描述:
- 独立概念:生成的图像能够准确捕捉输入图像中每个概念的外观,并且没有相互干扰。
- 组合概念:生成的图像将多个概念组合在一起,同时保持每个概念的视觉一致性。
- 对比:DreamBooth要么缺少关键概念属性,要么严重过拟合输入图像。Custom Diffusion在保持概念外观或解耦输入图像方面仍然存在困难。提出的方法在视觉保真度和编辑有效性之间取得了最佳平衡。
图6
内容:定量评估结果
- 子图6(a):展示了不同方法在十个数据集上的平均评估结果。
- 纵轴表示图像对齐度(Image Alignment)和文本对齐度(Text Alignment)的分数。
- 横轴表示不同的评估指标和方法,包括我们的方法(DisenDiff,绿色)、Textual Inversion(TI)、DreamBooth(DB)和Custom Diffusion(CD)。
- 结果显示,DisenDiff在图像对齐度上表现最佳,尤其是在Concept 2上,同时在文本对齐度上也保持了与其他方法相当的水平。
- 子图6(b):消融研究结果,评估了不同组件对模型性能的影响。
- 移除L_bind损失、L_s&s损失、抑制策略、高斯滤波以及应用两次抑制等设置下的性能变化。
- 结果表明,完整的DisenDiff模型在图像对齐度和文本对齐度之间达到了最佳平衡。
图7
内容:个性化概念修复应用示例
- 展示了给定输入图像和掩码后,模型能够无缝地将学习到的概念修复到掩码区域。
- 示例中,输入图像包含一张桌子和一盏灯,掩码区域覆盖了桌子的一部分。通过修改文本提示,用户可以轻松地在掩码区域内生成与输入图像风格一致的新内容。
图8
内容:与LoRA集成的应用示例
- 展示了将DisenDiff模型与LoRA参数结合,以增强图像生成的语义表达能力。
- 示例中,通过引入LoRA参数,生成的图像在细节上(如纹理)更加丰富和准确。
图9
内容:扩展到三个概念的应用示例
- 展示了DisenDiff模型在处理包含三个概念的输入图像时的能力。
- 通过应用L_s&s损失来解耦这三个概念,模型能够分别理解和生成每个概念。
相关推荐
- Node.js 获取文件信息及路径(node.js怎么获取当前文件路径)
-
获取文件信息每个文件都有一组细节,我们可以使用Node.js进行检查。特别是使用fs模块提供的stat()方法。constfs=require('fs');fs.stat(...
- 深入剖析JavaScript中深浅拷贝(js实现深浅拷贝)
-
大家好,我是Echa。最近有一位00后的小妹妹粉丝私信小编说自己很喜欢编程,目前在某公司实习前端开发工作,说到现在为止还没有搞懂JavaScript中深拷贝和浅拷贝这个问题,同时也在网上看了很多关于深...
- 为什么高手写 JS 总是又快又好?这10个技巧你要知道
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!JavaScript是前端开发的重要语言...
- IT技术栈:Javascript神器,URL.createObjectURL()
-
URL.createObjectURL()是JavaScript中的一个方法,用于创建一个特殊的URL,该URL可以用于将不支持直接加载的数据(如二进制数据或Blob对象)嵌入到we...
- 如何在 Linux 中创建和管理组?(linux如何建立组)
-
在Linux中,组是用户账户的集合,用于统一管理权限。每个用户至少属于一个主组(PrimaryGroup),还可以加入多个附加组(SupplementaryGroup)。组的权限设置决定了用户对文...
- 付费文库内容无法复制,不用任何工具,学会这4种方法轻松复制
-
关注职场办公,分享实用干货,洞察科技资讯,这里是「职场科技范」。我们在搜索资料的时候,看到非常有用的文库,但往往都是付费的,只能看不能复制。今天就来教大家,学会下面这4种方法,轻松复制文库内容。一、内...
- node.js v24.0.0 正式发布!10大重磅更新助力开发者,性能大幅提升
-
近日,Node.js官方团队正式发布了Node.jsv24.0.0版本,这是一个具有里程碑意义的重大更新。作为"Current"版本,它将在未来六个月内引领Node.js...
- 我理解的网站产品经理之四:网站产品前端姿势
-
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。2016年了,嗨,大家新年好。作为一个网页的产品经理,网页的前端知识可谓是不能不知,本文主讲网站产品的前端姿势。通常,...
- 五一我要看七天小说!免费开源的轻量化书库talebook搭建流程。
-
这次来分享一个简单阅读项目:TaleBook,项目曾用名calibre-webserver。TaleBook是一个基于Calibre的简单的个人图书管理系统,支持在线阅读。不过鉴于各种规章制度,仅...
- “5 分钟 CMake 使用指南,解决我的 C++ 打包问题!”
-
在软件开发的世界里,构建系统扮演着至关重要的角色,它不仅决定了项目的构建效率,还直接影响到团队协作的流畅度。对于许多C++开发者而言,CMake因其强大的功能和广泛的兼容性成为了构建自动化流程的...
- 大佬级鬼才终于把JavaScript整理成了修仙小说,让学习变简单
-
这是一本讲解JavaScript编程语言的技术书籍,只不过,本书采用了一种全新的写作手法。如果你厌倦了厚厚的、如同字典般的编程书籍,不妨尝试一下新的口味,话不多说,直接上干货!目录截图:内容展示:以上...
- JavaScript基础知识点总结(javascript基础入门教程)
-
//逗比小憨憨/*第一章*HTML引用js方法:*1,外部引用:HTML外部引用js:<scriptsrc="js/day1.js"></script>*2,...
- 在Node.js中处理Zip文件(node运行js文件)
-
作者:疯狂的技术宅转发链接:https://mp.weixin.qq.com/s/edJd9-t1AyTGRcha_1k6RA前言Zip文件是常用的压缩文件格式。在本文中,我将演示如何用adm-...
- Python 标准库中鲜为人知的宝藏 | Node.js 22.8.0 发布
-
Python标准库中鲜为人知的宝藏Python标准库功能强大,但有些模块却鲜为人知。本文将介绍一些有趣且实用的模块,助你提升代码效率和功能。数据结构:超越列表和字典除了常用的列表和字典,coll...
- 小程序,wxml页面里如何写JS代码?WXS如何模块化?
-
这篇接着上篇小程序,跳转页面的两种方式及其页面传参数继续讲,小程序wxml页面里如何写JS代码?wxs如何模块化?第一个问题:wxml页面要想类似HTML页面中写js代码,必须在页面中使用wxs标...
- 一周热门
- 最近发表
-
- Node.js 获取文件信息及路径(node.js怎么获取当前文件路径)
- 深入剖析JavaScript中深浅拷贝(js实现深浅拷贝)
- 为什么高手写 JS 总是又快又好?这10个技巧你要知道
- IT技术栈:Javascript神器,URL.createObjectURL()
- 如何在 Linux 中创建和管理组?(linux如何建立组)
- 付费文库内容无法复制,不用任何工具,学会这4种方法轻松复制
- node.js v24.0.0 正式发布!10大重磅更新助力开发者,性能大幅提升
- 我理解的网站产品经理之四:网站产品前端姿势
- 五一我要看七天小说!免费开源的轻量化书库talebook搭建流程。
- “5 分钟 CMake 使用指南,解决我的 C++ 打包问题!”
- 标签列表
-
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle安装补丁 (19)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- css class选择器用法 (25)
- css样式引入 (30)
- html5和css3新特性 (19)
- css教程文字移动 (33)
- php简单源码 (36)
- php个人中心源码 (25)
- 网站管理平台php源码 (19)
- php小说爬取源码 (23)
- github好玩的php项目 (18)
- 云电脑app源码 (22)
- js创建txt文件 (18)