Skip to main content

Unofficial python bindings for llm-rs. 🐍❤️🦀

Reason this release was yanked:

invalid import

Project description

llm-rs-python: Python Bindings for Rust's llm Library

Welcome to llm-rs, an unofficial Python interface for the Rust-based llm library, made possible through PyO3. Our package combines the convenience of Python with the performance of Rust to offer an efficient tool for your machine learning projects. 🐍❤️🦀

With llm-rs, you can operate a variety of Large Language Models (LLMs) including LLama and GPT-NeoX directly on your CPU.

For a detailed overview of all the supported architectures, visit the llm project page.

Installation

Simply install it via pip: pip install llm-rs

Usage

Running GGML converted models:

This example shows how a Llama model can be loaded.

from llm_rs import Llama

#load the model
model = Llama("path/to/model.bin")

#generate
print(model.generate("The meaning of life is"))

Running Huggingface Hub Models

llm-rs supports automatic conversion of all supported transformer architectures on the Huggingface Hub.

To run covnersions additional dependencies are needed which can be installed via pip install llm-rs[convert].

The following example shows how a Pythia model can be covnverted, quantized and run.

from llm_rs.convert import AutoConverter
from llm_rs import AutoModel, AutoQuantizer
import sys

#define the model which should be converted and an output folder
export_folder = "path/to/folder" 
base_model = "EleutherAI/pythia-410m"

#convert the model
converted_model = AutoConverter.convert(base_model, export_folder)

#quantize the model (this step is optional)
quantized_model = AutoQuantizer.quantize(converted_model)

#load the quantized model
model = AutoModel.load(quantized_model,verbose=True)

#generate text
def callback(text):
    print(text,end="")
    sys.stdout.flush()

model.generate("The meaning of life is",callback=callback)

Documentation

For in-depth information on customizing the loading and generation processes, refer to our detailed documentation.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

llm_rs-0.2.2.tar.gz (30.2 kB view hashes)

Uploaded Source

Built Distributions

llm_rs-0.2.2-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-pp39-pypy39_pp73-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.5+ i686

llm_rs-0.2.2-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-pp38-pypy38_pp73-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.5+ i686

llm_rs-0.2.2-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-pp37-pypy37_pp73-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded PyPy manylinux: glibc 2.5+ i686

llm_rs-0.2.2-cp311-none-win_amd64.whl (449.7 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

llm_rs-0.2.2-cp311-none-win32.whl (403.8 kB view hashes)

Uploaded CPython 3.11 Windows x86

llm_rs-0.2.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.5+ i686

llm_rs-0.2.2-cp311-cp311-macosx_11_0_arm64.whl (592.9 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

llm_rs-0.2.2-cp311-cp311-macosx_10_7_x86_64.whl (629.9 kB view hashes)

Uploaded CPython 3.11 macOS 10.7+ x86-64

llm_rs-0.2.2-cp310-none-win_amd64.whl (449.7 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

llm_rs-0.2.2-cp310-none-win32.whl (403.8 kB view hashes)

Uploaded CPython 3.10 Windows x86

llm_rs-0.2.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.5+ i686

llm_rs-0.2.2-cp310-cp310-macosx_11_0_arm64.whl (592.9 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

llm_rs-0.2.2-cp310-cp310-macosx_10_7_x86_64.whl (629.9 kB view hashes)

Uploaded CPython 3.10 macOS 10.7+ x86-64

llm_rs-0.2.2-cp39-none-win_amd64.whl (449.9 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

llm_rs-0.2.2-cp39-none-win32.whl (404.1 kB view hashes)

Uploaded CPython 3.9 Windows x86

llm_rs-0.2.2-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.5+ i686

llm_rs-0.2.2-cp38-none-win_amd64.whl (449.5 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

llm_rs-0.2.2-cp38-none-win32.whl (404.0 kB view hashes)

Uploaded CPython 3.8 Windows x86

llm_rs-0.2.2-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.5+ i686

llm_rs-0.2.2-cp37-none-win_amd64.whl (449.5 kB view hashes)

Uploaded CPython 3.7 Windows x86-64

llm_rs-0.2.2-cp37-none-win32.whl (404.1 kB view hashes)

Uploaded CPython 3.7 Windows x86

llm_rs-0.2.2-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.5 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

llm_rs-0.2.2-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.whl (1.5 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.5+ i686

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page