refactoring

This commit is contained in:
isaac hershenson
2024-08-07 14:48:27 -07:00
parent 9950d8e0ff
commit e156921b73
14 changed files with 125 additions and 7 deletions
-1
View File
@@ -2,4 +2,3 @@ OPENAI_API_KEY="..."
LANGCHAIN_API_KEY="..."
TAVILY_API_KEY="..."
ANTHROPIC_API_KEY="..."
PYTHONPATH="./my_agent"
+1 -1
View File
@@ -1,3 +1,3 @@
# Setup
Edit the `.env.example` file to create a proper `.env` file with your API keys. The only thing to copy over exactly is the `PYTHONPATH`, because without it LangGraph will not be able to find the `utils` module when you import it in `main.py`. If you wish to add more modules, just ensure that you add them to your `PYTHONPATH` environment variable.
Edit the `.env.example` file to create a proper `.env` file with your API keys.
@@ -0,0 +1,3 @@
from my_agent.utils.build_graph import workflow
graph = workflow.compile()
@@ -0,0 +1,3 @@
from my_other_agent.utils.build_graph import workflow
graph = workflow.compile()
@@ -0,0 +1,97 @@
from typing import TypedDict, Annotated, Sequence, Literal
from functools import lru_cache
from langchain_core.messages import BaseMessage
from langchain_anthropic import ChatAnthropic
from langchain_openai import ChatOpenAI
from langchain_community.tools.tavily_search import TavilySearchResults
from langgraph.prebuilt import ToolNode
from langgraph.graph import StateGraph, END, add_messages
tools = [TavilySearchResults(max_results=1)]
@lru_cache(maxsize=4)
def _get_model(model_name: str):
if model_name == "openai":
model = ChatOpenAI(temperature=0, model_name="gpt-4o")
elif model_name == "anthropic":
model = ChatAnthropic(temperature=0, model_name="claude-3-sonnet-20240229")
else:
raise ValueError(f"Unsupported model type: {model_name}")
model = model.bind_tools(tools)
return model
class AgentState(TypedDict):
messages: Annotated[Sequence[BaseMessage], add_messages]
# Define the function that determines whether to continue or not
def should_continue(state):
messages = state["messages"]
last_message = messages[-1]
# If there are no tool calls, then we finish
if not last_message.tool_calls:
return "end"
# Otherwise if there is, we continue
else:
return "continue"
system_prompt = """Be a helpful assistant"""
# Define the function that calls the model
def call_model(state, config):
messages = state["messages"]
messages = [{"role": "system", "content": system_prompt}] + messages
model_name = config.get('configurable', {}).get("model_name", "anthropic")
model = _get_model(model_name)
response = model.invoke(messages)
# We return a list, because this will get added to the existing list
return {"messages": [response]}
# Define the function to execute tools
tool_node = ToolNode(tools)
# Define the config
class GraphConfig(TypedDict):
model_name: Literal["anthropic", "openai"]
# Define a new graph
workflow = StateGraph(AgentState, config_schema=GraphConfig)
# Define the two nodes we will cycle between
workflow.add_node("agent", call_model)
workflow.add_node("action", tool_node)
# Set the entrypoint as `agent`
# This means that this node is the first one called
workflow.set_entry_point("agent")
# We now add a conditional edge
workflow.add_conditional_edges(
# First, we define the start node. We use `agent`.
# This means these are the edges taken after the `agent` node is called.
"agent",
# Next, we pass in the function that will determine which node is called next.
should_continue,
# Finally we pass in a mapping.
# The keys are strings, and the values are other nodes.
# END is a special node marking that the graph should finish.
# What will happen is we will call `should_continue`, and then the output of that
# will be matched against the keys in this mapping.
# Based on which one it matches, that node will then be called.
{
# If `tools`, then we call the tool node.
"continue": "action",
# Otherwise we finish.
"end": END,
},
)
# We now add a normal edge from `tools` to `agent`.
# This means that after `tools` is called, `agent` node is called next.
workflow.add_edge("action", "agent")
+18
View File
@@ -0,0 +1,18 @@
[tool.poetry]
name = "my-other-agent"
version = "0.0.1"
description = "An excellent agent build for LangGraph cloud."
authors = ["Polly the parrot <1223+polly@users.noreply.github.com>"]
license = "MIT"
[tool.poetry.dependencies]
python = ">=3.9.0,<3.13"
langgraph = "^0.1.7"
langchain-openai = ">=0.1.17"
langchain-anthropic = ">=0.1.20"
langchain-community = ">=0.2.11"
[build-system]
requires = ["poetry-core"]
build-backend = "poetry.core.masonry.api"
+3 -2
View File
@@ -1,7 +1,8 @@
{
"dependencies": ["."],
"dependencies": ["./all_projects/my_project/project_one","./all_projects/project_two"],
"graphs": {
"my_fantastic_agent": "./my_agent/main.py:graph"
"my_first_agent": "./all_projects/my_project/project_one/my_agent/main.py:graph",
"my_second_agent": "./all_projects/project_two/my_other_agent/main.py:graph"
},
"env": "./.env"
}
-3
View File
@@ -1,3 +0,0 @@
from utils.build_graph import workflow
graph = workflow.compile()