《深入浅出多模态》之多模态模型总结(中)

🎉AI学习星球推荐: GoAI的学习社区 知识星球是一个致力于提供《机器学习 | 深度学习 | CV | NLP | 大模型 | 多模态 | AIGC 》各方向综述、论文等成体系的学习资料,配有有深度的专栏内容,包括不限于前沿论文解读、资料共享、行业最新动态以、实践教程、求职相关(简历撰写技巧、面经)多方面综合学习平台,强烈推荐AI爱好者学习,作者所有文章内容都免费将更新在知识星球。➡ t.zsxq.com/Gx2eJ

💻 专栏目录

《深入浅出多模态》之多模态技术总结(上)

《深入浅出多模态》之多模态模型总结(中)

《深入浅出多模态》(一):多模态模型论文最全总结

《深入浅出多模态》(二):多模态任务应用与背景

《深入浅出多模态》(三):多模态任务前言知识

《深入浅出多模态》之多模态经典模型:CLIP

《深入浅出多模态》之多模态经典模型:ALBEF

《深入浅出多模态》之多模态经典模型:BLIP

《深入浅出多模态》之多模态经典模型:BLIP2

《深入浅出多模态》之多模态经典模型:MiniGPTv4

《深入浅出多模态》之多模态经典模型:MiniGPT-v2、MiniGPT5

《深入浅出多模态》之多模态经典模型:InstructBLIP

...

🔥本篇 导读: 本篇内容承接上篇《深入浅出多模态》之多模态技术总结(上),首先将围绕不同多模态模型的对齐方法对经典多模态模型进行对比与总结,并挑选主流的多模态模型CLIP、BLIP、BLIP2等展开详细介绍,最后引入厂内多模态框架PaddleMIX进行多任务实战,帮助大家快速了解多模态技术。

一、 主流多模态模型介绍

本文首先从多模态模型的基本思想、模型结构、损失设计及训练数据集情况对经典模型进行整理,太长不看版总结如下:

(1)CLIP

论文: Learning Transferable Visual Models From Natural Language Supervision

模型介绍

CLIP采用双塔结构,其核心思想是通过海量的弱监督文本对,通过对比学习,将图片和文本通过各自的预训练模型获得编码向量,通过映射到统一空间计算特征相似度,通过对角线上的标签引导编码器对齐,加速模型收敛。CLIP是一种弱对齐,可应用于图文相似度计算和文本分类等任务。

模型结构

1.图像编码器:使用的是之前文章提到的ViT网络,而且是效果比较好的ViT-L/14@336px

  • ViT-L中的L指代large,表示使用的Transformer的层数级别
  • 14表示每个子图像或者patch包含14*14 个像素点
  • 336px表示输入图像的像素是336x336
  • 所以最终图像被切分成 (336/14) (336/14)=576个子图,如果维度D为1024,那么一张图像就可以转化成5761024的序列 2.文本编码器:使用类似于 GPT-2 但更小的 Transformer 模型 3.投影:为了实现图像编码器和文本编码器输出的embedding向量在同一embedding空间中的一致性,使用了两个投影矩阵。这样,无论是图像还是文本编码器产生的向量,都将被投影到具有相同维度的空间中。
具体实现

在这里插入图片描述

  1. CLIP将图像和文本先分别输入一个图像编码器image_encoder和一个文本编码器text_encoder,得到图像和文本的向量表示 I_f 和 T_f 。其中 Image Encoder是 ResNet 或 Vision Transformer,Text Encoder 为 GPT-2。
  2. 将图像和文本的向量表示映射到一个多模态空间(不同类型的数据整合到一个统一的空间),得到新的可直接进行比较的图像和文本的向量表示 I_e 和T_e 。
  3. 计算图像向量和文本向量之间的cosine相似度。上述得到n x n矩阵,对角线为正样本为 1,其他为负样本0。有了n个图像的特征和n 个文本的特征之后,计算 cosine similarity,得到的相似度用来做分类的logits。
  4. 对比学习的目标函数就是让正样本对的相似度较高,负样本对的相似度较低。logits 和 ground truth 的labels 计算交叉熵损失,loss_i,loss_t分别是 Image 和 Text 的 loss,最后求平均就得到loss。

(2)BLIP

  • 论文地址: arxiv.org/pdf/2201.12...
  • 代码地址: github.com/salesforce/...
  • 体验地址: huggingface.co/spaces/akha...
  • 动机:
  • 从模型角度,vision-language pretraining 大多采用了encoder-base model或者 encoder-decoder based model。encoder-base model 无法实现文本生成,而encoder-decoder based model不能直接用于多模态检索。
  • 从数据角度,无论是CLIP、ALBEF训练的image-text 都是从web收集的,其中包含很多noisy data,vision-language训练是次优解。总结:BLIP既可以做内容理解,还可以做文本生成,是一个大一统的多模态预训练框架。(理解+生成 )
模型结构

BLIP由四个模块组成,分别是image encoder、text encoder(和image encoder 统一称为unimodal encoder)、image-grounded text encoder、image-grounded text decoder。

  1. image encoder:visual transformer,VIT
  2. text encoder:BERT(双向自注意力机制+FFN),加一个 cls token放在text input前面总结整句话
  3. image-grounded text encoder:将image encoder的输出一起输入的cross attention中,输入端加一个任务特定的encoder token,attention采用Bi self-attention,使得text全部可见。
  4. image-grounded text decoder:将image encoder的输出一起输入的cross attention中,输入端加一个任务特定的decoder token,attention采用causal self-attention,使得text只能见到当前和历史的文本。
损失函数

BLIP由三个损失函数监督,前两个是理解任务基础,另一个是生成任务基础 。具体损失如下:

Image-Text Contrastive Loss (ITC)

ITC通过对比学习,鼓励正向的图像-文本对在特征空间内靠近,而与负向对相远离,对齐视觉和文本转换器的特征空间。研究表明,ITC有效地促进了视觉和语言理解的提升。为了强化这一过程,ITC引入了动态编码器以产生特征,并利用软标签作为训练目标,以识别负对中潜在的正对。

Image-Text Matching Loss (ITM)

ITM专注于学习精细的视觉-语言对齐多模态表示。作为一个二分类任务,ITM用于预测图像-文本对是否匹配,通过线性层(ITM头)和它们的多模态特征。采用硬负采样策略,选择批次中对比相似度较高的负对参与损失计算,以获得更信息丰富的负样本。与ITC不同,ITM直接处理图像输入,以更精确地判断图像与文本的一致性。

Language Modeling Loss (LM)

LM旨在基于给定图像生成文本描述。LM通过交叉熵损失优化,以自回归形式训练模型,最大化文本可能性。在计算损失时,采用了0.1的标签平滑策略。不同于VLP中广泛使用的Masked Language Modeling损失,LM赋予模型根据视觉信息生成连贯文本描述的泛化能力。

数据生产

在这里插入图片描述

  • BLIP的关键创新在于引入预训练部分的Filter和Captioner模块。尽管CLIP使用了超过4亿个未经筛选的网络数据进行训练,但由于数据中包含大量噪声,模型的准确性受到了影响。BLIP在此基础上引入了这两个模块:
  • Filter用于清除不匹配的文本信息(去除噪声图像-文本对),而Captioner用于生成高质量文本信息(生成给定web图像的标题),进而提升图像-文本对训练数据集质量。两种都是从相同的预训练MED 模型初始化的,并在COCO数据集上分别进行微调,调优是一个轻量级的过程。

具体来说,BLIP首先以从网络爬取的可能不匹配的数据和部分人工标注的匹配数据(如COCO数据集)组成的数据集D进行预训练。BLIP利用人工标注的数据和内部的ITC&ITM模块微调Filter,筛选出不匹配的图像-文本对。接着,使用同样的标注数据和BLIP的Decoder微调Captioner,使其能根据图像生成匹配的文本,这些新文本再通过Filter判断其与原图像的匹配程度。通过这种方法,BLIP能构建一个高质量的新数据集D。

(3)BLIP2

  • 论文地址:Blip-2: Bootstrapping language-image pre-training with frozen image encoders and large language models (节约多模态训练成本:冻结预训练好的视觉语言模型参数 )发表于:ICML23
  • 代码地址:github

动机:CLIP通过相似性计算,对图像和文本算是粗对齐(因为文本和图像只对最后的结果比较,打比方,装修房子,问两个装好的房子像不像,只能看到一些表面的,具体的材料是看不到的)。

总结: 为减少计算成本并避免灾难性遗忘的问题, BLIP-2 在预训练时冻结预训练图像模型和语言模型,在中间添加一个轻量级 查询 Transformer (Query Transformer, Q-Former) 来弥合视觉和语言模型之间的模态隔阂 (modality gap)。在整个模型中,Q-Former 是唯一的可训练模块,而图像编码器和语言模型始终保持冻结状态。

在这里插入图片描述

论文中作者提出了一种预训练框架,利用 预训练frozen冻结的图像编码器 + 可学习的Q-Former 和 预训练frozen冻结的LLM大规模语言模型 来进行图像和语言的联合预训练。

1)Image Encoder:负责从输入图片中提取视觉特征,本文试验CLIP 训练的 ViT-L/14和EVA-CLIP训练的 ViT-g/14两种网络结构。

2)Large Language Model:负责文本生成,本文试验decoder-based LLM and encoder-decoder-based LLM。

3) Q-Former :为BLIP2核心使用用两阶段预训练 Q-Former 来弥补模态差距,共分为表示学习阶段和生成学习两个阶段。

第一阶段:表征学习
  • 表征学习阶段:Q-Former作为桥梁,来衔接图像编码器和LLM,并缩小两者表征上的GAP。Q-Former整体训练目标沿用BLIP,但在框架上更加精简,使用UniLM风格的统一自编码和自回归,使得由BERT随机初始化的32个Learned Queries将图像编码器的表示在语言空间中压缩对齐(其中,CA为每两层插入一次,用于融合图片视觉表征)。
第二阶段:从大规模语言模型学习视觉到语言生成
  • 生成学习阶段:将 Q-Former连接到冻结的 LLM,以利用 LLM 的语言生成能力。这里使用全连接层(FC,可视为Q-Former到LLM的适配器)将输出的Query嵌入线性投影到与 LLM 的文本嵌入相同的维度,然后将投影的Query嵌入添加到输入文本嵌入前面,实现替换LLM的部分文本嵌入(即软提示)。

BLIP2在Decoder-only 和Encoder-Decoder 架构的模型上均进行了实验。

  • Decoder only:将Q-former学到token直接输入,得到文本输出,论文中采用facebook的opt模型进行训练,具体过程如下。
  • encoder-decoder:将Q-former学到token加上前缀词(如图中的a cat)一起输入,得到后续的文本输出,论文中采用FlanT5添加指令进行训练。

注:目前BLIP系列已经更新到BLIP3 :《xGen-MM (BLIP-3): A Family of Open Large Multimodal Models》,在各方面进行升级:

  • 框架结构: xGen-MM (BLIP-3) 框架采用由 ViT、用于对图像嵌入进行下采样的视觉令牌采样器(感知器重采样器)、预采样器组成的架构j及训练有素的大型语言模型(phi3-mini)。
  • 训练流程: 预训练、有监督微调、交叉多模态微调和后训练四个阶段来加强模型理解能力。

(4 )LLaVa系列

论文动机: 通用LLM中指令遵循数据在Zero-shot场景下取得突破性进展,然而多模态领域探索的很少。

基本思想: LLaVA使用仅限语言的GPT-4生成多模态语言图像指令跟随数据,提出一种连接视觉编码器和LLM的端到端训练多模态大模型。

核心点: LLM基座采用更强的LLAMA模型,相比于BLIP-2 舍弃了Q-Former模块,直接将视觉编码器(CLIP)经过线性投影层作为LLM的软提示,再和指令数据一起让LLM生成对应任务回复。

  • 将Clip作为图像的编码器,在Clip后面加入一个线性映射层;
  • 将Clip编码后的图像特征Zv映射到语言模型特征空间中,得到视觉特征 Hv ;
  • 将其和文本的编码(语言指令的编码)一起送入到Language Model中。
训练流程:

在这里插入图片描述

  • 第一阶段--预训练阶段:只训练线性映射层(Projection W),目的是学习图像空间到语言模型词向量空间的映射,从CC3M 中过滤出595K图文对,并转换为单轮指令数据。
  • 第二阶段--微调阶段:冻结住视觉编码器的参数,训练线性映射层和大语言模型的参数。在这一阶段使用的数据集为ScienceQA和基于GPT-4生成的数据集。
模型结构:
  • 使用视觉编码器CLIP ViT-L/14+语言解码器LLaMA构成多模态大模型,然后使用生成的数据进行指令微调。
  • 输入图片X经过与训练好的视觉编码器的到图片特征Z,图片特征Z经过一个映射矩阵W转化为视觉Token H,这样Vison Token H_v与Language Token H_q指令就都在同一个特征空间,拼接后一起输入大模型。
  • 映射层W也可以替换为更复杂的网络来提升性能,比如Flamingo中用的gated cross-attentio,BLIP-2中用的Q-former。

注:目前LLaVa系列已更新LLaVa-1.5、LLaVa-1.6、LLaVa-NEXT多个版本,具体细节可参考链接:github.com/haotian-liu...

(5 )Qwen-VL系列

Githubgithub.com/QwenLM/Qwen... 体验地址:tongyi.aliyun.com/qianwen/ Qwen-VL系列模型是大规模的视觉语言模型,包含两个版本:Qwen-VL和Qwen-VL-Chat。Qwen-VL是一个预训练模型,通过视觉编码器的连接,它扩展了Qwen-7B语言模型的视觉能力,支持更灵活的交互,如多图像输入、多轮对话和定位能力。

模型特点:
  • 强大的性能:在相同规模模型下,它在多个评估基准测试(包括零样本字幕、VQA、DocVQA和定位)上明显优于现有的开源大型视觉语言模型
  • 支持文本识别和定位的多语言:Qwen-VL自然支持英语、中文和多语言对话,并推动中文和英文双语文本及图像中的实例端到端识别和定位。
  • 多图像交错对话:该功能允许输入和比较多个图像,以及指定与图像相关的问题并进行多图像讲故事能力。
  • 细粒度识别和理解:与其他开源LVLM当前使用的224 x 224分辨率相比,448 x 448分辨率提升了细粒度文本识别、文档QA和边界框检测。
模型结构

Qwen-VL模型主要分为图像编码器为ViT、连接模块为单层的查询+交叉注意力,改变图像序列的长度及LLM基座为Qwen(7B)器为ViT,大语言型为Qwen连接块为单层的询+交叉注意,改变图像序列的长度

  1. 大型语言模型:Qwen-VL采用使用Qwen-7B的预训练权重进行初始化。
  2. 视觉编码器:
  • Qwen-VL的视觉编码器使用Vision Transformer(ViT)架构,使用Openclip的ViT-bigG(1.9B)的预训练权重进行初始化。
  • 在训练和推理过程中,输入图像都调整为特定分辨率。其中ViT的视觉表征会经适配器转换为固定的256长度(前后追加和,与LLM的文本特征进行区分),论文认为位置对捕捉细粒度图像信息至关重要,二维绝对位置编码被引入适配器的query-key对中。视觉编码器通过步长为14对图像进行划分补丁,生成一组图像特征。
  1. 位置感知的视觉语言适配器(0.08B):为了缓解长图像特征序列带来的效率问题,Qwen-VL引入了一个压缩图像特征的视觉语言适配器。该适配器包含一个随机初始化的单层交叉注意力模块。
训练流程:

Qwen-VL系列作为目前国内主流多模态模型,其模型训练过程采用下图三个阶段进行训练,两个预训练阶段(预训练和多任务训练)和一个指令微调训练阶段。

Qwen-VL还通过将边界框到归一化为指定字符串格式并对定位框增加和,边界框对应描述增加<ref和加以区分,以此兼容区域描述问题和检测的数据形式,增强对细粒度视觉理解和定位的能力。

注:目前该系列已更新到Qwen2-VL,学习可参考链接:www.modelscope.cn/models/qwen...

三、多模态模型趋势总结

  • 思想:图文特征对齐、指令微调、多任务
  • 结构:图像编码器Image Encoder+-大语言模型LLM+对齐模块
  • Loss设计:参考对比学习探索不同的图文特征对齐方式,同时增加指令微调能力

四、全文总结:

本文主要对多模态模型的概念、下游任务类型、数据集、发展时间线的基础理论进行介绍,着重讲解经典多模态大模型(CLIP、BLIP、BLIP2等)原理及,最后对多模态趋势进行总结,欢迎大家在评论区交流学习,作者能力有限,若文中描述有误也欢迎大家指导!

相关推荐
Java与Android技术栈2 分钟前
图像编辑器 Monica 之 CV 常见算法的快速调参
算法
别NULL14 分钟前
机试题——最小矩阵宽度
c++·算法·矩阵
珊瑚里的鱼15 分钟前
【单链表算法实战】解锁数据结构核心谜题——环形链表
数据结构·学习·程序人生·算法·leetcode·链表·visual studio
无限码力19 分钟前
[矩阵扩散]
数据结构·算法·华为od·笔试真题·华为od e卷真题
gentle_ice19 分钟前
leetcode——矩阵置零(java)
java·算法·leetcode·矩阵
查理零世21 分钟前
保姆级讲解 python之zip()方法实现矩阵行列转置
python·算法·矩阵
刀客12332 分钟前
python3+TensorFlow 2.x(四)反向传播
人工智能·python·tensorflow
SpikeKing38 分钟前
LLM - 大模型 ScallingLaws 的设计 100B 预训练方案(PLM) 教程(5)
人工智能·llm·预训练·scalinglaws·100b·deepnorm·egs
zhbi9841 分钟前
测量校准原理
算法
时间很奇妙!1 小时前
decison tree 决策树
算法·决策树·机器学习