This example demonstrates how to run IPEX-LLM optimized low-bit model vertically partitioned on multiple Intel GPUs for Linux users.
To run this example with IPEX-LLM on Intel GPUs, we have some recommended requirements for your machine, please refer to here for more information. For this particular example, you will need at least two GPUs on your machine.
- meta-llama/Llama-2-7b-chat-hf
- meta-llama/Llama-2-13b-chat-hf
- meta-llama/Meta-Llama-3-8B-Instruct
- Qwen/Qwen2-7B-Instruct
- Qwen/Qwen1.5-7B-Chat
- Qwen/Qwen1.5-14B-Chat
- Qwen/Qwen1.5-32B-Chat
- Qwen/Qwen1.5-MoE-A2.7B-Chat
- Qwen/Qwen-VL-Chat
- Qwen/CodeQwen1.5-7B-Chat
- THUDM/glm-4-9b-chat
- THUDM/glm-4v-9b
- THUDM/chatglm3-6b
- baichuan-inc/Baichuan2-7B-Chat
- baichuan-inc/Baichuan2-13B-Chat
- microsoft/Phi-3-mini-4k-instruct
- microsoft/Phi-3-medium-4k-instruct
- mistralai/Mistral-7B-v0.1
- mistralai/Mixtral-8x7B-Instruct-v0.1
- 01-ai/Yi-6B-Chat
- 01-ai/Yi-34B-Chat
- codellama/CodeLlama-7b-Instruct-hf
- codellama/CodeLlama-13b-Instruct-hf
- codellama/CodeLlama-34b-Instruct-hf
- upstage/SOLAR-10.7B-Instruct-v1.0
- lmsys/vicuna-7b-v1.3
- lmsys/vicuna-13b-v1.3
- lmsys/vicuna-33b-v1.3
Please visit the Install IPEX-LLM on Linux with Intel GPU, follow Install Intel GPU Driver and Install oneAPI to install GPU driver and Intel® oneAPI Base Toolkit 2024.0.
conda create -n llm python=3.11
conda activate llm
# below command will install intel_extension_for_pytorch==2.1.10+xpu as default
pip install --pre --upgrade ipex-llm[xpu] --extra-index-url https://pytorch-extension.intel.com/release-whl/stable/xpu/us/
pip install oneccl_bind_pt==2.1.100 --extra-index-url https://pytorch-extension.intel.com/release-whl/stable/xpu/us/
For optimal performance, it is recommended to set several environment variables. We provide example usages as following:
Note: INT4 optimization is applied to the model by default. You could specify other low bit optimizations (such as 'fp8' and 'fp6') through
--low-bit
.
Show Llama2 and Llama3 example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Llama2 / Llama3 to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_llama_arc_2_card.sh
Show Qwen2 example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Qwen2 to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_qwen2_arc_2_card.sh
Show Qwen1.5 example
Run Qwen1.5-7B-Chat / Qwen1.5-14B-Chat / Qwen1.5-32B-Chat / CodeQwen1.5-7B-Chat on two Intel Arc A770
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Qwen1.5 to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_qwen1.5_arc_2_card.sh
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Qwen1.5-MoE to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.40.0 trl==0.8.1
bash run_qwen1.5_arc_2_card.sh
Show Qwen-VL example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Qwen-VL to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.32.0 tiktoken einops transformers_stream_generator==0.0.4 scipy torchvision pillow tensorboard matplotlib
bash run_qwen_vl_arc_2_card.sh
Show chatglm example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for chatglm to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0 "tiktoken>=0.7.0"
bash run_chatglm_arc_2_card.sh
Show glm-4v example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for glm-4v-9b to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0 tiktoken
bash run_glm_4v_arc_2_card.sh
Show Baichuan2 example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Baichuan2 to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
bash run_baichuan2_arc_2_card.sh
Show Phi3 example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Phi3 to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_phi3_arc_2_card.sh
Show Mistral/Mixtral example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Mistral / Mixtral to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_mistral_arc_2_card.sh
Show Yi example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Yi to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
bash run_yi_arc_2_card.sh
Show Codellama example
Run CodeLlama-7b-Instruct-hf / CodeLlama-13b-Instruct-hf / CodeLlama-34b-Instruct-hf on two Intel Arc A770
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Codellama to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_codellama_arc_2_card.sh
Show Solar example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Solar to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
pip install transformers==4.37.0
bash run_solar_arc_2_card.sh
Show Vicuna example
You could specify --repo-id-or-model-path
in the test script to be the huggingface repo id for Vicuna to be downloaded, or the path to the huggingface checkpoint folder. Besides, you could change NUM_GPUS
to the number of GPUs you have on your machine.
bash run_vicuna_arc_2_card.sh
Inference time: xxxx s
First token cost xxxx s and rest tokens cost average xxxx s
-------------------- Prompt --------------------
Once upon a time, there existed a little girl who liked to have adventures. She wanted to go to places and meet new people, and have fun
-------------------- Output --------------------
Once upon a time, there existed a little girl who liked to have adventures. She wanted to go to places and meet new people, and have fun. She was always asking her parents to take her on trips, but they were always too busy or too tired.
One day, the little girl
-------------------- Input --------------------
Message: [{'image': 'http://farm6.staticflickr.com/5268/5602445367_3504763978_z.jpg'}, {'text': '这是什么?'}]
-------------------- Output --------------------
这是一张图片,展现了一个穿着粉色条纹连衣裙的小女孩,她正拿着一只穿粉色裙子的白色玩具小熊。