Skip to content

🧘🏻‍♂️KarmaVLM (相生):A family of high efficiency and powerful visual language model.

License

Notifications You must be signed in to change notification settings

thomas-yanxin/KarmaVLM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

45 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🧘🏻‍♂️ KarmaVLM (相生)

github HuggingFace modelscope OpenI WiseModel

GitHub license GitHub Stars GitHub Forks GitHub Contributors

👏 Introduction

KarmaVLM is a family of high-efficiency and powerful visual language models (VLM) pre-trained with interleaved image-text data at scale, enabling content comprehension, recognition, and multi-round conversations about images.

🎉 News

  • [2024/02] KarmaVLM is released.

⚡️Features

KarmaVLM offers the following features:

  • High Efficiency: KarmaVLM focuses on exploring the capabilities of small parametric quantitative models on multimodal tasks. So, KarmaVLM can be efficiently deployed on most GPU cards and personal computers, and even on end devices such as mobile phones.

  • Multi-round text-image conversations: KarmaVLM can take both text and images as inputs and produce text outputs. Currently, it supports multi-round visual question answering with one image.

  • Strong image comprehension: KarmaVLM is adept at analyzing visuals, making it an efficient tool for tasks like extracting, organizing, and summarizing information from images.

🔥Model Zoo

Name Download Language Vision Encoder LLM MMBench LLaVA-Bench-Wild ScienceQA TextVQA
KarmaVLM-Qwen1.5-0_5B 🤗 / 🤖 / ✡️ EN openai/clip-vit-large-patch14-336 Qwen/Qwen1.5-0.5B 53.5 40.4 43.22 36.1
KarmaVLM-Qwen1.5-0_5B_Siglip 🤗 / 🤖 / ✡️ EN google/siglip-so400m-patch14-384 Qwen/Qwen1.5-0.5B 54.6 47.5 53.81 44.98
KarmaVLM-Qwen1.5-4B_Siglip 🤗 / 🤖 / ✡️ EN google/siglip-so400m-patch14-384 Qwen/Qwen1.5-4B 62.3 50.4 74.98 49.99
KarmaVLM-Qwen1.5-7B 🤗 / 🤖 / ✡️ EN/CN openai/clip-vit-large-patch14-336 Qwen/Qwen1.5-7B 69.9 57.9 76.59 56.32
KarmaVLM-Qwen1.5-0_5B_Siglip_moe 🤗 / 🤖 / ✡️ EN google/siglip-so400m-patch14-384 Qwen/Qwen1.5-0.5B 55.8 47.5 53.86 45.25

Basically, we have achieved SOTA among models of the same parameter order of magnitude, even beyond some models with larger parameters. More Benchmark evaluations are in progress!

👨‍💻 Quick Start

Requirements and Installation

  git clone https://github.com/X-D-Lab/KarmaVLM.git
  cd KarmaVLM

  conda create -n karmavlm python=3.10 -y
  conda activate karmavlm

  pip install --upgrade pip  # enable PEP 660 support
  pip install modelscope
  pip install -e .
  pip install -e ".[train]"
  pip install flash-attn --no-build-isolation

you can download model:X-D-Lab/KarmaVLM-Qwen1.5-0_5B, and vision tower:openai/clip-vit-large-patch14 by run download.py

python download.py

You need to change the path in the download.py to your path, also, you need to change the path of the vision tower in the config.json to your local vision tower path.

  from modelscope import snapshot_download

  model_dir = snapshot_download('X-D-Lab/KarmaVLM-Qwen1.5-0_5B',cache_dir="your_path/KarmaVLM-Qwen1.5-0_5B/")   #where you need change
  model_dir = snapshot_download('thomas/clip-vit-large-patch14',cache_dir="your_path/clip-vit-large-patch14/")  #where you need change

🌏 Demo

  1. CLI Inference
    python -m llava.serve.cli \
        --model-path /path/to/karmavlm/model \
        --image-file /path/to/the/test/image
    
  2. Gradio Web UI
  • Starting the Controller
    python -m llava.serve.gradio_web_server \
        --controller http://localhost:10000 \
        --model-list-mode reload
        --share ##(optional)
    
  • Launching the Gradio Web Server
    python -m llava.serve.model_worker \
        --host 0.0.0.0 \
        --controller http://localhost:10000 \
        --port 40000 \
        --worker http://localhost:40000 \
        --model-path /path/to/karmavlm/model 
    

📋 License

This project utilizes certain datasets and checkpoints that are subject to their respective original licenses. Users must comply with all terms and conditions of these original licenses. The content of this project itself is licensed under the Apache license 2.0.

🙇‍ Architecture

We build our project based on LLaVA: Large Language and Vision Assistant.

💪 Contributors

🙏 Acknowledgement

@misc{liu2023llava,
      title={Visual Instruction Tuning}, 
      author={Liu, Haotian and Li, Chunyuan and Wu, Qingyang and Lee, Yong Jae},
      publisher={NeurIPS},
      year={2023},
}

@article{qwen,
  title={Qwen Technical Report},
  author={Jinze Bai and Shuai Bai and Yunfei Chu and Zeyu Cui and Kai Dang and Xiaodong Deng and Yang Fan and Wenbin Ge and Yu Han and Fei Huang and Binyuan Hui and Luo Ji and Mei Li and Junyang Lin and Runji Lin and Dayiheng Liu and Gao Liu and Chengqiang Lu and Keming Lu and Jianxin Ma and Rui Men and Xingzhang Ren and Xuancheng Ren and Chuanqi Tan and Sinan Tan and Jianhong Tu and Peng Wang and Shijie Wang and Wei Wang and Shengguang Wu and Benfeng Xu and Jin Xu and An Yang and Hao Yang and Jian Yang and Shusheng Yang and Yang Yao and Bowen Yu and Hongyi Yuan and Zheng Yuan and Jianwei Zhang and Xingxuan Zhang and Yichang Zhang and Zhenru Zhang and Chang Zhou and Jingren Zhou and Xiaohuan Zhou and Tianhang Zhu},
  journal={arXiv preprint arXiv:2309.16609},
  year={2023}
}

@misc{2023internlm,
    title={InternLM: A Multilingual Language Model with Progressively Enhanced Capabilities},
    author={InternLM Team},
    howpublished = {\url{https://github.com/InternLM/InternLM-techreport}},
    year={2023}
}

🌟 Star History

Star History Chart