Skip to content

Latest commit

 

History

History
148 lines (93 loc) · 5.36 KB

README.md

File metadata and controls

148 lines (93 loc) · 5.36 KB

🤔🎞️ Video-of-Thought: Step-by-Step Video Reasoning from Perception to Cognition

ICML (Oral) 2024

Hao Fei, Shengqiong Wu, Wei Ji, Hanwang Zhang, Meishan Zhang, Mong Li Lee, and Wynne Hsu

YouTube License pytorch 1.8.1

This repository contains the code of ICML 2024 paper Video-of-Thought.

🎉 Visit the project page: VoT


Abstract

Existing research of video understanding still struggles to achieve in-depth comprehension and reasoning in complex videos, primarily due to the under-exploration of two key bottlenecks: fine-grained spatial-temporal perceptive understanding and cognitive-level video scene comprehension. This paper bridges the gap by presenting a novel solution. We first introduce a novel video Multimodal Large Language Model (MLLM), MotionEpic, which achieves fine-grained pixel-level spatial-temporal video grounding by integrating video spatial-temporal scene graph (STSG) representation. Building upon MotionEpic, we then develop a Video-ofThought (VoT) reasoning framework. VoT inherits the Chain-of-Thought (CoT) core, breaking down a complex task into simpler and manageable sub-problems, and addressing them step-bystep from a low-level pixel perception to highlevel cognitive interpretation. Extensive experiments across various complex video QA benchmarks demonstrate that our overall framework strikingly boosts existing state-of-the-art.

framework

Overview

The first video Chain-of-Thought reasoning framework, VoT, which decomposes raw complex problems into a chain of sub-problems, and reasons through multiple steps from low to high levels, enabling not only pixel perceptive recognition but also semantic cognitive understanding of videos.

We also introduce a novel video MLLM, namely MotionEpic, which supports not only video input but also the encoding, understanding and generation of STSGs.

Method

  • MotionEpic: Fine-grained Spatial-temporal Grounded Video MLLM

    • employ the Vicuna-7B (v1.5) as the backbone LLM. To perceive video input,
    • adopt the ViT-L/14 encoder and Q-Former projector.
    • design MotionEpic to support the STSG signal, where we retrofit the Graph Transformer with recurrent propagation to encode the multi-frame STSG information
  • Video-of-Thought Reasoning Framework

    • Step-1: Task Definition and Target Identification
    • Step-2: Object Tracking
    • Step-3: Action Analyzing
    • Step-4: Question Answering via Ranking
    • Step-5: Answer Verification

Installation

Please first clone the repo and install the required environment, which can be done by running the following commands:

conda env create -n motionepic python=3.8

conda activate motionepic

#### CUDA 12.1
conda install pytorch==2.1.2 torchvision==0.14.1 torchaudio==0.13.1 pytorch-cuda=11.6 -c pytorch -c nvidia

git clone https://github.com/scofield7419/Video-of-Thought.git
cd Video-of-Thought

pip install -r requirements.txt

Training

Firstly, you need to prepare the dataset, including Action Geome, webvid, MSR-VTT, and ActivityNet. Then, you need to modify the parameter, DATASET_NAME_LIST to determine the dataset used for training and fine-tuning. Next, run the command for training and fine-tuning:

#### for alignment learning
bash pretrain.sh

#### for finetuning.
bash fine-tune.sh

Inference

We implement CoT-based inference (i.e., VoT), please refer to the predict.py for details. Run the command to obtain the results:

python predict.py

Citation

If you use this work, please kindly cite:

@inproceedings{0001W0ZZLH24,
  author       = {Hao Fei, Shengqiong Wu, Wei Ji, Hanwang Zhang, Meishan Zhang, Mong-Li Lee, Wynne Hsu},
  title        = {Video-of-Thought: Step-by-Step Video Reasoning from Perception to
                  Cognition},
  booktitle    = {Proceeding of the ICML},
  year         = {2024}
} 

Acknowledgement

Our code is based on the respective official repositories, NExT-GPT, and graphtransformer. We fully thank the authors to release their code.

License

The code is released under Apache License 2.0 for Noncommercial use only.

Contact

For any questions, feel free to contact Hao Fei.