mirror of
https://github.com/hwchase17/langchain
synced 2024-11-08 07:10:35 +00:00
c1807d8408
# What does this PR do? Bring support of `encode_kwargs` for ` HuggingFaceInstructEmbeddings`, change the docstring example and add a test to illustrate with `normalize_embeddings`. Fixes #3605 (Similar to #3914) Use case: ```python from langchain.embeddings import HuggingFaceInstructEmbeddings model_name = "hkunlp/instructor-large" model_kwargs = {'device': 'cpu'} encode_kwargs = {'normalize_embeddings': True} hf = HuggingFaceInstructEmbeddings( model_name=model_name, model_kwargs=model_kwargs, encode_kwargs=encode_kwargs ) ```
58 lines
1.8 KiB
Python
58 lines
1.8 KiB
Python
"""Test huggingface embeddings."""
|
|
|
|
from langchain.embeddings.huggingface import (
|
|
HuggingFaceEmbeddings,
|
|
HuggingFaceInstructEmbeddings,
|
|
)
|
|
|
|
|
|
def test_huggingface_embedding_documents() -> None:
|
|
"""Test huggingface embeddings."""
|
|
documents = ["foo bar"]
|
|
embedding = HuggingFaceEmbeddings()
|
|
output = embedding.embed_documents(documents)
|
|
assert len(output) == 1
|
|
assert len(output[0]) == 768
|
|
|
|
|
|
def test_huggingface_embedding_query() -> None:
|
|
"""Test huggingface embeddings."""
|
|
document = "foo bar"
|
|
embedding = HuggingFaceEmbeddings(encode_kwargs={"batch_size": 16})
|
|
output = embedding.embed_query(document)
|
|
assert len(output) == 768
|
|
|
|
|
|
def test_huggingface_instructor_embedding_documents() -> None:
|
|
"""Test huggingface embeddings."""
|
|
documents = ["foo bar"]
|
|
model_name = "hkunlp/instructor-base"
|
|
embedding = HuggingFaceInstructEmbeddings(model_name=model_name)
|
|
output = embedding.embed_documents(documents)
|
|
assert len(output) == 1
|
|
assert len(output[0]) == 768
|
|
|
|
|
|
def test_huggingface_instructor_embedding_query() -> None:
|
|
"""Test huggingface embeddings."""
|
|
query = "foo bar"
|
|
model_name = "hkunlp/instructor-base"
|
|
embedding = HuggingFaceInstructEmbeddings(model_name=model_name)
|
|
output = embedding.embed_query(query)
|
|
assert len(output) == 768
|
|
|
|
|
|
def test_huggingface_instructor_embedding_normalize() -> None:
|
|
"""Test huggingface embeddings."""
|
|
query = "foo bar"
|
|
model_name = "hkunlp/instructor-base"
|
|
encode_kwargs = {"normalize_embeddings": True}
|
|
embedding = HuggingFaceInstructEmbeddings(
|
|
model_name=model_name, encode_kwargs=encode_kwargs
|
|
)
|
|
output = embedding.embed_query(query)
|
|
assert len(output) == 768
|
|
eps = 1e-5
|
|
norm = sum([o**2 for o in output])
|
|
assert abs(1 - norm) <= eps
|