npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@chroma-core/sentence-transformer

v0.1.0

Published

Sentence Transformer embedding provider for Chroma using transformers.js

Downloads

266

Readme

Sentence Transformers Embedding Function for Chroma

This package provides a Sentence Transformers embedding provider for Chroma using transformers.js (@huggingface/transformers). It allows you to run Sentence Transformer models directly in Node.js without requiring a separate server.

Installation

npm install @chroma-core/sentence-transformer

Usage

import { ChromaClient } from 'chromadb';
import { SentenceTransformersEmbeddingFunction } from '@chroma-core/sentence-transformer';

// Initialize the embedder with the default model (all-MiniLM-L6-v2)
const embedder = new SentenceTransformersEmbeddingFunction();

// Or initialize with a custom model
const customEmbedder = new SentenceTransformersEmbeddingFunction({
  modelName: 'Xenova/all-mpnet-base-v2', // Higher quality model
  device: 'cpu', // 'cpu' or 'gpu' (default: 'cpu')
  normalizeEmbeddings: false, // Whether to normalize embeddings (default: false)
  kwargs: { quantized: true }, // Optional: additional arguments like quantized
});

// Create a new ChromaClient
const client = new ChromaClient({
  path: 'http://localhost:8000',
});

// Create a collection with the embedder
const collection = await client.createCollection({
  name: 'my-collection',
  embeddingFunction: embedder,
});

// Add documents
await collection.add({
  ids: ["1", "2", "3"],
  documents: ["Document 1", "Document 2", "Document 3"],
});

// Query documents
const results = await collection.query({
  queryTexts: ["Sample query"],
  nResults: 2,
});

Configuration Options

  • modelName: The Sentence Transformer model to use (default: "all-MiniLM-L6-v2")
    • Short names (recommended): Use short names like "all-MiniLM-L6-v2" for cross-client compatibility with Python. These are automatically resolved to Xenova/all-MiniLM-L6-v2 for transformers.js.
    • Full names: You can also use full model identifiers like Xenova/all-MiniLM-L6-v2 or sentence-transformers/all-MiniLM-L6-v2 if you need to specify a particular variant.
    • Popular models: all-MiniLM-L6-v2 (default), all-mpnet-base-v2, bge-small-en-v1.5
  • device: Device to run the model on - 'cpu' or 'gpu' (default: 'cpu')
  • normalizeEmbeddings: Whether to normalize returned vectors (default: false)
  • kwargs: Additional arguments to pass to the model (e.g., { quantized: true })

Supported Models

You can use any Sentence Transformer model that is compatible with transformers.js. Popular models include:

  • Xenova/all-MiniLM-L6-v2 - Fast, lightweight model (384 dimensions)
  • Xenova/all-mpnet-base-v2 - Higher quality model (768 dimensions)
  • sentence-transformers/all-MiniLM-L6-v2 - Alternative model identifier
  • sentence-transformers/all-mpnet-base-v2 - Alternative model identifier

Check the transformers.js documentation for more available models.

Features

  • Local Execution: Run models directly in Node.js without external API calls
  • Multiple Models: Support for various Sentence Transformer models
  • GPU Support: Optional GPU acceleration when available
  • No API Keys: No external API keys required
  • Configurable Normalization: Control whether embeddings are normalized

Notes

  • Models are downloaded and cached on first use
  • You can pass quantized: true in kwargs for faster loading and reduced memory usage
  • GPU support requires appropriate hardware and drivers
  • Model loading may take some time on first use