Spaces:
Sleeping
Sleeping
Update agent.py
Browse files
agent.py
CHANGED
@@ -187,41 +187,44 @@ def build_graph(provider: str = "google"):
|
|
187 |
# return {"messages": [sys_msg] + state["messages"] + [example_msg]}
|
188 |
|
189 |
def retriever(state: MessagesState):
|
190 |
-
"""Retriever node"""
|
191 |
current_question = state["messages"][-1].content
|
192 |
similar_doc = vector_store.similarity_search(current_question, k=1)[0]
|
193 |
page_content = similar_doc.page_content.strip()
|
194 |
|
195 |
-
# Versuche, die Antwort aus dem bekannten Format zu extrahieren
|
196 |
-
# Erwartetes Format:
|
197 |
-
# "Question : ...\n\nFinal answer : ..."
|
198 |
try:
|
199 |
lines = page_content.splitlines()
|
200 |
-
final_line = next(line for line in lines if
|
201 |
extracted_answer = final_line.split(":", 1)[1].strip()
|
|
|
202 |
return {
|
203 |
-
"messages": [
|
204 |
"should_end": True
|
205 |
}
|
206 |
-
except Exception
|
207 |
-
# Falls Parsing fehlschlägt, trotzdem sinnvoll weitermachen
|
208 |
return {
|
209 |
-
"messages": [
|
210 |
-
|
211 |
-
]
|
212 |
}
|
213 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
214 |
builder = StateGraph(MessagesState)
|
215 |
builder.add_node("retriever", retriever)
|
216 |
-
|
217 |
-
|
218 |
-
builder.
|
219 |
-
builder.
|
220 |
-
builder.add_conditional_edges(
|
221 |
-
"assistant",
|
222 |
-
tools_condition,
|
223 |
-
)
|
224 |
-
builder.add_edge("tools", "assistant")
|
225 |
|
226 |
# Compile graph
|
227 |
return builder.compile()
|
|
|
187 |
# return {"messages": [sys_msg] + state["messages"] + [example_msg]}
|
188 |
|
189 |
def retriever(state: MessagesState):
|
190 |
+
"""Retriever node – gibt direkt die extrahierte Antwort zurück"""
|
191 |
current_question = state["messages"][-1].content
|
192 |
similar_doc = vector_store.similarity_search(current_question, k=1)[0]
|
193 |
page_content = similar_doc.page_content.strip()
|
194 |
|
|
|
|
|
|
|
195 |
try:
|
196 |
lines = page_content.splitlines()
|
197 |
+
final_line = next(line for line in lines if "final answer" in line.lower())
|
198 |
extracted_answer = final_line.split(":", 1)[1].strip()
|
199 |
+
|
200 |
return {
|
201 |
+
"messages": [{"type": "system", "content": extracted_answer}],
|
202 |
"should_end": True
|
203 |
}
|
204 |
+
except Exception:
|
|
|
205 |
return {
|
206 |
+
"messages": [{"type": "system", "content": "Retriever error: no answer found."}],
|
207 |
+
"should_end": True
|
|
|
208 |
}
|
209 |
|
210 |
+
# builder = StateGraph(MessagesState)
|
211 |
+
#builder.add_node("retriever", retriever)
|
212 |
+
#builder.add_node("assistant", assistant)
|
213 |
+
#builder.add_node("tools", ToolNode(tools))
|
214 |
+
#builder.add_edge(START, "retriever")
|
215 |
+
#builder.add_edge("retriever", "assistant")
|
216 |
+
#builder.add_conditional_edges(
|
217 |
+
# "assistant",
|
218 |
+
# tools_condition,
|
219 |
+
#)
|
220 |
+
#builder.add_edge("tools", "assistant")
|
221 |
+
|
222 |
builder = StateGraph(MessagesState)
|
223 |
builder.add_node("retriever", retriever)
|
224 |
+
|
225 |
+
# Retriever ist Start und Endpunkt
|
226 |
+
builder.set_entry_point("retriever")
|
227 |
+
builder.set_finish_point("retriever")
|
|
|
|
|
|
|
|
|
|
|
228 |
|
229 |
# Compile graph
|
230 |
return builder.compile()
|