lucataco / moondream2

moondream2 is a small vision language model designed to run efficiently on edge devices

  • Public
  • 22.7K runs
  • GitHub
  • License

Input

Output

Run time and cost

This model runs on Nvidia A40 GPU hardware. Predictions typically complete within 4 seconds.

Readme

Moondream2

moondream2 is a small vision language model designed to run efficiently on edge devices. Check out the GitHub repository for details, or try it out on the Hugging Face Space!

Benchmarks

Release VQAv2 GQA TextVQA TallyQA (simple) TallyQA (full)
2024-03-04 74.2 58.5 36.4 - -
2024-03-06 75.4 59.8 43.1 79.5 73.2
2024-03-13 (latest) 76.8 60.6 46.4 79.6 73.3

Usage

pip install transformers timm einops
from transformers import AutoModelForCausalLM, AutoTokenizer
from PIL import Image

model_id = "vikhyatk/moondream2"
revision = "2024-03-06"
model = AutoModelForCausalLM.from_pretrained(
    model_id, trust_remote_code=True, revision=revision
)
tokenizer = AutoTokenizer.from_pretrained(model_id, revision=revision)

image = Image.open('<IMAGE_PATH>')
enc_image = model.encode_image(image)
print(model.answer_question(enc_image, "Describe this image.", tokenizer))

The model is updated regularly, so we recommend pinning the model version to a specific release as shown above.