the AI-native open-source embedding database
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Max Isom c881a0e5a8
[ENH]: skip querying `MetadataSegmentReader` for empty where clause (#2711)
4 days ago
.github [BLD]: fix nightly tests pod log upload (#2670) 3 weeks ago
.vscode [DOC] nits and fixes (#2107) 4 months ago
bin [TST] Isolated Test Environments using testcontainers (#2607) 1 month ago
chromadb [ENH]: skip querying `MetadataSegmentReader` for empty where clause (#2711) 4 days ago
clients [ENH]: update JS CloudClient to accept `tenant` parameter (#2726) 2 weeks ago
docs [ENH] JS Client Refactor (Full Stack) (#2542) 1 month ago
examples [CHORE]: Support for CLI in systemd examples (#2217) 3 months ago
go [PERF] Add include metadata to MetadataReader to avoid unncessary payload size (#2750) 1 week ago
idl [PERF] Add include metadata to MetadataReader to avoid unncessary payload size (#2750) 1 week ago
k8s [ENH] Add gc for log service (#2634) 2 weeks ago
rust [ENH]: skip querying `MetadataSegmentReader` for empty where clause (#2711) 4 days ago
.dockerignore Ignore .conda in .dockerignore (#814) 1 year ago
.gitattributes [ENH]: refactoring log service (#1958) 5 months ago
.gitignore [ENH] Simplify auth and correctly overwrite singleton tenant+db (#1970) 5 months ago
.pre-commit-config.yaml [ENH] JS Client Refactor (Full Stack) (#2542) 1 month ago
Cargo.lock [ENH] Network Admission Control APIs (#2628) 3 weeks ago
Cargo.toml [CLN] Move distance, and index into their own crates (#2624) 1 month ago
DEVELOP.md [ENH] Upgrade tests and release to Python 3.12 (#1715) 7 months ago
Dockerfile [BLD] Python & misc lint fixes (#2046) 5 months ago
Dockerfile.windows [BLD] Build Dockerfile on Windows (#2130) 3 months ago
LICENSE Initial commit 2 years ago
README.md [DOC] change cachce on discord shields (#2331) 3 months ago
RELEASE_PROCESS.md [BLD] Make python release processes add a check tag step 1 year ago
Tiltfile [ENH]: add metric for total # of uncompacted log records (#2696) 2 weeks ago
bandit.yaml [SEC]: Bandit Scan (#1113) 1 year ago
compose-env.linux [BLD] Build Dockerfile on Windows (#2130) 3 months ago
compose-env.windows [BLD] Build Dockerfile on Windows (#2130) 3 months ago
docker-compose.server.example.yml [ENH]: Docker compose data volume (#1119) 9 months ago
docker-compose.test-auth.yml [ENH] Add an init method that eagerly reports errors with the tenant or DB (#2537) 2 months ago
docker-compose.test.yml [ENH] Add an init method that eagerly reports errors with the tenant or DB (#2537) 2 months ago
docker-compose.yml [BUG] Docker compose authn env var (#2114) 4 months ago
pull_request_template.md [DOCS] Update pull_request_template.md (#1824) 6 months ago
pyproject.toml [ENH] add vacuum CLI command (#2519) 1 month ago
requirements.txt [PERF]: bump compaction partition size to 10k (#2647) 1 month ago
requirements_dev.txt [ENH] Connection pool FD leak v2 (#2014) 1 month ago
yarn.lock CLN: Updated versions of `flake8` and `pre-commit-hooks` and modified files accordingly (#1575) 8 months ago

README.md

Chroma logo

Chroma - the open-source embedding database.
The fastest way to build Python or JavaScript LLM apps with memory!

Discord | License | Docs | Homepage

pip install chromadb # python client
# for javascript, npm install chromadb!
# for client-server mode, chroma run --path /chroma_db_path

The core API is only 4 functions (run our 💡 Google Colab or Replit template):

import chromadb
# setup Chroma in-memory, for easy prototyping. Can add persistence easily!
client = chromadb.Client()

# Create collection. get_collection, get_or_create_collection, delete_collection also available!
collection = client.create_collection("all-my-documents")

# Add docs to the collection. Can also update and delete. Row-based API coming soon!
collection.add(
    documents=["This is document1", "This is document2"], # we handle tokenization, embedding, and indexing automatically. You can skip that and add your own embeddings as well
    metadatas=[{"source": "notion"}, {"source": "google-docs"}], # filter on these!
    ids=["doc1", "doc2"], # unique for each doc
)

# Query/search 2 most similar results. You can also .get by id
results = collection.query(
    query_texts=["This is a query document"],
    n_results=2,
    # where={"metadata_field": "is_equal_to_this"}, # optional filter
    # where_document={"$contains":"search_string"}  # optional filter
)

Features

  • Simple: Fully-typed, fully-tested, fully-documented == happiness
  • Integrations: 🦜🔗 LangChain (python and js), 🦙 LlamaIndex and more soon
  • Dev, Test, Prod: the same API that runs in your python notebook, scales to your cluster
  • Feature-rich: Queries, filtering, density estimation and more
  • Free & Open Source: Apache 2.0 Licensed

Use case: ChatGPT for ______

For example, the "Chat your data" use case:

  1. Add documents to your database. You can pass in your own embeddings, embedding function, or let Chroma embed them for you.
  2. Query relevant documents with natural language.
  3. Compose documents into the context window of an LLM like GPT3 for additional summarization or analysis.

Embeddings?

What are embeddings?

  • Read the guide from OpenAI
  • Literal: Embedding something turns it from image/text/audio into a list of numbers. 🖼 or 📄 => [1.2, 2.1, ....]. This process makes documents "understandable" to a machine learning model.
  • By analogy: An embedding represents the essence of a document. This enables documents and queries with the same essence to be "near" each other and therefore easy to find.
  • Technical: An embedding is the latent-space position of a document at a layer of a deep neural network. For models trained specifically to embed data, this is the last layer.
  • A small example: If you search your photos for "famous bridge in San Francisco". By embedding this query and comparing it to the embeddings of your photos and their metadata - it should return photos of the Golden Gate Bridge.

Embeddings databases (also known as vector databases) store embeddings and allow you to search by nearest neighbors rather than by substrings like a traditional database. By default, Chroma uses Sentence Transformers to embed for you but you can also use OpenAI embeddings, Cohere (multilingual) embeddings, or your own.

Get involved

Chroma is a rapidly developing project. We welcome PR contributors and ideas for how to improve the project.

Release Cadence We currently release new tagged versions of the pypi and npm packages on Mondays. Hotfixes go out at any time during the week.

License

Apache 2.0