retrieval.py — langchain Source File
Architecture documentation for retrieval.py, a python file in the langchain codebase. 3 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR a9b15678_260f_ff5a_60e8_7e75bfd1bbc7["retrieval.py"] feec1ec4_6917_867b_d228_b134d0ff8099["typing"] a9b15678_260f_ff5a_60e8_7e75bfd1bbc7 --> feec1ec4_6917_867b_d228_b134d0ff8099 2b1aa4a8_5352_1757_010a_46ac9ef4b0b0["langchain_core.retrievers"] a9b15678_260f_ff5a_60e8_7e75bfd1bbc7 --> 2b1aa4a8_5352_1757_010a_46ac9ef4b0b0 31eab4ab_7281_1e6c_b17d_12e6ad9de07a["langchain_core.runnables"] a9b15678_260f_ff5a_60e8_7e75bfd1bbc7 --> 31eab4ab_7281_1e6c_b17d_12e6ad9de07a style a9b15678_260f_ff5a_60e8_7e75bfd1bbc7 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
from __future__ import annotations
from typing import Any
from langchain_core.retrievers import (
BaseRetriever,
RetrieverOutput,
)
from langchain_core.runnables import Runnable, RunnablePassthrough
def create_retrieval_chain(
retriever: BaseRetriever | Runnable[dict, RetrieverOutput],
combine_docs_chain: Runnable[dict[str, Any], str],
) -> Runnable:
"""Create retrieval chain that retrieves documents and then passes them on.
Args:
retriever: Retriever-like object that returns list of documents. Should
either be a subclass of BaseRetriever or a Runnable that returns
a list of documents. If a subclass of BaseRetriever, then it
is expected that an `input` key be passed in - this is what
is will be used to pass into the retriever. If this is NOT a
subclass of BaseRetriever, then all the inputs will be passed
into this runnable, meaning that runnable should take a dictionary
as input.
combine_docs_chain: Runnable that takes inputs and produces a string output.
The inputs to this will be any original inputs to this chain, a new
context key with the retrieved documents, and chat_history (if not present
in the inputs) with a value of `[]` (to easily enable conversational
retrieval.
Returns:
An LCEL Runnable. The Runnable return is a dictionary containing at the very
least a `context` and `answer` key.
Example:
```python
# pip install -U langchain langchain-openai
from langchain_openai import ChatOpenAI
from langchain_classic.chains.combine_documents import (
create_stuff_documents_chain,
)
from langchain_classic.chains import create_retrieval_chain
from langchain_classic import hub
retrieval_qa_chat_prompt = hub.pull("langchain-ai/retrieval-qa-chat")
model = ChatOpenAI()
retriever = ...
combine_docs_chain = create_stuff_documents_chain(
model, retrieval_qa_chat_prompt
)
retrieval_chain = create_retrieval_chain(retriever, combine_docs_chain)
retrieval_chain.invoke({"input": "..."})
```
"""
if not isinstance(retriever, BaseRetriever):
retrieval_docs: Runnable[dict, RetrieverOutput] = retriever
else:
retrieval_docs = (lambda x: x["input"]) | retriever
return (
RunnablePassthrough.assign(
context=retrieval_docs.with_config(run_name="retrieve_documents"),
).assign(answer=combine_docs_chain)
).with_config(run_name="retrieval_chain")
Domain
Subdomains
Functions
Dependencies
- langchain_core.retrievers
- langchain_core.runnables
- typing
Source
Frequently Asked Questions
What does retrieval.py do?
retrieval.py is a source file in the langchain codebase, written in python. It belongs to the AgentOrchestration domain, ClassicChains subdomain.
What functions are defined in retrieval.py?
retrieval.py defines 1 function(s): create_retrieval_chain.
What does retrieval.py depend on?
retrieval.py imports 3 module(s): langchain_core.retrievers, langchain_core.runnables, typing.
Where is retrieval.py in the architecture?
retrieval.py is located at libs/langchain/langchain_classic/chains/retrieval.py (domain: AgentOrchestration, subdomain: ClassicChains, directory: libs/langchain/langchain_classic/chains).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free