Run a fast ChatGPT-like model locally on your device. The screencast below is not sped up and running on an M2 Macbook Air with 4GB of weights.
This combines the LLaMA foundation model with an KoAlpaca a fine-tuning of the base model to obey instructions (akin to the RLHF used to train ChatGPT) and a set of modifications to llama.cpp to add a chat interface.
# 1. Install required packages:
# Check if Python 3 is installed:
python3 --version
# Install Python 3 if not installed:
# Ubuntu:
sudo apt update && sudo apt install python3 python3-pip python3-venv
# macOS:
brew install python
# Install required Python packages:
pip3 install torch transformers onnx
# 2. Clone the repository and change into the repository directory:
git clone https://github.com/gyunggyung/KoAlpaca.cpp
cd KoAlpaca.cpp
# 3. Save the provided Python script in a previous response as convert_to_onnx.py. Replace your-model-name with the name of your model.
# 4. Run the script to convert the model to ONNX format:
python3 convert_to_onnx.py
# 5. Test the ONNX model using the provided Python script: python3 test_onnx.py
# This should output the input text and the predicted token.
# 6. Install ONNX Runtime:
pip3 install onnxruntime
# 7. Compile the C++ code:
g++ main.cpp -o main -lonnxruntime
./main
You can download the weights for ggml-alpaca-7b-q4.bin
with BitTorrent magnet:?xt=urn:btih:5aaceaec63b03e51a98f04fd5c42320b2a033010&dn=ggml-alpaca-7b-q4.bin&tr=udp%3A%2F%2Ftracker.opentrackr.org%3A1337%2Fannounce&tr=udp%3A%2F%2Fopentracker.i2p.rocks%3A6969%2Fannounce
Alternatively you can download them with IPFS.
# any of these will work
wget -O ggml-alpaca-7b-q4.bin -c https://gateway.estuary.tech/gw/ipfs/QmQ1bf2BTnYxq73MFJWu1B7bQ2UD6qG7D7YDCxhTndVkPC
wget -O ggml-alpaca-7b-q4.bin -c https://ipfs.io/ipfs/QmQ1bf2BTnYxq73MFJWu1B7bQ2UD6qG7D7YDCxhTndVkPC
wget -O ggml-alpaca-7b-q4.bin -c https://cloudflare-ipfs.com/ipfs/QmQ1bf2BTnYxq73MFJWu1B7bQ2UD6qG7D7YDCxhTndVkPC
Save the ggml-alpaca-7b-q4.bin
file in the same directory as your ./chat
executable.
The weights are based on the published fine-tunes from alpaca-lora
, converted back into a pytorch checkpoint with a modified script and then quantized with llama.cpp the regular way.
To chat with the KoAlpaca model using the provided Python script, simply follow these steps:
- Install Python 3 and the necessary dependencies (Hugging Face Transformers and PyTorch libraries).
- Save the koalpaca.py script in a directory of your choice.
- Open a terminal or command prompt and navigate to the directory containing the script.
- Run the script by entering python3 koalpaca.py.
- Type your input message and press Enter to see the model's generated response.
- Continue chatting by entering more messages, and type 'quit' when you wish to exit the chat.
git clone https://github.com/gyunggyung/KoAlpaca.cpp
cd KoAlpaca.cpp
pip3 install --user transformers
pip3 install --user torch
python3 koalpaca.py
git clone https://github.com/gyunggyung/KoAlpaca.cpp
cd /Users/YourUsername/koalpaca
pip3 install --user transformers
pip3 install --user torch
python3 koalpaca.py
git clone https://github.com/gyunggyung/KoAlpaca.cpp
cd C:\koalpaca
pip install transformers
pip install torch
python koalpaca.py
git clone https://github.com/gyunggyung/KoAlpaca.cpp
cd KoAlpaca.cpp
g++ -o koalpaca koalpaca.cpp -I/path/to/transformers/include -L/path/to/transformers/lib -ltransformers -lonnx -ltorch -lc10
./koalpaca
make chat
./chat
KoAlpaca used two models as backbone models.
- based on Polyglot-ko 5.8B -> https://huggingface.co/beomi/KoAlpaca-Polyglot
- based on Meta LLAMA 7B -> https://huggingface.co/beomi/KoAlpaca
Meta's LLAMA model does not train enough Korean datasets, so there is an issue with low Korean performance when running the actual inference.
To get better quality for Korean, we trained two models using Polyglot-ko 5.8B as a backbone.
First of all, I am very grateful to KoAlpaca: Korean Alpaca Model based on Stanford Alpaca (feat. LLAMA and Polyglot-ko). Most of all, thank you @Beomi for giving me the best choice to make a Korean model.
This combines Facebook's LLaMA, Stanford Alpaca, alpaca-lora and corresponding weights by Eric Wang (which uses Jason Phang's implementation of LLaMA on top of Hugging Face Transformers), and llama.cpp by Georgi Gerganov. The chat implementation is based on Matvey Soloviev's Interactive Mode for llama.cpp. Inspired by Simon Willison's getting started guide for LLaMA.
Note that the model weights are only to be used for research purposes, as they are derivative of LLaMA, and uses the published instruction data from the Stanford Alpaca project which is generated by OpenAI, which itself disallows the usage of its outputs to train competing models.