Inference on CPU code for LLaMA models
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
randaller 770ac1aabc
Update README.md
3 years ago
llama run on cpu 3 years ago
model Create .gitkeep 3 years ago
tokenizer Create .gitkeep 3 years ago
.gitignore Initial commit 3 years ago
CODE_OF_CONDUCT.md Initial commit 3 years ago
CONTRIBUTING.md Initial commit 3 years ago
FAQ.md Add FAQ.md // add command line options 3 years ago
LICENSE Initial commit 3 years ago
MODEL_CARD.md Fix typos in MODEL_CARD.md 3 years ago
README.md Update README.md 3 years ago
example-chat.py Create example-chat.py 3 years ago
example-cpu.py Update example-cpu.py 3 years ago
merge-weights.py Update merge-weights.py 3 years ago
requirements.txt Update requirements.txt 3 years ago
setup.py Initial commit 3 years ago

README.md

Inference LLaMA models using CPU only

This repository is intended as a minimal, hackable and readable example to load LLaMA (arXiv) models and run inference by using only CPU. Thus requires no videocard, but 64 (better 128 Gb) of RAM and modern processor is required.

Conda Environment Setup Example for Windows 10+

Download and install Anaconda Python https://www.anaconda.com and run Anaconda Prompt

conda create -n llama python=3.10
conda activate llama
conda install pytorch torchvision torchaudio pytorch-cuda=11.7 -c pytorch -c nvidia

Setup

In a conda env with pytorch / cuda available, run

pip install -r requirements.txt

Then in this repository

pip install -e .

Download tokenizer and models

magnet:?xt=urn:btih:ZXXDAUWYLRUXXBHUYEMS6Q5CE5WA3LVA&dn=LLaMA

CPU Inference of 7B model

Place tokenizer.model file from torrent into repo's [/tokenizer] folder.

Place consolidated.00.pth and params.json from 7B torrent folder into repo's [/model] folder.

Run the example:

python example-cpu.py

CPU Inference of 13B, 30B and 65B models

A little bit tricky part is that we need to unshard the checkpoints first. In this example, D:\Downloads\LLaMA is a root folder of downloaded torrent with models. Run the following command to create merged weights checkpoint:

python merge-weights.py --input_dir D:\Downloads\LLaMA --model_size 13B

This will create merged.pth file in the repo's root folder. Move this file into [/model] folder.

Place corresponding params.json file (from 13B torrent folder) into repo's [/model] folder.

So, you should end up with two files in [/model] folder: merged.pth and params.json.

Place tokenizer.model file from torrent into repo's [/tokenizer] folder.

Run the example:

python example-cpu.py

Interactive chat with LLaMA

python example-chat.py

Some measurements

Running model with single prompt on Windows computer equipped with 12700k, fast nvme and 128 Gb of RAM.

model RAM usage, fp32 RAM usage, bf16 fp32 inference bf16 inference
7B 44 Gb, peak 56 Gb 22 Gb 170 seconds 850 seconds
13B 77 Gb, peak 100 Gb 38 Gb 340 seconds

RAM usage optimization

By default, torch uses Float32 precision while running on CPU, which leads, for example, to use 44 GB of RAM for 7B model. We may use Bfloat16 precision on CPU too, which decreases RAM consumption/2, down to 22 GB for 7B model, but inference processing much slower.

Uncomment this line in the example-cpu.py to enable Bfloat16 and save memory.

torch.set_default_dtype(torch.bfloat16)

Model Card

See MODEL_CARD.md

License

See the LICENSE file.