license: apache-2.0
language:
- en
metrics:
- accuracy
pipeline_tag: text-generation
tags:
- meta
- '3.1'
- autoawq
- awq
- text-generation-inference
- llama-3.1-instruct
- llama-3.1
- 8B
- '32'
- group-size
- 2.17B
- instruct
Quantized Model
This is the quantizied version of the INSTRUCT model of LLama-3.1-8B using AutoAWQ with a group size of 32. This model contains 2.17B parameters as opposed to the 1.98B parameters in the 128 group size version of this qunatization. The additional parameters results in a more accurate model at the cost of slighlty more VRAM usage.
Model Information
The Meta Llama 3.1 collection of multilingual large language models (LLMs) is a collection of pretrained and instruction tuned generative models in 8B, 70B and 405B sizes (text in/text out). The Llama 3.1 instruction tuned text only models (8B, 70B, 405B) are optimized for multilingual dialogue use cases and outperform many of the available open source and closed chat models on common industry benchmarks.
Usage Requirements
The model inference requires at least 8GB of VRAM to load the model checkpoint. This model has been tested to run on a T4 GPU but can be run on a less powerful machine if needed.
Running The Model
Please be sure to install the following packages before running the sample code.
pip install -q --upgrade transformers accelerate
pip install autoawq
Below is an example of how this model can be run. Simply replace the 'prompt' with an input of your choosing and adjust the maximum token size as needed.
import torch
from transformers import AutoTokenizer, AwqConfig, AutoModelForCausalLM, pipeline
from huggingface_hub import login
#This code below is if you are using a hugging face token on google colab.
from google.colab import userdata
my_token = userdata.get("HF_TOKEN")
login(my_token)
model_name = "UCLA-EMC/Meta-Llama-3.1-8B-AWQ-INT4"
quantization_config = AwqConfig(
bits=4,
fuse_max_seq_len=512, # Note: Update this as per your use-case
do_fuse=True,
)
tokenizer = AutoTokenizer.from_pretrained(model_id)
model = AutoModelForCausalLM.from_pretrained(
model_name,
torch_dtype=torch.float16,
low_cpu_mem_usage=True,
device_map="auto",
quantization_config=quantization_config
)
tokenizer = AutoTokenizer.from_pretrained(model_id)
model = AutoModelForCausalLM.from_pretrained(
model_name,
torch_dtype=torch.float16,
low_cpu_mem_usage=True,
device_map="auto",
quantization_config=quantization_config
)
text_generator = pipeline(
'text-generation',
model = model,
tokenizer = tokenizer,
max_new_tokens=456,
)
def get_response(prompt):
response = text_generator(prompt)
gen_text = response[0]['generated_text']
return gen_text
prompt = "generate python code to make a bar graph"
llama_response = get_response(prompt)
print(llama_response)
Final Statements
I hope this model proves useful to you in your projects. Good luck and happy coding!
Acknowledgements
The example above uses code from the following sources:
- hugging-quants/Meta-Llama-3.1-405B-Instruct-AWQ-INT4
- Author: hugging-quants
- Source: https://huggingface.co/hugging-quants/Meta-Llama-3.1-405B-Instruct-AWQ-INT4
- License: Llama 3.1 Community License Agreement