Moss vector search integration for Pipecat
Project description
Pipecat Moss Integration
Moss delivers sub-10ms semantic retrieval, ensuring your Pipecat AI voice agents respond naturally without noticeable delays.
Installation
Install the package
pip install pipecat-moss
Prerequisites
- Moss project ID and project key (get them from Moss Portal)
- Deepgram, OpenAI, Cartesia API keys (to run the example)
Usage with Pipecat Pipeline
Pipecat-Moss integrates seamlessly into a Pipecat pipeline, enabling efficient retrieval-based operations. It leverages Pipecat's modular architecture to inject semantic context for Voice AI Agents.
import os
import asyncio
from pipecat_moss import MossRetrievalService
moss_service = MossRetrievalService(
project_id=os.getenv("MOSS_PROJECT_ID"),
project_key=os.getenv("MOSS_PROJECT_KEY"),
system_prompt="Relevant passages from the Moss knowledge base:\n\n",
)
async def setup_indexes():
await moss_service.load_index(os.getenv("MOSS_INDEX_NAME"))
asyncio.run(setup_indexes())
pipeline = Pipeline([
transport.input(), # audio/user input
stt, # speech to text
context_aggregator.user(), # add user text to context
moss_service.query(os.getenv("MOSS_INDEX_NAME"), top_k=5, alpha=0.8), # retrieve relevant docs from Moss
llm, # LLM generates response
tts, # TTS synthesis
transport.output(), # stream audio back to user
context_aggregator.assistant(), # store assistant response
])
setup_indexes() must be awaited before the pipeline starts so the service can load the Moss index. See examples/moss-retrieval-demo.py for a complete working example.
Pipecat Compatibility
Tested with Pipecat v0.0.99. Please upgrade to this version (or newer) to ensure API compatibility with the snippets below.
Contributing
If you are contributing or want to build from source, follow the CONTRIBUTING.md setup steps.
Running the Example
Setup Environment Variables
Create a .env file in the root directory with the following content:
MOSS_PROJECT_ID= Your Moss Project ID
MOSS_PROJECT_KEY= Your Moss Project Key
MOSS_INDEX_NAME= Your Moss Index Name
DEEPGRAM_API_KEY= Your DEEPGRAM API KEY
CARTESIA_API_KEY= Your CARTESIA API KEY
OPENAI_API_KEY= Your OpenAI Key
Or pass them directly when creating the MossRetrievalService.
Creating a Moss Index (One-time Setup)
Before using Moss in your pipeline, you need to create an index and populate it with documents:
python examples/moss-create-index-demo.py
Run the Example
python examples/moss-retrieval-demo.py
Configuration Options
MossRetrievalService
project_id(required): Moss project ID (can use env varMOSS_PROJECT_ID)project_key(required): Moss project key (can use env varMOSS_PROJECT_KEY)system_prompt(default: "Here is additional context retrieved from database:\n\n"): Prefix added ahead of retrieved documentsload_index(index_name): Awaitable method that loads the given index before the pipeline runsquery(index_name, *, top_k=5): Returns aMossIndexProcessorfor the specified index;top_kcontrols result count,alphablends semantic vs keyword scoring (0.0 keyword-only, 1.0 semantic-only)
License
This integration is provided under a permissive open source license (BSD-2 or equivalent).
Support
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pipecat_moss-0.0.2.tar.gz.
File metadata
- Download URL: pipecat_moss-0.0.2.tar.gz
- Upload date:
- Size: 6.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
04ccf00e6b7efde64a2eb03286f06b01fb6dd96041323688f583502b1cbac787
|
|
| MD5 |
d0ed5b98278ad7835896406a7faaa8ac
|
|
| BLAKE2b-256 |
8619b0febe6fc7930258795b6330414860ce052c245d093baef3daaae951d066
|
File details
Details for the file pipecat_moss-0.0.2-py3-none-any.whl.
File metadata
- Download URL: pipecat_moss-0.0.2-py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5cd49f6b2cc33709af143796bd530d8fdbd77ce43d853a549ddd05359f5bc7ce
|
|
| MD5 |
802d92a9b285468dc92b83f1ce749391
|
|
| BLAKE2b-256 |
0e1f0196e8484b7fe55b3bceb2645a54aaf22519b30fcba817c27e386241131e
|