abetlen / llama-cpp-python
- вторник, 11 апреля 2023 г. в 00:13:56
Python bindings for llama.cpp
llama.cppSimple Python bindings for @ggerganov's llama.cpp library.
This package provides:
ctypes interface.Install from PyPI:
pip install llama-cpp-python>>> from llama_cpp import Llama
>>> llm = Llama(model_path="./models/7B/ggml-model.bin")
>>> output = llm("Q: Name the planets in the solar system? A: ", max_tokens=32, stop=["Q:", "\n"], echo=True)
>>> print(output)
{
"id": "cmpl-xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
"object": "text_completion",
"created": 1679561337,
"model": "./models/7B/ggml-model.bin",
"choices": [
{
"text": "Q: Name the planets in the solar system? A: Mercury, Venus, Earth, Mars, Jupiter, Saturn, Uranus, Neptune and Pluto.",
"index": 0,
"logprobs": None,
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 14,
"completion_tokens": 28,
"total_tokens": 42
}
}llama-cpp-python offers a web server which aims to act as a drop-in replacement for the OpenAI API.
This allows you to use llama.cpp compatible models with any OpenAI compatible client (language libraries, services, etc).
To install the server package and get started:
pip install llama-cpp-python[server]
export MODEL=./models/7B/ggml-model.bin
python3 -m llama_cpp.serverNavigate to http://localhost:8000/docs to see the OpenAPI documentation.
The low-level API is a direct ctypes binding to the C API provided by llama.cpp.
The entire API can be found in llama_cpp/llama_cpp.py and should mirror llama.h.
Documentation is available at https://abetlen.github.io/llama-cpp-python. If you find any issues with the documentation, please open an issue or submit a PR.
This package is under active development and I welcome any contributions.
To get started, clone the repository and install the package in development mode:
git clone git@github.com:abetlen/llama-cpp-python.git
git submodule update --init --recursive
# Will need to be re-run any time vendor/llama.cpp is updated
python3 setup.py developllama.cpp?I originally wrote this package for my own use with two goals in mind:
llama.cpp and access the full C API in llama.h from Pythonllama.cppAny contributions and changes to this package will be made with these goals in mind.
This project is licensed under the terms of the MIT license.