|
--- |
|
license: apache-2.0 |
|
language: |
|
- en |
|
pipeline_tag: image-text-to-text |
|
tags: |
|
- chat |
|
--- |
|
|
|
# mPLUG-Owl3 |
|
|
|
## Introduction |
|
mPLUG-Owl3 is a state-of-the-art multi-modal large language model designed to tackle the challenges of long image sequence understanding. We propose Hyper Attention, which boosts the speed of long visual sequence understanding in multimodal large language models by sixfold, allowing for processing of visual sequences that are eight times longer. Meanwhile, we maintain excellent performance on single-image, multi-image, and video tasks. |
|
|
|
Github: [mPLUG-Owl](https://github.com/X-PLUG/mPLUG-Owl) |
|
|
|
## Quickstart |
|
|
|
Load the mPLUG-Owl3. We now only support attn_implementation in ```['sdpa', 'flash_attention_2']```. |
|
```Python |
|
import torch |
|
model_path = 'mPLUG/mPLUG-Owl3-7B-240728' |
|
config = mPLUGOwl3Config.from_pretrained(model_path) |
|
print(config) |
|
# model = mPLUGOwl3Model(config).cuda().half() |
|
model = mPLUGOwl3Model.from_pretrained(model_path, attn_implementation='sdpa', torch_dtype=torch.half) |
|
model.eval().cuda() |
|
``` |
|
Chat with images. |
|
```Python |
|
from PIL import Image |
|
|
|
from transformers import AutoTokenizer, AutoProcessor |
|
from decord import VideoReader, cpu # pip install decord |
|
model_path = 'mPLUG/mPLUG-Owl3-7B-240728' |
|
tokenizer = AutoTokenizer.from_pretrained(model_path) |
|
processor = model.init_processor(tokenizer) |
|
|
|
image = Image.new('RGB', (500, 500), color='red') |
|
|
|
messages = [ |
|
{"role": "user", "content": """<|image|> |
|
Describe this image."""}, |
|
{"role": "assistant", "content": ""} |
|
] |
|
|
|
inputs = processor(messages, images=[image], videos=None) |
|
|
|
inputs.to('cuda') |
|
inputs.update({ |
|
'tokenizer': tokenizer, |
|
'max_new_tokens':100, |
|
'decode_text':True, |
|
}) |
|
|
|
|
|
g = model.generate(**inputs) |
|
print(g) |
|
``` |
|
|
|
Chat with a video. |
|
```Python |
|
from PIL import Image |
|
|
|
from transformers import AutoTokenizer, AutoProcessor |
|
from decord import VideoReader, cpu # pip install decord |
|
model_path = 'mPLUG/mPLUG-Owl3-7B-240728' |
|
tokenizer = AutoTokenizer.from_pretrained(model_path) |
|
processor = model.init_processor(tokenizer) |
|
|
|
|
|
messages = [ |
|
{"role": "user", "content": """<|video|> |
|
Describe this video."""}, |
|
{"role": "assistant", "content": ""} |
|
] |
|
|
|
videos = ['/nas-mmu-data/examples/car_room.mp4'] |
|
|
|
MAX_NUM_FRAMES=16 |
|
|
|
def encode_video(video_path): |
|
def uniform_sample(l, n): |
|
gap = len(l) / n |
|
idxs = [int(i * gap + gap / 2) for i in range(n)] |
|
return [l[i] for i in idxs] |
|
|
|
vr = VideoReader(video_path, ctx=cpu(0)) |
|
sample_fps = round(vr.get_avg_fps() / 1) # FPS |
|
frame_idx = [i for i in range(0, len(vr), sample_fps)] |
|
if len(frame_idx) > MAX_NUM_FRAMES: |
|
frame_idx = uniform_sample(frame_idx, MAX_NUM_FRAMES) |
|
frames = vr.get_batch(frame_idx).asnumpy() |
|
frames = [Image.fromarray(v.astype('uint8')) for v in frames] |
|
print('num frames:', len(frames)) |
|
return frames |
|
video_frames = [encode_video(_) for _ in videos] |
|
inputs = processor(messages, images=None, videos=video_frames) |
|
|
|
inputs.to('cuda') |
|
inputs.update({ |
|
'tokenizer': tokenizer, |
|
'max_new_tokens':100, |
|
'decode_text':True, |
|
}) |
|
|
|
|
|
g = model.generate(**inputs) |
|
print(g) |
|
``` |
|
|
|
|
|
## Citation |
|
|
|
If you find our work helpful, feel free to give us a cite. |
|
|
|
``` |
|
@misc{ye2024mplugowl3longimagesequenceunderstanding, |
|
title={mPLUG-Owl3: Towards Long Image-Sequence Understanding in Multi-Modal Large Language Models}, |
|
author={Jiabo Ye and Haiyang Xu and Haowei Liu and Anwen Hu and Ming Yan and Qi Qian and Ji Zhang and Fei Huang and Jingren Zhou}, |
|
year={2024}, |
|
eprint={2408.04840}, |
|
archivePrefix={arXiv}, |
|
primaryClass={cs.CV}, |
|
url={https://arxiv.org/abs/2408.04840}, |
|
} |
|
``` |
|
|