Cohere Rerank on LangChain (Integration Guide)

Cohere supports various integrations with LangChain, a large language model (LLM) framework which allows you to quickly create applications based on Cohere’s models. This doc will guide you through how to leverage Rerank with LangChain.

Prerequisites

Running Cohere Rerank with LangChain doesn’t require many prerequisites, consult the top-level document for more information.

Cohere ReRank with LangChain

To use Cohere’s rerank functionality with LangChain, start with instantiating a CohereRerank object as follows: cohere_rerank = CohereRerank(cohere_api_key="{API_KEY}").

You can then use it with LangChain retrievers, embeddings, and RAG. The example below uses the vector DB chroma, for which you will need to install pip install chromadb. Other vector DB’s from this list can also be used.

PYTHON
1from langchain.retrievers import ContextualCompressionRetriever
2from langchain_cohere import CohereEmbeddings
3from langchain_cohere import ChatCohere
4from langchain_cohere import CohereRerank, CohereRagRetriever
5from langchain.text_splitter import CharacterTextSplitter
6from langchain_community.document_loaders import TextLoader
7from langchain_community.vectorstores import Chroma
8from langchain_community.document_loaders import WebBaseLoader
9
10user_query = "what is Cohere Toolkit?"
11
12# Define the Cohere LLM
13llm = ChatCohere(
14 cohere_api_key="COHERE_API_KEY", model="command-r-plus-08-2024"
15)
16
17# Define the Cohere embedding model
18embeddings = CohereEmbeddings(
19 cohere_api_key="COHERE_API_KEY", model="embed-english-light-v3.0"
20)
21
22# Load text files and split into chunks, you can also use data gathered elsewhere in your application
23raw_documents = WebBaseLoader(
24 "https://docs.cohere.com/docs/cohere-toolkit"
25).load()
26text_splitter = CharacterTextSplitter(
27 chunk_size=1000, chunk_overlap=0
28)
29documents = text_splitter.split_documents(raw_documents)
30
31# Create a vector store from the documents
32db = Chroma.from_documents(documents, embeddings)
33
34# Create Cohere's reranker with the vector DB using Cohere's embeddings as the base retriever
35reranker = CohereRerank(
36 cohere_api_key="COHERE_API_KEY", model="rerank-english-v3.0"
37)
38
39compression_retriever = ContextualCompressionRetriever(
40 base_compressor=reranker, base_retriever=db.as_retriever()
41)
42compressed_docs = compression_retriever.get_relevant_documents(
43 user_query
44)
45# Print the relevant documents from using the embeddings and reranker
46print(compressed_docs)
47
48# Create the cohere rag retriever using the chat model
49rag = CohereRagRetriever(llm=llm, connectors=[])
50docs = rag.get_relevant_documents(
51 user_query,
52 documents=compressed_docs,
53)
54# Print the documents
55print("Documents:")
56for doc in docs[:-1]:
57 print(doc.metadata)
58 print("\n\n" + doc.page_content)
59 print("\n\n" + "-" * 30 + "\n\n")
60# Print the final generation
61answer = docs[-1].page_content
62print("Answer:")
63print(answer)
64# Print the final citations
65citations = docs[-1].metadata["citations"]
66print("Citations:")
67print(citations)

Using LangChain on Private Deployments

You can use LangChain with privately deployed Cohere models. To use it, specify your model deployment URL in the base_url parameter.

PYTHON
1llm = CohereRerank(
2 base_url="<YOUR_DEPLOYMENT_URL>",
3 cohere_api_key="COHERE_API_KEY",
4 model="MODEL_NAME",
5)
Built with