Yongkang ZOU
commited on
Commit
·
3fba19d
1
Parent(s):
547bea9
add retriever
Browse files- agent.py +38 -4
- requirements.txt +1 -0
agent.py
CHANGED
|
@@ -87,7 +87,8 @@ sys_msg = SystemMessage(content=system_prompt)
|
|
| 87 |
from langchain_openai import ChatOpenAI # ✅ 新增导入
|
| 88 |
|
| 89 |
def build_graph(provider: str = "groq"):
|
| 90 |
-
"""Build
|
|
|
|
| 91 |
if provider == "google":
|
| 92 |
llm = ChatGoogleGenerativeAI(model="gemini-2.0-flash", temperature=0)
|
| 93 |
elif provider == "groq":
|
|
@@ -106,21 +107,54 @@ def build_graph(provider: str = "groq"):
|
|
| 106 |
openai_key = os.getenv("OPENAI_API_KEY")
|
| 107 |
if not openai_key:
|
| 108 |
raise ValueError("OPENAI_API_KEY is not set.")
|
| 109 |
-
llm = ChatOpenAI(model="gpt-3.5-turbo", temperature=0, api_key=openai_key)
|
| 110 |
else:
|
| 111 |
raise ValueError("Invalid provider")
|
| 112 |
|
|
|
|
| 113 |
llm_with_tools = llm.bind_tools(tools)
|
| 114 |
|
| 115 |
def assistant(state: MessagesState):
|
| 116 |
return {"messages": [sys_msg] + [llm_with_tools.invoke(state["messages"])]}
|
| 117 |
|
| 118 |
-
#
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 119 |
builder = StateGraph(MessagesState)
|
|
|
|
| 120 |
builder.add_node("assistant", assistant)
|
| 121 |
builder.add_node("tools", ToolNode(tools))
|
| 122 |
|
| 123 |
-
builder.add_edge(START, "
|
|
|
|
|
|
|
|
|
|
|
|
|
| 124 |
builder.add_conditional_edges("assistant", tools_condition)
|
| 125 |
builder.add_edge("tools", "assistant")
|
| 126 |
|
|
|
|
| 87 |
from langchain_openai import ChatOpenAI # ✅ 新增导入
|
| 88 |
|
| 89 |
def build_graph(provider: str = "groq"):
|
| 90 |
+
"""Build LangGraph agent with QA retriever and tool-use fallback."""
|
| 91 |
+
# 初始化 LLM
|
| 92 |
if provider == "google":
|
| 93 |
llm = ChatGoogleGenerativeAI(model="gemini-2.0-flash", temperature=0)
|
| 94 |
elif provider == "groq":
|
|
|
|
| 107 |
openai_key = os.getenv("OPENAI_API_KEY")
|
| 108 |
if not openai_key:
|
| 109 |
raise ValueError("OPENAI_API_KEY is not set.")
|
| 110 |
+
llm = ChatOpenAI(model="gpt-3.5-turbo", temperature=0, api_key=openai_key)
|
| 111 |
else:
|
| 112 |
raise ValueError("Invalid provider")
|
| 113 |
|
| 114 |
+
# 工具绑定
|
| 115 |
llm_with_tools = llm.bind_tools(tools)
|
| 116 |
|
| 117 |
def assistant(state: MessagesState):
|
| 118 |
return {"messages": [sys_msg] + [llm_with_tools.invoke(state["messages"])]}
|
| 119 |
|
| 120 |
+
# ✅ 初始化 Supabase Retriever
|
| 121 |
+
SUPABASE_URL = os.getenv("SUPABASE_URL")
|
| 122 |
+
SUPABASE_KEY = os.getenv("SUPABASE_SERVICE_KEY")
|
| 123 |
+
supabase = create_client(SUPABASE_URL, SUPABASE_KEY)
|
| 124 |
+
|
| 125 |
+
embedding_model = HuggingFaceEmbeddings(model_name="sentence-transformers/all-mpnet-base-v2")
|
| 126 |
+
vectorstore = SupabaseVectorStore(
|
| 127 |
+
client=supabase,
|
| 128 |
+
embedding=embedding_model,
|
| 129 |
+
table_name="QA_db"
|
| 130 |
+
)
|
| 131 |
+
retriever = vectorstore.as_retriever(search_kwargs={"k": 1})
|
| 132 |
+
|
| 133 |
+
# ✅ Retriever 节点
|
| 134 |
+
def qa_retriever_node(state: MessagesState):
|
| 135 |
+
user_question = state["messages"][-1].content
|
| 136 |
+
docs = retriever.invoke(user_question)
|
| 137 |
+
if docs:
|
| 138 |
+
return {
|
| 139 |
+
"messages": state["messages"] + [AIMessage(content=docs[0].page_content)],
|
| 140 |
+
"__condition__": "complete"
|
| 141 |
+
}
|
| 142 |
+
return {
|
| 143 |
+
"messages": state["messages"],
|
| 144 |
+
"__condition__": "default"
|
| 145 |
+
}
|
| 146 |
+
|
| 147 |
+
# 构建图结构
|
| 148 |
builder = StateGraph(MessagesState)
|
| 149 |
+
builder.add_node("retriever", qa_retriever_node)
|
| 150 |
builder.add_node("assistant", assistant)
|
| 151 |
builder.add_node("tools", ToolNode(tools))
|
| 152 |
|
| 153 |
+
builder.add_edge(START, "retriever")
|
| 154 |
+
builder.add_conditional_edges("retriever", {
|
| 155 |
+
"default": "assistant",
|
| 156 |
+
"complete": None
|
| 157 |
+
})
|
| 158 |
builder.add_conditional_edges("assistant", tools_condition)
|
| 159 |
builder.add_edge("tools", "assistant")
|
| 160 |
|
requirements.txt
CHANGED
|
@@ -17,3 +17,4 @@ pymupdf
|
|
| 17 |
wikipedia
|
| 18 |
pgvector
|
| 19 |
python-dotenv
|
|
|
|
|
|
| 17 |
wikipedia
|
| 18 |
pgvector
|
| 19 |
python-dotenv
|
| 20 |
+
supabase
|