cicdatopea's picture
Update README.md
0dc7dee verified
metadata
datasets:
  - NeelNanda/pile-10k
base_model:
  - fancyfeast/llama-joycaption-alpha-two-hf-llava

Model Details

This model is an int4 model with group_size 128 and symmetric quantization of fancyfeast/llama-joycaption-alpha-two-hf-llava generated by intel/auto-round. Load the model with revision="bc917a8" to use AutoGPTQ format.

How To Use

Requirements

Please see the Github for more details.

INT4 Inference

from auto_round import AutoRoundConfig ## must import for auto-round format
import requests
import torch
from PIL import Image
from transformers import AutoProcessor, LlavaForConditionalGeneration


quantized_model_path="OPEA/llama-joycaption-alpha-two-hf-llava-int4-sym-inc"

# Load JoyCaption INT4 Model
processor = AutoProcessor.from_pretrained(quantized_model_path)
model = LlavaForConditionalGeneration.from_pretrained(
    quantized_model_path,
    device_map="auto",
    revision="bc917a8" ## ##AutoGPTQ format
)
model.eval()

image_url = "http://images.cocodataset.org/train2017/000000116003.jpg"
content = "Write a descriptive caption for this image in a formal tone."

# Preparation for inference
with torch.no_grad():
    image = Image.open(requests.get(image_url, stream=True).raw)
    messages = [
        {
            "role": "system",
            "content": "You are a helpful image captioner.",
        },
        {
            "role": "user",
            "content": content,
        },
    ]
    prompt = processor.apply_chat_template(messages, tokenize = False, add_generation_prompt = True)
    assert isinstance(prompt, str)
    inputs = processor(text=[prompt], images=[image], return_tensors="pt").to(model.device)
    inputs['pixel_values'] = inputs['pixel_values'].to(model.dtype)
    
    # Generate the captions
    generate_ids = model.generate(
        **inputs,
        max_new_tokens=50,
        do_sample=False,
        suppress_tokens=None,
        use_cache=True,
        temperature=0.6,
        top_k=None,
        top_p=0.9,
    )[0]
    
    # Trim off the prompt
    generate_ids = generate_ids[inputs['input_ids'].shape[1]:]
    
    # Decode the caption
    caption = processor.tokenizer.decode(generate_ids, skip_special_tokens=True, clean_up_tokenization_spaces=False)
    caption = caption.strip()
    print(caption)


##INT4: This black-and-white photograph captures a moment of triumph on a tennis court. The central figure is a male tennis player, mid-celebration,
## with his arms raised high in victory. He is wearing a white athletic shirt and shorts, with a


##BF16: This black-and-white photograph captures a moment of triumph on a tennis court. The central figure is a male tennis player, mid-celebration,
## with his arms raised high in victory. He is wearing a white tennis shirt and shorts, with a

image_url = "http://images.cocodataset.org/train2017/000000411975.jpg"
content = "Write a descriptive caption for this image in a formal tone."

##INT4: This is a photograph capturing a moment during a baseball game. The image is taken from a high vantage point, likely from the stands,
## looking down onto the field. The main focus is on a young girl and a man standing on the grassy

##BF16: This is a photograph capturing a moment during a baseball game. The image is taken from a high angle, looking down onto the field.
## In the foreground, there is a section of the baseball field with a reddish-brown dirt infield and a well


image_url = "http://images.cocodataset.org/train2017/000000093025.jpg"
content = "Write a descriptive caption for this image in a formal tone."

##INT4: This is a photograph capturing a serene outdoor scene on a rocky mountainous terrain under a clear blue sky with scattered white clouds.
## The central focus is on a man and a sheep. The man, positioned slightly to the right of the center, is sitting

##BF16: This photograph captures a serene mountainous landscape under a bright blue sky dotted with fluffy white clouds. In the foreground,
## a man and a woman are seated on a rocky outcrop. The man, positioned on the left, is wearing a blue jacket and

Generate the model

Here is the sample command to reproduce the model.

pip install auto-round
auto-round-mllm \
--model  \
--device 0 \
--group_size 128 \
--bits 4 \
--iters 1000 \
--nsample 512 \
--seqlen 2048 \
--template default \
--model_dtype "float16" \
--format 'auto_gptq,auto_round' \
--output_dir "./tmp_autoround"

Ethical Considerations and Limitations

The model can produce factually incorrect output, and should not be relied on to produce factually accurate information. Because of the limitations of the pretrained model and the finetuning datasets, it is possible that this model could generate lewd, biased or otherwise offensive outputs.

Therefore, before deploying any applications of the model, developers should perform safety testing.

Caveats and Recommendations

Users (both direct and downstream) should be made aware of the risks, biases and limitations of the model.

Here are a couple of useful links to learn more about Intel's AI software:

  • Intel Neural Compressor link

Disclaimer

The license on this model does not constitute legal advice. We are not responsible for the actions of third parties who use this model. Please consult an attorney before using this model for commercial purposes.

Cite

@article{cheng2023optimize, title={Optimize weight rounding via signed gradient descent for the quantization of llms}, author={Cheng, Wenhua and Zhang, Weiwei and Shen, Haihao and Cai, Yiyang and He, Xin and Lv, Kaokao and Liu, Yi}, journal={arXiv preprint arXiv:2309.05516}, year={2023} }

arxiv github