2 Commits

Author SHA1 Message Date
ryan
033429798e Merge pull request 'RAG optimizations' (#12) from rc/langchain-migration into main
Reviewed-on: #12
2026-01-11 09:36:59 -05:00
Ryan Chen
733ffae8cf RAG optimizations 2026-01-11 09:36:36 -05:00
2 changed files with 23 additions and 17 deletions

View File

@@ -12,7 +12,6 @@ from .agents import main_agent
from .logic import ( from .logic import (
add_message_to_conversation, add_message_to_conversation,
get_conversation_by_id, get_conversation_by_id,
get_conversation_transcript,
rename_conversation, rename_conversation,
) )
from .models import ( from .models import (
@@ -43,22 +42,29 @@ async def query():
user=user, user=user,
) )
transcript = await get_conversation_transcript(user=user, conversation=conversation) # Build conversation history from recent messages (last 10 for context)
recent_messages = (
conversation.messages[-10:]
if len(conversation.messages) > 10
else conversation.messages
)
transcript_prompt = f"Here is the message transcript thus far {transcript}." messages_payload = [
prompt = f"""Answer the user in as if you were a cat named Simba. Don't act too catlike. Be assertive. {
{transcript_prompt if len(transcript) > 0 else ""} "role": "system",
Respond to this prompt: {query}""" "content": "You are a helpful cat assistant named Simba that understands veterinary terms. When there are questions to you specifically, they are referring to Simba the cat. Answer the user in as if you were a cat named Simba. Don't act too catlike. Be assertive.\n\nIMPORTANT: When users ask factual questions about Simba's health, medical history, veterinary visits, medications, weight, or any information that would be in documents, you MUST use the simba_search tool to retrieve accurate information before answering. Do not rely on general knowledge - always search the documents for factual questions.",
}
]
payload = { # Add recent conversation history
"messages": [ for msg in recent_messages[:-1]: # Exclude the message we just added
{ role = "user" if msg.speaker == "user" else "assistant"
"role": "system", messages_payload.append({"role": role, "content": msg.text})
"content": "You are a helpful cat assistant named Simba that understands veterinary terms. When there are questions to you specifically, they are referring to Simba the cat. Answer the user in as if you were a cat named Simba. Don't act too catlike. Be assertive.\n\nIMPORTANT: When users ask factual questions about Simba's health, medical history, veterinary visits, medications, weight, or any information that would be in documents, you MUST use the simba_search tool to retrieve accurate information before answering. Do not rely on general knowledge - always search the documents for factual questions.",
}, # Add current query
{"role": "user", "content": prompt}, messages_payload.append({"role": "user", "content": query})
]
} payload = {"messages": messages_payload}
response = await main_agent.ainvoke(payload) response = await main_agent.ainvoke(payload)
message = response.get("messages", [])[-1].content message = response.get("messages", [])[-1].content

View File

@@ -8,7 +8,7 @@ from langchain_text_splitters import RecursiveCharacterTextSplitter
from .fetchers import PaperlessNGXService from .fetchers import PaperlessNGXService
embeddings = OpenAIEmbeddings(model="text-embedding-3-large") embeddings = OpenAIEmbeddings(model="text-embedding-3-small")
vector_store = Chroma( vector_store = Chroma(
collection_name="simba_docs", collection_name="simba_docs",
@@ -61,7 +61,7 @@ async def index_documents():
async def query_vector_store(query: str): async def query_vector_store(query: str):
retrieved_docs = vector_store.similarity_search(query, k=2) retrieved_docs = await vector_store.asimilarity_search(query, k=2)
serialized = "\n\n".join( serialized = "\n\n".join(
(f"Source: {doc.metadata}\nContent: {doc.page_content}") (f"Source: {doc.metadata}\nContent: {doc.page_content}")
for doc in retrieved_docs for doc in retrieved_docs