Home / File/ embedding_router.py — langchain Source File

embedding_router.py — langchain Source File

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

Entity Profile

Dependency Diagram

graph LR
  5a575985_9717_2712_b4d3_63eae36d8efc["embedding_router.py"]
  cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7["collections.abc"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7
  8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3["typing"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> 8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3
  f3bc7443_c889_119d_0744_aacc3620d8d2["langchain_core.callbacks"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> f3bc7443_c889_119d_0744_aacc3620d8d2
  c554676d_b731_47b2_a98f_c1c2d537c0aa["langchain_core.documents"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> c554676d_b731_47b2_a98f_c1c2d537c0aa
  bc46b61d_cfdf_3f6b_a9dd_ac2a328d84b3["langchain_core.embeddings"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> bc46b61d_cfdf_3f6b_a9dd_ac2a328d84b3
  d55af636_303c_0eb6_faee_20d89bd952d5["langchain_core.vectorstores"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> d55af636_303c_0eb6_faee_20d89bd952d5
  6e58aaea_f08e_c099_3cc7_f9567bfb1ae7["pydantic"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> 6e58aaea_f08e_c099_3cc7_f9567bfb1ae7
  91721f45_4909_e489_8c1f_084f8bd87145["typing_extensions"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> 91721f45_4909_e489_8c1f_084f8bd87145
  2e4e7dd2_a233_b459_0286_08afde64f38f["langchain_classic.chains.router.base"]
  5a575985_9717_2712_b4d3_63eae36d8efc --> 2e4e7dd2_a233_b459_0286_08afde64f38f
  style 5a575985_9717_2712_b4d3_63eae36d8efc fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

from __future__ import annotations

from collections.abc import Sequence
from typing import Any

from langchain_core.callbacks import (
    AsyncCallbackManagerForChainRun,
    CallbackManagerForChainRun,
)
from langchain_core.documents import Document
from langchain_core.embeddings import Embeddings
from langchain_core.vectorstores import VectorStore
from pydantic import ConfigDict
from typing_extensions import override

from langchain_classic.chains.router.base import RouterChain


class EmbeddingRouterChain(RouterChain):
    """Chain that uses embeddings to route between options."""

    vectorstore: VectorStore
    routing_keys: list[str] = ["query"]

    model_config = ConfigDict(
        arbitrary_types_allowed=True,
        extra="forbid",
    )

    @property
    def input_keys(self) -> list[str]:
        """Will be whatever keys the LLM chain prompt expects."""
        return self.routing_keys

    @override
    def _call(
        self,
        inputs: dict[str, Any],
        run_manager: CallbackManagerForChainRun | None = None,
    ) -> dict[str, Any]:
        _input = ", ".join([inputs[k] for k in self.routing_keys])
        results = self.vectorstore.similarity_search(_input, k=1)
        return {"next_inputs": inputs, "destination": results[0].metadata["name"]}

    @override
    async def _acall(
        self,
        inputs: dict[str, Any],
        run_manager: AsyncCallbackManagerForChainRun | None = None,
    ) -> dict[str, Any]:
        _input = ", ".join([inputs[k] for k in self.routing_keys])
        results = await self.vectorstore.asimilarity_search(_input, k=1)
        return {"next_inputs": inputs, "destination": results[0].metadata["name"]}

    @classmethod
    def from_names_and_descriptions(
        cls,
        names_and_descriptions: Sequence[tuple[str, Sequence[str]]],
        vectorstore_cls: type[VectorStore],
        embeddings: Embeddings,
        **kwargs: Any,
    ) -> EmbeddingRouterChain:
        """Convenience constructor."""
        documents = []
        for name, descriptions in names_and_descriptions:
            documents.extend(
                [
                    Document(page_content=description, metadata={"name": name})
                    for description in descriptions
                ]
            )
        vectorstore = vectorstore_cls.from_documents(documents, embeddings)
        return cls(vectorstore=vectorstore, **kwargs)

    @classmethod
    async def afrom_names_and_descriptions(
        cls,
        names_and_descriptions: Sequence[tuple[str, Sequence[str]]],
        vectorstore_cls: type[VectorStore],
        embeddings: Embeddings,
        **kwargs: Any,
    ) -> EmbeddingRouterChain:
        """Convenience constructor."""
        documents = []
        documents.extend(
            [
                Document(page_content=description, metadata={"name": name})
                for name, descriptions in names_and_descriptions
                for description in descriptions
            ]
        )
        vectorstore = await vectorstore_cls.afrom_documents(documents, embeddings)
        return cls(vectorstore=vectorstore, **kwargs)

Subdomains

Dependencies

  • collections.abc
  • langchain_classic.chains.router.base
  • langchain_core.callbacks
  • langchain_core.documents
  • langchain_core.embeddings
  • langchain_core.vectorstores
  • pydantic
  • typing
  • typing_extensions

Frequently Asked Questions

What does embedding_router.py do?
embedding_router.py is a source file in the langchain codebase, written in python. It belongs to the CoreAbstractions domain, RunnableInterface subdomain.
What does embedding_router.py depend on?
embedding_router.py imports 9 module(s): collections.abc, langchain_classic.chains.router.base, langchain_core.callbacks, langchain_core.documents, langchain_core.embeddings, langchain_core.vectorstores, pydantic, typing, and 1 more.
Where is embedding_router.py in the architecture?
embedding_router.py is located at libs/langchain/langchain_classic/chains/router/embedding_router.py (domain: CoreAbstractions, subdomain: RunnableInterface, directory: libs/langchain/langchain_classic/chains/router).

Analyze Your Own Codebase

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

Try Supermodel Free