Source code for langchain_core.embeddings.fake

import hashlib
from typing import List

from langchain_core.embeddings import Embeddings
from langchain_core.pydantic_v1 import BaseModel


[docs]class FakeEmbeddings(Embeddings, BaseModel): """θ™šε‡ηš„ε΅Œε…₯ζ¨‘εž‹γ€‚""" size: int """塌ε…₯ε‘ι‡ηš„ε€§ε°γ€‚""" def _get_embedding(self) -> List[float]: import numpy as np # type: ignore[import-not-found, import-untyped] return list(np.random.normal(size=self.size))
[docs] def embed_documents(self, texts: List[str]) -> List[List[float]]: return [self._get_embedding() for _ in texts]
[docs] def embed_query(self, text: str) -> List[float]: return self._get_embedding()
[docs]class DeterministicFakeEmbedding(Embeddings, BaseModel): """θ™šζ‹Ÿε΅Œε…₯ζ¨‘εž‹οΌŒε§‹η»ˆδΈΊη›ΈεŒζ–‡ζœ¬θΏ”ε›žη›ΈεŒηš„ε΅Œε…₯向量。 """ size: int """塌ε…₯ε‘ι‡ηš„ε€§ε°γ€‚""" def _get_embedding(self, seed: int) -> List[float]: import numpy as np # type: ignore[import-not-found, import-untyped] # set the seed for the random generator np.random.seed(seed) return list(np.random.normal(size=self.size)) def _get_seed(self, text: str) -> int: """ δ½Ώη”¨ζ–‡ζœ¬ηš„ε“ˆεΈŒε€ΌθŽ·ε–ιšζœΊη”Ÿζˆε™¨ηš„η§ε­γ€‚ """ return int(hashlib.sha256(text.encode("utf-8")).hexdigest(), 16) % 10**8
[docs] def embed_documents(self, texts: List[str]) -> List[List[float]]: return [self._get_embedding(seed=self._get_seed(_)) for _ in texts]
[docs] def embed_query(self, text: str) -> List[float]: return self._get_embedding(seed=self._get_seed(text))