From 4a474468f9b5ded79cc93512acba726e9adf7332 Mon Sep 17 00:00:00 2001 From: Alper Date: Mon, 14 Oct 2024 18:08:53 +0200 Subject: [PATCH] feat: SentenceTransformersTextEmbedder supports `config_kwargs` (#8432) * add config_kwargs * disable PLR0913 for a specific function * add a release note * refer to AutoConfig in config_kwargs docstring --------- Co-authored-by: David S. Batista Co-authored-by: Julian Risch --- .../embedders/sentence_transformers_text_embedder.py | 8 +++++++- ...mers-text-embedder-config_kwargs-11f10429e25a3a6e.yaml | 4 ++++ .../embedders/test_sentence_transformers_text_embedder.py | 6 ++++++ 3 files changed, 17 insertions(+), 1 deletion(-) create mode 100644 releasenotes/notes/sentence-transformers-text-embedder-config_kwargs-11f10429e25a3a6e.yaml diff --git a/haystack/components/embedders/sentence_transformers_text_embedder.py b/haystack/components/embedders/sentence_transformers_text_embedder.py index e29b2d439c..f8b959495f 100644 --- a/haystack/components/embedders/sentence_transformers_text_embedder.py +++ b/haystack/components/embedders/sentence_transformers_text_embedder.py @@ -34,7 +34,7 @@ class SentenceTransformersTextEmbedder: ``` """ - def __init__( + def __init__( # noqa: PLR0913 self, model: str = "sentence-transformers/all-mpnet-base-v2", device: Optional[ComponentDevice] = None, @@ -48,6 +48,7 @@ def __init__( truncate_dim: Optional[int] = None, model_kwargs: Optional[Dict[str, Any]] = None, tokenizer_kwargs: Optional[Dict[str, Any]] = None, + config_kwargs: Optional[Dict[str, Any]] = None, precision: Literal["float32", "int8", "uint8", "binary", "ubinary"] = "float32", ): """ @@ -86,6 +87,8 @@ def __init__( :param tokenizer_kwargs: Additional keyword arguments for `AutoTokenizer.from_pretrained` when loading the tokenizer. Refer to specific model documentation for available kwargs. + :param config_kwargs: + Additional keyword arguments for `AutoConfig.from_pretrained` when loading the model configuration. :param precision: The precision to use for the embeddings. All non-float32 precisions are quantized embeddings. @@ -105,6 +108,7 @@ def __init__( self.truncate_dim = truncate_dim self.model_kwargs = model_kwargs self.tokenizer_kwargs = tokenizer_kwargs + self.config_kwargs = config_kwargs self.embedding_backend = None self.precision = precision @@ -135,6 +139,7 @@ def to_dict(self) -> Dict[str, Any]: truncate_dim=self.truncate_dim, model_kwargs=self.model_kwargs, tokenizer_kwargs=self.tokenizer_kwargs, + config_kwargs=self.config_kwargs, precision=self.precision, ) if serialization_dict["init_parameters"].get("model_kwargs") is not None: @@ -172,6 +177,7 @@ def warm_up(self): truncate_dim=self.truncate_dim, model_kwargs=self.model_kwargs, tokenizer_kwargs=self.tokenizer_kwargs, + config_kwargs=self.config_kwargs, ) if self.tokenizer_kwargs and self.tokenizer_kwargs.get("model_max_length"): self.embedding_backend.model.max_seq_length = self.tokenizer_kwargs["model_max_length"] diff --git a/releasenotes/notes/sentence-transformers-text-embedder-config_kwargs-11f10429e25a3a6e.yaml b/releasenotes/notes/sentence-transformers-text-embedder-config_kwargs-11f10429e25a3a6e.yaml new file mode 100644 index 0000000000..9409b09e6d --- /dev/null +++ b/releasenotes/notes/sentence-transformers-text-embedder-config_kwargs-11f10429e25a3a6e.yaml @@ -0,0 +1,4 @@ +--- +enhancements: + - | + SentenceTransformersTextEmbedder now supports config_kwargs for additional parameters when loading the model configuration diff --git a/test/components/embedders/test_sentence_transformers_text_embedder.py b/test/components/embedders/test_sentence_transformers_text_embedder.py index 2f043de237..9325c481ca 100644 --- a/test/components/embedders/test_sentence_transformers_text_embedder.py +++ b/test/components/embedders/test_sentence_transformers_text_embedder.py @@ -70,6 +70,7 @@ def test_to_dict(self): "truncate_dim": None, "model_kwargs": None, "tokenizer_kwargs": None, + "config_kwargs": None, "precision": "float32", }, } @@ -88,6 +89,7 @@ def test_to_dict_with_custom_init_parameters(self): truncate_dim=256, model_kwargs={"torch_dtype": torch.float32}, tokenizer_kwargs={"model_max_length": 512}, + config_kwargs={"use_memory_efficient_attention": False}, precision="int8", ) data = component.to_dict() @@ -106,6 +108,7 @@ def test_to_dict_with_custom_init_parameters(self): "truncate_dim": 256, "model_kwargs": {"torch_dtype": "torch.float32"}, "tokenizer_kwargs": {"model_max_length": 512}, + "config_kwargs": {"use_memory_efficient_attention": False}, "precision": "int8", }, } @@ -131,6 +134,7 @@ def test_from_dict(self): "truncate_dim": None, "model_kwargs": {"torch_dtype": "torch.float32"}, "tokenizer_kwargs": {"model_max_length": 512}, + "config_kwargs": {"use_memory_efficient_attention": False}, "precision": "float32", }, } @@ -147,6 +151,7 @@ def test_from_dict(self): assert component.truncate_dim is None assert component.model_kwargs == {"torch_dtype": torch.float32} assert component.tokenizer_kwargs == {"model_max_length": 512} + assert component.config_kwargs == {"use_memory_efficient_attention": False} assert component.precision == "float32" def test_from_dict_no_default_parameters(self): @@ -218,6 +223,7 @@ def test_warmup(self, mocked_factory): truncate_dim=None, model_kwargs=None, tokenizer_kwargs={"model_max_length": 512}, + config_kwargs=None, ) @patch(