--- language: - en - ko license: cc-by-nc-4.0 tags: - multimodal - conversational - ncsoft - varco base_model: - Qwen/Qwen2.5-14B-Instruct - google/siglip-so400m-patch14-384 library_name: transformers --- # VARCO-VISION-14B ## About the Model **VARCO-VISION-14B** is a powerful English-Korean Vision-Language Model (VLM) developed through four distinct training phases, culminating in a final preference optimization stage. Designed to excel in both multimodal and text-only tasks, VARCO-VISION-14B not only surpasses other models of similar size in performance but also achieves scores comparable to those of proprietary models. The model currently accepts a single image and accompanying text as input, generating text as output. It supports grounding—the ability to identify the locations of objects within an image—as well as OCR (Optical Character Recognition) to recognize text within images. - **Developed by:** NC Research, Multimodal Generation Team - **Technical Report:** [Coming Soon]() - **Languages:** Korean, English - **License:** CC BY-NC 4.0 - **Architecture:** VARCO-VISION-14B follows the architecture of [LLaVA-OneVision](https://arxiv.org/abs/2408.03326). - **Base Model:** - **Language Model:** [Qwen/Qwen2.5-14B-Instruct](https://huggingface.co/Qwen/Qwen2.5-14B-Instruct) - **Vision Encoder:** [google/siglip-so400m-patch14-384](https://huggingface.co/google/siglip-so400m-patch14-384) ## Uses ### Direct Use To load VARCO-VISION-14B, start by cloning and installing **LLaVA-NeXT**: ```bash git clone https://github.com/LLaVA-VL/LLaVA-NeXT cd LLaVA-NeXT pip install -e ".[train]" ``` After installing **LLaVA-NeXT**, you can load VARCO-VISION-14B using the following code: ```python import torch from transformers import AutoTokenizer from llava.model.language_model.llava_qwen import LlavaQwenForCausalLM from llava.mm_utils import tokenizer_image_token, process_images model_name = "NCSOFT/VARCO-VISION-14B" tokenizer = AutoTokenizer.from_pretrained(model_name) model = LlavaQwenForCausalLM.from_pretrained( model_name, torch_dtype=torch.float16, attn_implementation="flash_attention_2", low_cpu_mem_usage=True, device_map="auto" ) vision_tower = model.get_vision_tower() image_processor = vision_tower.image_processor ``` Prepare the image and text input by preprocessing the image and tokenizing the text. Pass the processed inputs to the model to generate predictions. ```python import requests from PIL import Image # Define a chat history and use `apply_chat_template` to get correctly formatted prompt # Each value in "content" has to be a list of dicts with types ("text", "image") conversation = [ { "role": "user", "content": [ {"type": "text", "text": "Describe this image."}, {"type": "image"}, ], }, ] prompt = tokenizer.apply_chat_template(conversation, add_generation_prompt=True, tokenize=False) IMAGE_TOKEN_INDEX = -200 EOS_TOKEN = "<|im_end|>" input_ids = tokenizer_image_token(prompt, tokenizer, IMAGE_TOKEN_INDEX, return_tensors="pt") input_ids = input_ids.unsqueeze(0).to(model.device) image_url = "http://images.cocodataset.org/val2017/000000039769.jpg" raw_image = Image.open(requests.get(image_url, stream=True).raw) image_tensors = process_images([raw_image], image_processor, model.config) image_tensors = [image_tensor.half().to(model.device) for image_tensor in image_tensors] image_sizes = [raw_image.size] with torch.inference_mode(): output_ids = model.generate( input_ids, images=image_tensors, image_sizes=image_sizes, do_sample=False, max_new_tokens=1024, use_cache=True, ) outputs = tokenizer.batch_decode(output_ids)[0] if outputs.endswith(EOS_TOKEN): outputs = outputs[: -len(EOS_TOKEN)] outputs = outputs.strip() print(outputs) ``` ### Specialized Features To receive questions or answers based on bounding boxes (e.g., grounding, referring, OCR tasks), include special tokens in the input text. The following special tokens are used to define specific tasks, inputs and outputs for the model: - ``: Indicates that the model's response should include bounding box information. - ``: Specifies OCR tasks for recognizing text within an image. - `` and ``: Used to mark a text phrase. - `` and ``: Used to indicate an object. - `` and ``: Used to represent a bounding box. - ``: Represents multiple location points for a single object or text. #### Grounding Grounding refers to the task where the model identifies specific locations within an image to provide an answer. To perform grounding, prepend the special token `` to the question. ```python conversation = [ { "role": "user", "content": [ {"type": "text", "text": "\nDescribe the image in detail."}, {"type": "image"}, ], }, ] ``` **Expected Output Example:** ```html The image shows two cats0.521, 0.049, 0.997, 0.7830.016, 0.108, 0.512, 0.99 lying on a pink blanket0.002, 0.231, 0.999, 0.999. The cat on the left is lying on its side with its head resting on the blanket and its body stretched out. The cat on the right is lying on its back with its paws stretched out and its head turned to the side. Both cats appear relaxed and comfortable. There are also two remote controls0.039, 0.138, 0.283, 0.2570.508, 0.166, 0.581, 0.295 placed near the cats, one on each side of them. ``` Grounding Example #### Referring VARCO-VISION-14B can handle location-specific questions using bounding boxes. To perform referring tasks, structure the conversation by including the object of interest within `` and `` tags and specifying its location with `` and `` tags. This allows the model to understand the context and focus on the object at the specified location. ```python conversation = [ { "role": "user", "content": [ { "type": "text", "text": "이 물건0.039, 0.138, 0.283, 0.257은 어떻게 쓰는거야?", }, {"type": "image"}, ], }, ] ``` **Expected Output Example:** ``` **이 물건**은 리모컨으로, 주로 텔레비전이나 다른 전자 기기를 원격으로 조작하는 데 사용됩니다. 버튼을 누르면 채널 변경, 볼륨 조절, 전원 켜기/끄기 등의 기능을 수행할 수 있습니다. 리모컨의 버튼에는 일반적으로 숫자, 메뉴, 설정, 재생/일시정지 등의 기능이 포함되어 있으며, 사용자는 이를 통해 손쉽게 기기를 제어할 수 있습니다. ``` #### OCR To perform Optical Character Recognition (OCR), use the `` token. ```python image_file = "./assets/ocr_1.png" conversation = [ { "role": "user", "content": [ {"type": "text", "text": ""}, {"type": "image"}, ], }, ] ``` **Expected Output Example:** ``` 백범로0.172, 0.265, 0.328, 0.34 124번길0.349, 0.265, 0.512, 0.34 Baekbeom-ro0.171, 0.335, 0.432, 0.391 1240.444, 0.34, 0.508, 0.391 만수주공아파트0.109, 0.528, 0.335, 0.594 시흥0.443, 0.516, 0.522, 0.578 시청0.711, 0.521, 0.811, 0.594 Mansu0.103, 0.601, 0.181, 0.647 Jugong0.186, 0.601, 0.273, 0.658 Apt0.281, 0.601, 0.327, 0.651 420.377, 0.601, 0.416, 0.647 Shieung0.445, 0.578, 0.53, 0.623 인천대공원0.431, 0.623, 0.609, 0.684 모래내시장역0.651, 0.591, 0.873, 0.664 IncheonGrand0.433, 0.684, 0.561, 0.723 Park0.564, 0.684, 0.611, 0.723 ``` OCR Example ## Citing the Model (*bibtex will be updated soon..*) If you use VARCO-VISION-14B in your research, please cite the following: ```bibtex ```