Skip to main content

open-source vector database. store and retrieve embeddings for your next ai project!

Project description

🍋 citrus.

open-source (distributed) vector database

Installation

pip install citrusdb

Getting started

1. Create index

import citrusdb

# Initialize client
citrus = citrusdb.Client()

# Create index
citrus.create_index(
  name="example",
  max_elements=1000,            # increases dynamically as you insert more vectors
)

2. Insert elements

ids = [1, 2, 3]
documents = [
  "Your time is limited, so don't waste it living someone else's life",
  "I'd rather be optimistic and wrong than pessimistic and right.",
  "Running a start-up is like chewing glass and staring into the abyss."
]

citrus.add(index="example", ids=ids, documents=documents)

You can directly pass vector embeddings as well. If you're passing a list of strings like we have done here, ensure you have your OPENAI_API_KEY in the environment. By default we use OpenAI to to generate the embeddings. Please reach out if you're looking for support from a different provider!

3. Search

results = citrus.query(
    index="example",
    documents=["What is it like to launch a startup"],
    k=1,
    include=["document", "metadata"]
)

print(results)

You can specify if you want the associated text document and metadata to be returned. By default, only the IDs are returned.

Go launch a repl on Replit and see what result you get after running the query! result will contain the ids of the top k search hits.

Example

chat w/ replit ai podcast

pokedex search

Facing issues?

Feel free to open issues on this repository! Discord server coming soon!

PS: citrus isn't fully distributed just yet. We're getting there though ;)

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

citrusdb-0.6.2.tar.gz (18.3 kB view details)

Uploaded Source

Built Distribution

citrusdb-0.6.2-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file citrusdb-0.6.2.tar.gz.

File metadata

  • Download URL: citrusdb-0.6.2.tar.gz
  • Upload date:
  • Size: 18.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for citrusdb-0.6.2.tar.gz
Algorithm Hash digest
SHA256 21abf43f52a652827352533316a5c97f60956b96bb4422a6ccaca54b47d9c05c
MD5 19bcbe6a49da6868c4de8a21e72120e7
BLAKE2b-256 a01650e9a88975ec38cc5cda1d0f4933aee089874171b3aaff673aab47b194d4

See more details on using hashes here.

File details

Details for the file citrusdb-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: citrusdb-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for citrusdb-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1c56c648a30b66501a4d1f478cc8ef93d0052a050c0e4ce271479244f1b84051
MD5 3e92941a196c31ec6c3a1ed463fe5fbe
BLAKE2b-256 f2b7f378b108b3872291b47925f9401d19040fb49133e4c9b8afb46a03a6f5fd

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