Home / File/ common.py — langchain Source File

common.py — langchain Source File

Architecture documentation for common.py, a python file in the langchain codebase. 4 imports, 0 dependents.

File python LangChainCore Runnables 4 imports 2 functions 2 classes

Entity Profile

Dependency Diagram

graph LR
  b62fe5d9_7b83_0e14_ef50_3645cafa8bc5["common.py"]
  a83cf0c6_37ab_ef90_8783_e7ae0273a0a0["requests"]
  b62fe5d9_7b83_0e14_ef50_3645cafa8bc5 --> a83cf0c6_37ab_ef90_8783_e7ae0273a0a0
  6a98b0a5_5607_0043_2e22_a46a464c2d62["langchain_core.documents"]
  b62fe5d9_7b83_0e14_ef50_3645cafa8bc5 --> 6a98b0a5_5607_0043_2e22_a46a464c2d62
  918b8514_ba55_6df2_7254_4598ec160e33["langchain_core.embeddings"]
  b62fe5d9_7b83_0e14_ef50_3645cafa8bc5 --> 918b8514_ba55_6df2_7254_4598ec160e33
  67883832_8f96_6ce0_6b88_0267f86654f8["langchain_qdrant"]
  b62fe5d9_7b83_0e14_ef50_3645cafa8bc5 --> 67883832_8f96_6ce0_6b88_0267f86654f8
  style b62fe5d9_7b83_0e14_ef50_3645cafa8bc5 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import requests  # type: ignore[import-untyped]
from langchain_core.documents import Document
from langchain_core.embeddings import Embeddings

from langchain_qdrant import SparseEmbeddings, SparseVector


def qdrant_running_locally() -> bool:
    """Check if Qdrant is running at http://localhost:6333."""
    try:
        response = requests.get("http://localhost:6333", timeout=10.0)
        response_json = response.json()
        return response_json.get("title") == "qdrant - vector search engine"
    except (requests.exceptions.ConnectionError, requests.exceptions.Timeout):
        return False


def assert_documents_equals(actual: list[Document], expected: list[Document]) -> None:  # type: ignore[no-untyped-def]
    assert len(actual) == len(expected)

    for actual_doc, expected_doc in zip(actual, expected, strict=False):
        assert actual_doc.page_content == expected_doc.page_content

        assert "_id" in actual_doc.metadata
        assert "_collection_name" in actual_doc.metadata

        actual_doc.metadata.pop("_id")
        actual_doc.metadata.pop("_collection_name")

        assert actual_doc.metadata == expected_doc.metadata


class ConsistentFakeEmbeddings(Embeddings):
    """Fake embeddings which remember all the texts seen so far to return consistent
    vectors for the same texts.
    """

    def __init__(self, dimensionality: int = 10) -> None:
        self.known_texts: list[str] = []
        self.dimensionality = dimensionality

    def embed_documents(self, texts: list[str]) -> list[list[float]]:
        """Return consistent embeddings for each text seen so far."""
        out_vectors = []
        for text in texts:
            if text not in self.known_texts:
                self.known_texts.append(text)
            vector = [1.0] * (self.dimensionality - 1) + [
                float(self.known_texts.index(text))
            ]
            out_vectors.append(vector)
        return out_vectors

    def embed_query(self, text: str) -> list[float]:
        """Return consistent embeddings for the text, if seen before, or a constant
        one if the text is unknown.
        """
        return self.embed_documents([text])[0]


class ConsistentFakeSparseEmbeddings(SparseEmbeddings):
    """Fake sparse embeddings which remembers all the texts seen so far
    "to return consistent vectors for the same texts.
    """

    def __init__(self, dimensionality: int = 25) -> None:
        self.known_texts: list[str] = []
        self.dimensionality = dimensionality

    def embed_documents(self, texts: list[str]) -> list[SparseVector]:
        """Return consistent embeddings for each text seen so far."""
        out_vectors = []
        for text in texts:
            if text not in self.known_texts:
                self.known_texts.append(text)
            index = self.known_texts.index(text)
            indices = [i + index for i in range(self.dimensionality)]
            values = [1.0] * (self.dimensionality - 1) + [float(index)]
            out_vectors.append(SparseVector(indices=indices, values=values))
        return out_vectors

    def embed_query(self, text: str) -> SparseVector:
        """Return consistent embeddings for the text, if seen before, or a constant
        one if the text is unknown.
        """
        return self.embed_documents([text])[0]

Domain

Subdomains

Dependencies

  • langchain_core.documents
  • langchain_core.embeddings
  • langchain_qdrant
  • requests

Frequently Asked Questions

What does common.py do?
common.py is a source file in the langchain codebase, written in python. It belongs to the LangChainCore domain, Runnables subdomain.
What functions are defined in common.py?
common.py defines 2 function(s): assert_documents_equals, qdrant_running_locally.
What does common.py depend on?
common.py imports 4 module(s): langchain_core.documents, langchain_core.embeddings, langchain_qdrant, requests.
Where is common.py in the architecture?
common.py is located at libs/partners/qdrant/tests/integration_tests/common.py (domain: LangChainCore, subdomain: Runnables, directory: libs/partners/qdrant/tests/integration_tests).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free