SentenceTransformersSparseDocumentEmbedder
Calculate sparse embeddings for documents using Sentence Transformers sparse models. The model runs locally, so no external API calls are made during embedding. Use this component in indexing pipelines to add sparse embeddings to documents before writing them to a document store.
We recommend using models available through the DeepsetNvidia components instead of the Sentence Transformers models.. Add a DeepsetNvidia component to your pipeline and choose an appropriate model from the list.
Embedding Models in Query Pipelines and Indexes
The embedding model you use to embed documents in your indexing pipeline must be the same as the embedding model you use to embed the query in your query pipeline.
This means the embedders for your indexing and query pipelines must match. For example, if you use CohereDocumentEmbedder to embed your documents, you should use CohereTextEmbedder with the same model to embed your queries.
Key Features
- Calculates sparse embeddings for documents using SPLADE-based models.
- Stores sparse embeddings in the
sparse_embeddingmetadata field of each document. - Supports embedding document metadata fields alongside document text.
- Configurable batch size and progress reporting.
Configuration
- Drag the
SentenceTransformersSparseDocumentEmbeddercomponent onto the canvas from the Component Library. - Click on the component to open the configuration panel.
- On the General tab:
- Set
modelto the sparse embedding model to use (for example,prithivida/Splade_PP_en_v2). - Set
batch_sizeto control how many documents are embedded at once. - Toggle
progress_barto show or hide a progress bar during embedding.
- Set
- Go to the Advanced tab to configure
prefix,suffix,trust_remote_code,token, anddevice.
Embedding Models in Query Pipelines and Indexes
The embedding model you use to embed documents in your indexing pipeline must be the same as the embedding model you use to embed the query in your query pipeline.
This means the embedders for your indexing and query pipelines must match. For example, if you use CohereDocumentEmbedder to embed your documents, you should use CohereTextEmbedder with the same model to embed your queries.
Connections
SentenceTransformersSparseDocumentEmbedder receives a list of documents through its documents input, typically from a DocumentSplitter or other preprocessor. It outputs a documents list with the sparse_embedding field populated. Connect the output to DocumentWriter to write the embedded documents to a document store.
Source Code
To check this component's source code, open sentence_transformers_sparse_document_embedder.py in the Haystack repository.
Usage Examples
Basic Configuration
SparseDocumentEmbedder:
type:
haystack.components.embedders.sentence_transformers_sparse_document_embedder.SentenceTransformersSparseDocumentEmbedder
init_parameters:
model: prithivida/Splade_PP_en_v2
batch_size: 32
progress_bar: true
This index uses SentenceTransformersSparseDocumentEmbedder to create sparse embeddings for documents:
components:
FileTypeRouter:
type: haystack.components.routers.file_type_router.FileTypeRouter
init_parameters:
mime_types:
- text/plain
- application/pdf
- text/markdown
TextFileToDocument:
type: haystack.components.converters.txt.TextFileToDocument
init_parameters:
encoding: utf-8
store_full_path: false
PDFMinerToDocument:
type: haystack.components.converters.pdfminer.PDFMinerToDocument
init_parameters:
store_full_path: false
MarkdownToDocument:
type: haystack.components.converters.markdown.MarkdownToDocument
init_parameters:
store_full_path: false
DocumentJoiner:
type: haystack.components.joiners.document_joiner.DocumentJoiner
init_parameters:
join_mode: concatenate
sort_by_score: false
DocumentSplitter:
type: haystack.components.preprocessors.document_splitter.DocumentSplitter
init_parameters:
split_by: word
split_length: 250
split_overlap: 30
respect_sentence_boundary: true
language: en
SparseDocumentEmbedder:
type: haystack.components.embedders.sentence_transformers_sparse_document_embedder.SentenceTransformersSparseDocumentEmbedder
init_parameters:
model: prithivida/Splade_PP_en_v2
batch_size: 32
progress_bar: true
DocumentWriter:
type: haystack.components.writers.document_writer.DocumentWriter
init_parameters:
document_store:
type: haystack_integrations.document_stores.opensearch.document_store.OpenSearchDocumentStore
init_parameters:
hosts:
index: ''
max_chunk_bytes: 104857600
embedding_dim: 768
return_embedding: false
method:
mappings:
settings:
create_index: true
http_auth:
use_ssl:
verify_certs:
timeout:
policy: OVERWRITE
connections:
- sender: FileTypeRouter.text/plain
receiver: TextFileToDocument.sources
- sender: FileTypeRouter.application/pdf
receiver: PDFMinerToDocument.sources
- sender: FileTypeRouter.text/markdown
receiver: MarkdownToDocument.sources
- sender: TextFileToDocument.documents
receiver: DocumentJoiner.documents
- sender: PDFMinerToDocument.documents
receiver: DocumentJoiner.documents
- sender: MarkdownToDocument.documents
receiver: DocumentJoiner.documents
- sender: DocumentJoiner.documents
receiver: DocumentSplitter.documents
- sender: DocumentSplitter.documents
receiver: SparseDocumentEmbedder.documents
- sender: SparseDocumentEmbedder.documents
receiver: DocumentWriter.documents
max_runs_per_component: 100
metadata: {}
inputs:
files:
- FileTypeRouter.sources
Parameters
Inputs
| Parameter | Type | Default | Description |
|---|---|---|---|
documents | List[Document] | Documents to embed. |
Outputs
| Parameter | Type | Default | Description |
|---|---|---|---|
documents | List[Document] | Documents with sparse embeddings added in the sparse_embedding field. |
Init Parameters
These are the parameters you can configure in Pipeline Builder:
| Parameter | Type | Default | Description |
|---|---|---|---|
model | str | prithivida/Splade_PP_en_v2 | The model to use for calculating sparse embeddings. Pass a local path or the ID of the model on Hugging Face. |
device | Optional[ComponentDevice] | None | The device to use for loading the model. Overrides the default device. |
token | Optional[Secret] | The API token to download private models from Hugging Face. | |
prefix | str | "" | A string to add at the beginning of each document text. |
suffix | str | "" | A string to add at the end of each document text. |
batch_size | int | 32 | Number of documents to embed at once. |
progress_bar | bool | True | If True, shows a progress bar when embedding documents. |
meta_fields_to_embed | Optional[List[str]] | None | List of metadata fields to embed along with the document text. |
embedding_separator | str | "\n" | Separator used to concatenate the metadata fields to the document text. |
trust_remote_code | bool | False | If True, allows custom models and scripts. |
local_files_only | bool | False | If True, only looks at local files without downloading from Hugging Face Hub. |
model_kwargs | Optional[Dict[str, Any]] | None | Additional keyword arguments for AutoModelForSequenceClassification.from_pretrained when loading the model. |
tokenizer_kwargs | Optional[Dict[str, Any]] | None | Additional keyword arguments for AutoTokenizer.from_pretrained when loading the tokenizer. |
config_kwargs | Optional[Dict[str, Any]] | None | Additional keyword arguments for AutoConfig.from_pretrained when loading the model configuration. |
backend | Literal["torch", "onnx", "openvino"] | torch | The backend to use for the Sentence Transformers model. Refer to the Sentence Transformers documentation for more information. |
revision | Optional[str] | None | The specific model version to use. It can be a branch name, a tag name, or a commit ID for a stored model on Hugging Face. |
Run Method Parameters
These are the parameters you can configure for the component's run() method. This means you can pass these parameters at query time through the API, in Playground, or when running a job. For details, see Modify Pipeline Parameters at Query Time.
| Parameter | Type | Default | Description |
|---|---|---|---|
documents | List[Document] | Documents to embed. |
Was this page helpful?