中文 | English
论文 | 演示 | 对话演示 | 详细描述 | 模型权重 | 始智AI
Monkey 引入了一种高效的训练方法,可以有效地将输入分辨率提高到 896 x 1344 ,同时不需要从开始进行预训练。为了弥合简单的文本描述和高输入分辨率之间的差距,Monkey 还提出了一种多级描述生成方法,该方法自动提供丰富的信息,可以指导模型学习场景和对象之间的关联。通过这两种设计的协同作用,Monkey 在多个基准测试中取得了优异的结果。与各种多模态大模型(包括 GPT4V)相比,Monkey 通过关注文本信息并捕获图像中的精细细节,在图像字幕方面表现出了良好的性能;高输入分辨率还可以使模型在具有密集文本的文档图像中展现出出色的性能。
- 上下文关联。 Monkey在回答问题时展现了更有效地推断目标之间关系的卓越能力,从而能够提供更全面和更有洞察力的结果。
- 支持高达 1344 x 896 的分辨率。 Monkey支持的分辨率的显着超越了 LMM 通常采用的标准 448 x 448 分辨率,增强了辨别和理解不明显或紧密聚集的对象和密集文本的能力。
- 性能提高 在 16 个不同的数据集上进行了测试,结果表明 Monkey 在图像字幕、一般视觉问答、以文本为中心的视觉问答和面向文档的视觉问答等任务中表现出色。
conda create -n monkey python=3.9
conda activate monkey
git clone https://github.com/Yuliang-Liu/Monkey.git
cd ./Monkey
pip install -r requirements.txt
演示 快速且易于使用。只需从桌面或手机上传图像,或直接拍照即可。
为了提供更好的交互体验,我们还推出了原始演示的升级版本对话演示。
我们观察到对于一些随机图片Monkey可以取得比GPT4V更准确的结果。
我们还提供原始演示的源代码和模型权重,允许您自定义某些参数以获得更独特的体验。具体操作如下:
- 确保您配置好了环境.
- 您可以选择在线或离线方法运行demo.py:
- 离线:
- 下载模型权重.
- 修改
demo.py
文件里的DEFAULT_CKPT_PATH="pathto/Monkey"
为您下载的模型权重的路径。 - 用下面的命令运行演示:
python demo.py
- 在线:
- 使用下面的命令加载模型并运行演示:
python demo.py -c echo840/Monkey
为了生成更详细的字幕,我们提供了一些 prompt 示例,以便您进行更有趣的探索。您可以在caption
函数中修改这两个变量来实现字幕任务的不同提示输入,如下所示:
query = "Generate the detailed caption in English. Answer:"
chat_query = "Generate the detailed caption in English. Answer:"
- Generate the detailed caption in English.
- Explain the visual content of the image in great detail.
- Analyze the image in a comprehensive and detailed manner.
- Describe the image in as much detail as possible in English without duplicating it.
- Describe the image in as much detail as possible in English, including as many elements from the image as possible, but without repetition.
我们开源了多级描述生成方法生成的数据。您可以在这里下载:详细描述数据.
我们在evaluate_vqa.py
文件中提供了 14 个视觉问答(VQA)数据集的评估代码,以便于快速验证结果。具体操作如下:
- 确保您配置好了环境.
- 修改
sys.path.append("pathto/Monkey")
为模型权重的路径。 - 准备需要评估的数据集。
- 运行评估代码。
以ESTVQA数据集的评测为例:
- 按照下面的格式准备数据集:
├── data
| ├── estvqa
| ├── test_image
| ├── {image_path0}
| ├── {image_path1}
| ·
| ·
| ├── estvqa.jsonl
- 注释文件
.jsonl
每行的格式示例:
{"image": "data/estvqa/test_image/011364.jpg", "question": "What is this store?", "answer": "pizzeria", "question_id": 0}
- 修改这个字典
ds_collections
:
ds_collections = {
'estvqa_test': {
'test': 'data/estvqa/estvqa.jsonl',
'metric': 'anls',
'max_new_tokens': 100,
},
...
}
- 运行下面的命令:
bash eval/eval.sh 'EVAL_PTH' 'SAVE_NAME'
我们还提供 Monkey 的模型定义和训练代码,您可以在上面进行探索。 通过执行finetune_ds_debug.sh
来进行训练。
注意: 需要指定训练数据的路径,该路径应该是包含对话列表的 json 文件。
Monkey 可以准确地描述图像中的细节。
Monkey 在密集文本问答任务中表现特别好。 例如,在商品标签的密集文本中,Monkey 可以准确回答有关该商品的各种信息,与包括 GPT4V 在内的其他 LMMs 相比,Monkey的性能非常突出。
Monkey 在日常生活场景中也表现同样出色。 它可以完成各种问答和字幕任务,详细描述图像中的各种细节,甚至是不显眼的水印。
与现有的 LMMs(包括 GPT4V、Qwen-vl 等)进行定性比较,Moneky 显示出令人鼓舞的结果。 您可以尝试使用我们提供的演示。
如果您觉得我们的论文和代码对研究有帮助,请考虑star和引用:
@article{li2023monkey,
title={Monkey: Image Resolution and Text Label Are Important Things for Large Multi-modal Models},
author={Li, Zhang and Yang, Biao and Liu, Qiang and Ma, Zhiyin and Zhang, Shuo and Yang, Jingxu and Sun, Yabo and Liu, Yuliang and Bai, Xiang},
journal={arXiv preprint arXiv:2311.06607},
year={2023}
}
我们在 Qwen-VL 的基础上构建代码。感谢 Qwen 的作者提供的框架。
我们欢迎提出建议来帮助我们改进 Monkey。如有任何疑问,请联系刘禹良博士:[email protected]。如果您发现有趣的事,也请随时通过电子邮件与我们分享或提出问题。谢谢!