cross_encoder_rerank.py — langchain Source File
Architecture documentation for cross_encoder_rerank.py, a python file in the langchain codebase. 7 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 6749ef2d_df7f_33a1_7b95_8223dc91d794["cross_encoder_rerank.py"] 7aaf52d4_ee88_411e_980e_bc4beeeb30ad["operator"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> 7aaf52d4_ee88_411e_980e_bc4beeeb30ad cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7["collections.abc"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7 f3bc7443_c889_119d_0744_aacc3620d8d2["langchain_core.callbacks"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> f3bc7443_c889_119d_0744_aacc3620d8d2 c554676d_b731_47b2_a98f_c1c2d537c0aa["langchain_core.documents"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> c554676d_b731_47b2_a98f_c1c2d537c0aa 6e58aaea_f08e_c099_3cc7_f9567bfb1ae7["pydantic"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> 6e58aaea_f08e_c099_3cc7_f9567bfb1ae7 91721f45_4909_e489_8c1f_084f8bd87145["typing_extensions"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> 91721f45_4909_e489_8c1f_084f8bd87145 7762678a_b51d_63da_2237_7b27aa7c9ffa["langchain_classic.retrievers.document_compressors.cross_encoder"] 6749ef2d_df7f_33a1_7b95_8223dc91d794 --> 7762678a_b51d_63da_2237_7b27aa7c9ffa style 6749ef2d_df7f_33a1_7b95_8223dc91d794 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
from __future__ import annotations
import operator
from collections.abc import Sequence
from langchain_core.callbacks import Callbacks
from langchain_core.documents import BaseDocumentCompressor, Document
from pydantic import ConfigDict
from typing_extensions import override
from langchain_classic.retrievers.document_compressors.cross_encoder import (
BaseCrossEncoder,
)
class CrossEncoderReranker(BaseDocumentCompressor):
"""Document compressor that uses CrossEncoder for reranking."""
model: BaseCrossEncoder
"""CrossEncoder model to use for scoring similarity
between the query and documents."""
top_n: int = 3
"""Number of documents to return."""
model_config = ConfigDict(
arbitrary_types_allowed=True,
extra="forbid",
)
@override
def compress_documents(
self,
documents: Sequence[Document],
query: str,
callbacks: Callbacks | None = None,
) -> Sequence[Document]:
"""Rerank documents using CrossEncoder.
Args:
documents: A sequence of documents to compress.
query: The query to use for compressing the documents.
callbacks: Callbacks to run during the compression process.
Returns:
A sequence of compressed documents.
"""
scores = self.model.score([(query, doc.page_content) for doc in documents])
docs_with_scores = list(zip(documents, scores, strict=False))
result = sorted(docs_with_scores, key=operator.itemgetter(1), reverse=True)
return [doc for doc, _ in result[: self.top_n]]
Domain
Subdomains
Classes
Dependencies
- collections.abc
- langchain_classic.retrievers.document_compressors.cross_encoder
- langchain_core.callbacks
- langchain_core.documents
- operator
- pydantic
- typing_extensions
Source
Frequently Asked Questions
What does cross_encoder_rerank.py do?
cross_encoder_rerank.py is a source file in the langchain codebase, written in python. It belongs to the CoreAbstractions domain, Serialization subdomain.
What does cross_encoder_rerank.py depend on?
cross_encoder_rerank.py imports 7 module(s): collections.abc, langchain_classic.retrievers.document_compressors.cross_encoder, langchain_core.callbacks, langchain_core.documents, operator, pydantic, typing_extensions.
Where is cross_encoder_rerank.py in the architecture?
cross_encoder_rerank.py is located at libs/langchain/langchain_classic/retrievers/document_compressors/cross_encoder_rerank.py (domain: CoreAbstractions, subdomain: Serialization, directory: libs/langchain/langchain_classic/retrievers/document_compressors).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free