Skip to main content

Use sentence-transformers for embeddings with LLM

Project description

llm-sentence-transformers

PyPI Changelog Tests License

LLM plugin for embedding models using sentence-transformers

Further reading:

Installation

Install this plugin in the same environment as LLM.

llm install llm-sentence-transformers

Configuration

After installing the plugin you need to register one or more models in order to use it. The all-MiniLM-L6-v2 model is registered by default, and will be downloaded the first time you use it.

You can try that model out like this:

llm embed -m mini-l6 -c 'hello'

This will return a JSON array of floating point numbers.

You can add more models using the llm sentence-transformers register command. Here is a list of available models.

Two good models to start experimenting with are all-MiniLM-L12-v2 - a 120MB download - and all-mpnet-base-v2, which is 420MB.

To install that all-mpnet-base-v2 model, run:

llm sentence-transformers register \
  all-mpnet-base-v2 \
  --alias mpnet

The --alias is optional, but can be used to configure one or more shorter aliases for the model.

You can run llm aliases to confirm which aliases you have configured, and llm aliases set to configure further aliases.

Usage

Once you have installed an embedding model you can use it like this:

llm embed -m sentence-transformers/all-mpnet-base-v2 \
  -c "Hello world"

Or use its alias:

llm embed -m mpnet -c "Hello world"

Embeddings are more useful if you store them in a database - see the LLM documentation for instructions on doing that.

Be sure to review the documentation for the model you are using. Many models will silently truncate content beyond a certain number of tokens. all-mpnet-base-v2 says that "input text longer than 384 word pieces is truncated", for example.

Development

To set up this plugin locally, first checkout the code. Then create a new virtual environment:

cd llm-sentence-transformers
python3 -m venv venv
source venv/bin/activate

Now install the dependencies and test dependencies:

pip install -e '.[test]'

To run the tests:

pytest

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-sentence-transformers-0.2.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

llm_sentence_transformers-0.2-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file llm-sentence-transformers-0.2.tar.gz.

File metadata

File hashes

Hashes for llm-sentence-transformers-0.2.tar.gz
Algorithm Hash digest
SHA256 67f6b5cb8cd57276d90ed976d729fbe6357aae6c8daa7c98435c086687c3da3b
MD5 01d7b01a94f4f31d4719163123ba675a
BLAKE2b-256 99dac1d669d338b86ddfd0c18bc5f0bfd1aed24c8a59c4bbad21231e6ff09fd1

See more details on using hashes here.

File details

Details for the file llm_sentence_transformers-0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for llm_sentence_transformers-0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 48e10fe9312454355aa8865b946b67b6854763da9b79d85a7d385561f1ff7c51
MD5 edf92876a67342114e96ffb42d8d1d1f
BLAKE2b-256 bc4205fd68dc43031ad9c40f8bf12b54558b1d0cb990d2c1274570f63596a90f

See more details on using hashes here.

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