Skip to content

Latest commit

 

History

History
217 lines (181 loc) · 12.6 KB

README_zh.md

File metadata and controls

217 lines (181 loc) · 12.6 KB

mPLUG-Owl🦉: Modularization Empowers Large Language Models with Multimodality

Qinghao Ye*, Haiyang Xu*, Guohai Xu*, Jiabo Ye, Ming Yan†, Yiyang Zhou, Junyang Wang, Anwen Hu, Pengcheng Shi, Yaya Shi, Chaoya Jiang, Chenliang Li, Yuanhong Xu, Hehong Chen, Junfeng Tian, Qian Qi, Ji Zhang, Fei Huang
阿里巴巴集团,达摩院
*Equal Contribution; † Corresponding Author
Open in Spaces Demo ModelScope License Hits
English | 简体中文

示例

Training paradigm and model overview Training paradigm and model overview

最新更新

  • 🔥 [05.05] 我们发布了指令微调的代码。
  • 🔥 [05.05] 我们在HuggingFace上也搭建了Demo。感谢HuggingFace提供的免费算力!
  • 🔥 [05.05] HuggingFace上的Demo现在已经支持视频输入!ModelScope上的Demo也即将支持。
  • 🔥 [05.05] 我们公开了视觉相关指令的测评集OwlEval
  • [04.26] 我们在Modelscope上提供了一个在线Demo供大家体验。
  • [04.26] 我们开放了mPLUG-Owl🦉,以及推理代码和二阶段微调参数。

亮点特色

  • 一种面向多模态语言模型的模块化的训练范式。
  • 能学习与语言空间相适应的视觉知识,并支持在多模态场景(支持图片、视频、文本输入)下进行多轮对话
  • 涌现多图关系理解场景文本理解基于视觉的文档理解等能力。
  • 提出了针对视觉相关指令的测评集OwlEval,用以评估多模态语言模型的对带有视觉信息上下文的理解能力。
  • 我们在模块化上的一些探索:
  • 即将发布
    • 在HuggingFace Hub上发布。
    • 多语言支持(中文、日文等)。
    • 在多图片/视频数据上训练的模型
    • Huggingface 在线Demo
    • 指令微调代码。
    • 视觉相关指令的测评集OwlEval

Training paradigm and model overview

在线Demo

ModelScope

Hugging Face

Open in Spaces

预训练参数

Model Phase Download link
mPLUG-Owl 7B Pre-training 下载链接
mPLUG-Owl 7B Instruction tuning 下载链接
Tokenizer model N/A 下载链接

OwlEval

我们所使用的评测集放在 ./OwlEval 中。

使用

安装依赖

  1. 创建conda环境
conda create -n mplug_owl python=3.10
conda activate mplug_owl
  1. 安装PyTorch
conda install pytorch==1.13.1 torchvision==0.14.1 torchaudio==0.13.1 pytorch-cuda=11.7 -c pytorch -c nvidia
  1. 安装 Apex(在下一个版本中将移除Apex依赖)

    Apex 需要从源代码手动编译,因为 mPLUG-Owl 依赖于其 cpp 扩展(MixedFusedLayerNorm)。

    考虑到 Apex 代码经常更改,我们在代码库中包含了 Apex 的固定副本,可以使用以下命令进行安装:

cd apex_22.01_pp

TORCH_CUDA_ARCH_LIST='5.2 6.0 6.1 7.0 7.5 8.0 8.6' pip install -v --disable-pip-version-check --no-cache-dir --global-option="--cpp_ext" --global-option="--cuda_ext" ./
  1. 安装其它依赖
pip install -r requirements.txt

本地部署Demo

我们提供了一个易扩展的脚本来一键部署本地Demo,你可以根据自己的需求进行修改。

python -m server_mplug.owl_demo --debug --port 6363 --checkpoint_path 'your checkpoint path' --tokenizer_path 'your tokenizer path'

推理

如果要实现自定义的推理,可以参考以下步骤。

构建model, tokenizer, img_processor

from interface import get_model
model, tokenizer, img_processor = get_model(
        checkpoint_path='checkpoint path', tokenizer_path='tokenizer path')

准备模型输入

# We use a human/AI template to organize the context as a multi-turn conversation.
# <image> denotes an image placehold.
prompts = [
'''The following is a conversation between a curious human and AI assistant. The assistant gives helpful, detailed, and polite answers to the user's questions.
Human: <image>
Human: Explain why this meme is funny.
AI: ''']

# The image paths should be placed in the image_list and kept in the same order as in the prompts.
# We support urls, local file paths and base64 string. You can custom the pre-process of images by modifying the mplug_owl.modeling_mplug_owl.ImageProcessor
image_list = ['https://xxx.com/image.jpg',]

对于多张图片,由于这是模型涌现的能力(训练数据并不包含多图的样本),我们并不知道何种格式对模型而言是最佳的。下面是我们在实验中所使用的格式。大家也可以自行探索能让模型更好理解多图关系的格式或者prompt。

prompts = [
'''The following is a conversation between a curious human and AI assistant. The assistant gives helpful, detailed, and polite answers to the user's questions.
Human: <image>
Human: <image>
Human: Do the shirts worn by the individuals in the first and second pictures vary in color? If so, what is the specific color of each shirt?
AI: ''']

image_list = ['https://xxx.com/image_1.jpg', 'https://xxx.com/image_2.jpg']

获取模型回复

# generate kwargs (the same in transformers) can be passed in the do_generate()
from interface import do_generate
sentence = do_generate(prompts, image_list, model, tokenizer,
                               img_processor, max_length=512, top_k=5, do_sample=True)

指令微调

训练样本存放在xxx.jsonl 中,格式如下:

{"text": "The following is a conversation between a curious human and AI assistant. The assistant gives helpful, detailed, and polite answers to the user's questions.\nHuman: Construct a sentence using the given verb in the past tense\nshudder\nAI: She shuddered at the thought of being alone in the dark.", "task_type": "gpt4instruct_sft"}
{"image": ["xxx.jpg"], "text": "The following is a conversation between a curious human and AI assistant. The assistant gives helpful, detailed, and polite answers to the user's questions.\nHuman: <image>\nHuman: Where is the man located in the image?\nAI: The man is located in a small restaurant, sitting and enjoying his meal.\nHuman: What type of food is the man eating in the image?\nAI: The man is eating a burrito in the image.\nHuman: What can be seen next to the man in the restaurant?\nAI: Next to the man in the restaurant, there is a fridge filled with cans of soda.\nHuman: How does the man feel as he is about to eat his meal?\nAI: The man looks happy and is smiling as he is about to take a bite of his meal.\nHuman: What unique aspect of the photo makes the scene appear distorted or unusual?\nAI: The unique aspect of this photo is that it was taken using a fish-eye lens, which creates a distorted, wide-angle view of the scene, making it appear different from a standard perspective.", "task_type": "llava_sft"}

其中 task_type 可以为 {'quora_chat_sft', 'sharegpt_chat_sft', 'llava_sft', 'gpt4instruct_sft'}

准备好 train.jsonl 和 dev.jsonl 并修改 configs/instruction_tuning/v0.yaml 中的 data_files.

执行训练脚本。

bash train_it.sh

性能比较

我们展示了50个单轮对话(左)和52个多轮对话(右)在人工评估指标下,mPLUG-Owl和基线方法的比较结果。A/B/C/D表示评分人员对每个回复的评级。

Comparison Results

相关项目

  • LLaMA. 开源的大型预训练语言模型系列。
  • Baize. 使用LoRA在10万个通过让ChatGPT自聊生成的对话上进行训练的开源聊天模型。
  • Alpaca. 从7B LLaMA模型上进行微调训练的,用于52K个指令数据的模型。
  • LoRA. 即插即用的模块,可以极大地减少下游任务的可训练参数数量。
  • MiniGPT-4. 仅使用一个线性映射层,将冻结的语言模型和视觉编码器结合的多模态语言模型。
  • LLaVA. 经过视觉指令调整的视觉语言模型,可以实现GPT4级别的能力。
  • mPLUG. 视觉语言基础模型,可以用于跨模态理解和生成。
  • mPLUG-2. 具有模块化设计的多模态模型,启发了我们的项目。

引用

如果我们的工作对你有帮助,可以考虑给我们的仓库点个star & 引用我们的论文。

@misc{ye2023mplugowl,
      title={mPLUG-Owl: Modularization Empowers Large Language Models with Multimodality}, 
      author={Qinghao Ye and Haiyang Xu and Guohai Xu and Jiabo Ye and Ming Yan and Yiyang Zhou and Junyang Wang and Anwen Hu and Pengcheng Shi and Yaya Shi and Chaoya Jiang and Chenliang Li and Yuanhong Xu and Hehong Chen and Junfeng Tian and Qian Qi and Ji Zhang and Fei Huang},
      year={2023},
      eprint={2304.14178},
      archivePrefix={arXiv},
      primaryClass={cs.CL}
}