成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用LangChain和LangGraph大幅提升RAG效果

開發 前端
現在,當處理現實世界的問題時,一個常見的問題是希望找到介于鏈和代理之間的解決方案。即不像鏈那樣硬編碼,但也不像代理那樣完全由LLM驅動。

一、簡介

LangGraph是LangChain、LangServe和LangSmith系列的最新成員,旨在使用LLM構建生成式人工智能應用程序。請記住,所有這些都是獨立的包,必須單獨進行pip安裝。

在深入學習LangGraph之前,需要了解LangChain的兩個主要概念。

1. 鏈:圍繞LLM編寫的程序,用于執行任務,例如自動SQL編寫或NER提取鏈等。請注意,鏈不能用于任何其他任務(甚至不能用于一般用例),如果嘗試這樣做,可能會損壞鏈。鏈中要遵循的步驟是預定義的,不可靈活調整。

2. 代理:鏈的更加靈活版本,代理通常是啟用第三方工具(例如谷歌搜索、YouTube)的LLM,由LLM本身決定下一步如何解決給定的查詢。

現在,當處理現實世界的問題時,一個常見的問題是希望找到介于鏈和代理之間的解決方案。即不像鏈那樣硬編碼,但也不像代理那樣完全由LLM驅動。

二、LangGraph

LangGraph是以LangChain為核心,用于創建工作流程中的循環圖的工具。因此,我們假設以下示例:

你希望在知識庫上搭建一個基于RAG的檢索系統。現在,你希望引入這樣一種情況:如果RAG的輸出未滿足特定質量要求,代理/鏈應該再次檢索數據,但這次是自行更改提示。并且重復此過程,直到達到質量閾值為止。

使用LangGraph可以實現這種循環邏輯。這只是一個示例,使用LangGraph還可以做更多事情。

注:可以將其視為向鏈中引入循環邏輯,使其成為循環鏈。

  • LangGraph對于構建Autogen或MetaGPT等多代理應用程序至關重要。

顧名思義,LangGraph具有一般圖形所具有的所有組件,例如節點、邊等,接下來通過一個示例來了解。

三、使用LangGraph改善RAG

在此示例中,希望將RAG系統在數據庫中的最終輸出減少到不超過30個字符。如果輸出長度大于30個字符,則希望引入循環,使用不同的提示再次嘗試,直到長度小于30個字符為止。這是一個演示目的的基本邏輯。你甚至可以實現復雜的邏輯來改善RAG結果。

我們將創建的圖形如下所示。

圖片圖片

此處使用的版本為 langchain===0.0.349, openai===1.3.8, langgraph===0.0.26。

3.1 首先,讓我們導入重要的內容并初始化LLM。這里使用的是OpenAI API,但你也可以使用其他LLM。

from typing import Dict, TypedDict, Optional
from langgraph.graph import StateGraph, END
from langchain.vectorstores import Chroma
from langchain.chains import RetrievalQA
from langchain.llms import OpenAI
from langchain.embeddings.openai import OpenAIEmbeddings

llm = OpenAI(openai_api_key='your API')

接下來,我們將定義一個StateGraph。

class GraphState(TypedDict):
    question: Optional[str] = None
    classification: Optional[str] = None
    response: Optional[str] = None
    length: Optional[int] = None
    greeting: Optional[str] = None

workflow = StateGraph(GraphState)

什么是StateGraph?

StateGraph是任何LangGraph流程的核心,它存儲了在執行工作流程時我們將存儲的各種變量的狀態。在本例中,我們有5個變量,其值在執行圖形時將進行更新,并將與所有邊和節點共享。

3.2 接下來,讓我們從現有向量數據庫中初始化一個RAG檢索鏈。代碼已在以下視頻中進行了解釋。

def retriever_qa_creation():
        embeddings = OpenAIEmbeddings()
        db = Chroma(embedding_functinotallow=embeddings,persist_directory='/database',collection_name='details')
        qa = RetrievalQA.from_chain_type(llm=llm, chain_type="stuff", retriever=db.as_retriever())
        return qa

rag_chain = retriever_qa_creation()

3.3 接下來,我們將向該圖形添加節點。

def classify(question):
    return llm("classify intent of given input as greeting or not_greeting. Output just the class.Input:{}".format(question)).strip()

def classify_input_node(state):
    question = state.get('question', '').strip()
    classification = classify(question) 
    return {"classification": classification}

def handle_greeting_node(state):
    return {"greeting": "Hello! How can I help you today?"}

def handle_RAG(state):
    question = state.get('question', '').strip()
    prompt = question
    if state.get("length")<30:
         search_result = rag_chain.run(prompt)
    else:
         search_result = rag_chain.run(prompt+'. Return total count only.')

    return {"response": search_result,"length":len(search_result)}


def bye(state):
    return{"greeting":"The graph has finished"}

workflow.add_node("classify_input", classify_input_node)
workflow.add_node("handle_greeting", handle_greeting_node)
workflow.add_node("handle_RAG", handle_RAG)
workflow.add_node("bye", bye)

這需要一些解釋。

  • 每個節點都是一個Python函數,它可以:

①讀取任何狀態變量。

②更新任何狀態變量。在這種情況下,每個節點的返回函數都會更新某個或某些狀態變量的狀態/值。

  • 使用state.get()來讀取任何狀態變量。
  • handle_RAG節點可以幫助我們實現我們希望的循環自定義邏輯。如果輸出的長度<30,則使用提示符A;否則使用提示符B。對于第一種情況(當RAG節點尚未執行時),我們將傳遞length=0,并提供一個提示。

3.4 接下來,我們將添加入口點和邊緣。

workflow.set_entry_point("classify_input")
workflow.add_edge('handle_greeting', END)
workflow.add_edge('bye', END)

在上述的代碼片段中,

  • 我們向圖中添加了一個入口點,即無論輸入提示是什么,都會執行的第一個節點函數。
  • A節點和B節點之間的邊界定義了在節點A之后執行節點B。在這種情況下,如果在我們的工作流中出現了handle_greeting或bye,則圖形應該END(一個特殊的節點來終止工作流)。

3.5 接下來,讓我們添加條件邊界。

def decide_next_node(state):
    return "handle_greeting" if state.get('classification') == "greeting" else "handle_RAG"

def check_RAG_length(state):
    return "handle_RAG" if state.get("length")>30 else "bye"

workflow.add_conditional_edges(
    "classify_input",
    decide_next_node,
    {
        "handle_greeting": "handle_greeting",
        "handle_RAG": "handle_RAG"
    }
)

workflow.add_conditional_edges(
    "handle_RAG",
    check_RAG_length,
    {
        "bye": "bye",
        "handle_RAG": "handle_RAG"
    }
)

條件邊界可根據條件(例如if-else)在兩個節點之間進行選擇。在創建的兩個條件邊界中:

第一個條件邊界

當遇到classify_input時,根據decide_next_node函數的輸出選擇handle_greeting或handle_RAG。

第二個條件邊界

如果遇到handle_RAG,則根據check_RAG_length條件選擇handle_RAG或bye。

3.6 編譯并調用提示。初始時保持length變量設置為0。

app = workflow.compile()
app.invoke({'question':'Mehul developed which projects?','length':0})
# 輸出
{'question': 'Mehul developed which projects?',
 'classification': 'not_greeting',
 'response': ' 4',
 'length': 2,
 'greeting': 'The graph has finished'}

對于上述提示,圖形流程如下所示:

classify_input: 情感將為not_greeting。

由于第一個條件邊界,移至handle_RAG。

由于length=0,使用第一個提示并檢索答案(總長度將大于30)。

由于第二個條件邊界,再次移至handle_RAG。

由于length>30,使用第二個提示符。

由于第二個條件邊界,移至bye。

END。

如果沒有使用LangGraph:

rag_chain.run("Mehul developed which projects?")

# 輸出
"Mehul developed projects like ABC, XYZ, QWERTY. Not only these, he has major contribution in many other projects as well at OOO organization"

3.7 下一個輸入。

app.invoke({'question':'Hello bot','length':0})

# 輸出
{'question': 'Hello bot',
 'classification': 'greeting',
 'response': None,
 'length': 0,
 'greeting': 'Hello! How can I help you today?'}

這里的流程會更簡單。

classify_input: 情感將為greeting。

由于第一個條件邊界,移至handle_greeting。

END。

雖然我在這里應用的條件相當簡單,但通過添加更復雜的條件,這個框架可以很容易地用于改進你的結果。

責任編輯:武曉燕 來源: Python學研大本營
相關推薦

2024-08-06 08:43:17

2025-06-10 04:00:00

RAGRRFReranker

2025-06-06 03:11:00

LangGraphDeepSeek-RRAG

2024-04-29 18:55:16

緩存Spring性能

2023-04-10 09:15:25

Vite 4.3SWC 插件

2025-05-22 06:48:50

RAGAI應用開發框架DeepSeek

2024-10-07 08:49:25

2023-11-09 08:46:24

2025-06-17 01:00:00

Dify智能體RAG

2020-02-03 13:50:17

Windows 10Windows技巧

2023-11-26 09:04:10

Vue性能

2022-12-27 13:36:39

審計工作人工智能

2009-06-28 22:55:00

SAN惠普存儲

2023-11-23 08:00:00

OpenAILangChain

2024-02-26 08:00:00

LangGraph大型語言模型人工智能

2024-08-06 10:07:15

2025-03-06 10:41:32

2024-05-22 09:38:25

2025-06-26 07:00:00

上下文工程AI智能體

2024-09-29 10:58:56

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久亚洲一区 | 一本色道精品久久一区二区三区 | 91视频国产精品 | 国产97人人超碰caoprom | 国产亚洲区 | 亚洲精品视频在线播放 | 狠狠色香婷婷久久亚洲精品 | 91精品国产手机 | 成人国产精品入口免费视频 | 午夜寂寞福利视频 | 色网站视频 | 欧美一级大片免费看 | 亚洲va国产日韩欧美精品色婷婷 | 精品视频一区二区三区在线观看 | 日韩三级在线观看 | 一级美国黄色片 | 国产电影一区二区在线观看 | 亚洲成人高清 | 午夜看看 | 亚洲欧美在线观看 | 久久五月婷 | 国产片一区二区三区 | 日韩一区二区三区在线视频 | 视频一区在线播放 | 性欧美xxxx | av中文在线 | 国产欧美一区二区三区在线看 | 欧美国产视频 | 在线免费观看欧美 | 日韩视频中文字幕 | 日韩欧美在线观看 | 国产欧美一区二区三区另类精品 | 仙人掌旅馆在线观看 | 丁香婷婷在线视频 | 成人国产精品久久久 | 日韩第一夜 | 黄色成人在线观看 | 久久99国产精品 | 成人激情视频在线观看 | 免费一级黄色录像 | 日韩中文视频 |