Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Langgraph Agent - ML4Bio #280

Draft
wants to merge 146 commits into
base: main
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
146 commits
Select commit Hold shift + click to select a range
90a2e5e
adding minimal on_new_PR webhook for Github lil-jr-dev
KastanDay Aug 11, 2023
2e8d3ff
debug env vars
KastanDay Aug 11, 2023
78bfe38
fixed env vars
KastanDay Aug 11, 2023
c048e09
refactor github initialization
KastanDay Aug 11, 2023
78d7e7c
fix repo name
KastanDay Aug 11, 2023
bebd6dc
fixing repo parsing from json
KastanDay Aug 11, 2023
2864486
fixing repo parsing from json
KastanDay Aug 11, 2023
7048df2
add functions for issues and PRs. Rework auth for GH Auth
KastanDay Aug 11, 2023
b44ce17
fix the issue vs issues spelling
KastanDay Aug 11, 2023
de4e67d
working on fixing issues
KastanDay Aug 11, 2023
1c306c1
fixing up the issue and comment handlers
KastanDay Aug 11, 2023
cc19161
fixing issue comments
KastanDay Aug 11, 2023
fd4bec6
fixing paylods
KastanDay Aug 11, 2023
78a2ed0
don't reply to own comments
KastanDay Aug 11, 2023
46472de
no inf loops, and responding to new issues should finally work
KastanDay Aug 11, 2023
18095bb
handle conditional JSON blobs better with .get()
KastanDay Aug 11, 2023
b20b60c
typo
KastanDay Aug 11, 2023
ad21acb
working responses to new Issues, new PRs and new comments on each
KastanDay Aug 11, 2023
5e30753
MAJOR push: adding agents that respond to new PRs and new Issues. No …
KastanDay Aug 11, 2023
7700e20
major push: first draft of working MVP. Create an issue -> get a PR
KastanDay Aug 12, 2023
5bc16f4
minor type fix
KastanDay Aug 12, 2023
b8c4f7a
set langchain to my own fork
KastanDay Aug 12, 2023
b1c55a0
set langchain to my own fork, with proper branch
KastanDay Aug 12, 2023
5ac47a2
adding bot for on-pr-comment hook
KastanDay Aug 12, 2023
390674a
add bot for issue comments, have an MVP for the WHOLE STACK now. woohoo!
KastanDay Aug 12, 2023
1543863
typo fix
KastanDay Aug 12, 2023
30b10de
add error messages as github comments
KastanDay Aug 12, 2023
a6cf7e1
fix branch name in new issue comment
KastanDay Aug 12, 2023
fa971e2
adding automatic retries to the GH agents on-comment runs
KastanDay Aug 12, 2023
b06520d
minor type fix
KastanDay Aug 12, 2023
691e170
refine bot retry mechanism
KastanDay Aug 12, 2023
f4dbd09
wonderful refactor of bot responsibilities. GH_Agent is now a more re…
KastanDay Aug 12, 2023
d4c69d8
spelling typo
KastanDay Aug 12, 2023
b982acf
spelling typo
KastanDay Aug 12, 2023
5022221
add traceback exception
KastanDay Aug 12, 2023
c737b4c
add traceback exception
KastanDay Aug 12, 2023
8fb51fb
improve traceback exception, improve branch handling
KastanDay Aug 14, 2023
9bbb688
adding run file so imports work
KastanDay Sep 20, 2023
772afbc
use relative imports, remove the need to update python path
KastanDay Sep 20, 2023
4bf7948
fix relative imports and failing VectorStoreRetriever import from lan…
KastanDay Sep 29, 2023
dbc10c5
major code cleanup, add langsmith tracing
KastanDay Oct 1, 2023
66fed91
Completed Setup UIUC.chat vectorstore retrievers for all the common t…
KastanDay Oct 11, 2023
bc37e20
add several bio packages as vectorstore retriever tools
KastanDay Oct 17, 2023
c4f146c
Plan and execute agent
rohan-uiuc Oct 18, 2023
fd3f5b0
Merge branch 'github_agent_webhooks' of github.com:UIUC-Chatbot/ai-ta…
rohan-uiuc Oct 18, 2023
3ea9ec3
Add support for Azure models, add LangSmith link to github comment, v…
KastanDay Nov 1, 2023
239d5ec
Major code cleanup, deleting old code. Added README.
KastanDay Nov 1, 2023
b5f65ac
Further code cleanup, and full implementation of LangSmith real-time …
KastanDay Nov 2, 2023
9654c05
Fixed the 'follow bot's progress in real time' link
KastanDay Nov 2, 2023
6f69756
utils code cleanup
KastanDay Nov 2, 2023
e19159a
Experimental: Adding newrelic logging, major railway.json change
KastanDay Nov 2, 2023
59e58a9
setup newrelic-admin before installing telemetry
KastanDay Nov 2, 2023
5fec929
Maybe it's just pip3?
KastanDay Nov 2, 2023
cd9a019
attempting to change the order of the build steps
KastanDay Nov 2, 2023
f937eec
moving newrelic phase into the phase
KastanDay Nov 2, 2023
34f1f8b
fix silly mistake of trying to run the program too early
KastanDay Nov 2, 2023
d27011b
python310 (instead of 3.8)
KastanDay Nov 2, 2023
d36951f
consolidate newrelic install command to original one-liner
KastanDay Nov 2, 2023
49887f2
INFRA ONLY, NO LOGS. attempt to add the license key better
KastanDay Nov 2, 2023
c489d8c
INFRA ONLY, NO LOGS
KastanDay Nov 2, 2023
12f02d3
INFRA ONLY, NO LOGS
KastanDay Nov 2, 2023
bb95ca5
Install worked... but infra staid 'unsupported'. trying to add back l…
KastanDay Nov 2, 2023
bc9dd6b
try to fix newrelic.ini path
KastanDay Nov 2, 2023
331a21b
try to fix newrelic.ini path v2
KastanDay Nov 2, 2023
2dd4431
try to fix newrelic.ini path v3
KastanDay Nov 2, 2023
e251c4b
try to fix newrelic.ini path v4
KastanDay Nov 2, 2023
ad0ba77
try to fix newrelic.ini path v5 -- very close, just removeing a doubl…
KastanDay Nov 2, 2023
bc33a90
Added custom code execution tool from autogen, integrated with plan&e…
rohan-uiuc Nov 2, 2023
4166236
Merge branch 'github_agent_webhooks' of github.com:UIUC-Chatbot/ai-ta…
rohan-uiuc Nov 2, 2023
616905f
change LangChain branch to our new internal Langchain fork
KastanDay Nov 2, 2023
133e9e2
add ray start --head to try to fix 'unable to start GCS' for ray
KastanDay Nov 2, 2023
e472d97
📜 update readme
KastanDay Nov 2, 2023
1417c5e
support custom langchain-experimental
KastanDay Nov 2, 2023
f58d232
fix langchain-experimental, and random log messages
KastanDay Nov 2, 2023
a67781b
2 spaces is the only way
KastanDay Nov 2, 2023
dcc1c91
Adding ability to fetch linked PRs from issues and vice-versa!
KastanDay Nov 3, 2023
abbaa08
First attempt at Dockerfile for code execution
KastanDay Nov 6, 2023
9b5db8b
Add cmd-line args to support Docker, add shell and filesystem tool
KastanDay Nov 6, 2023
2094625
Setting up docker image for each request (Issue/PR) (#133)
rohan-uiuc Nov 7, 2023
b69626a
WIP docker setup
rohan-uiuc Nov 8, 2023
5293f9b
Working docker setup
rohan-uiuc Nov 9, 2023
cdcec7c
Fix openai version
KastanDay Nov 7, 2023
be0d25f
adding langchainhub
KastanDay Nov 7, 2023
87f83f5
add MemGPT custom implementation plan
KastanDay Nov 14, 2023
4d0f5e3
Initial attempts at MemoryCallbacks
KastanDay Nov 14, 2023
7254d77
working M1 docker builds
KastanDay Nov 14, 2023
900a845
proper .env path in Dockerfile
KastanDay Nov 14, 2023
0900156
can't get .env from above Dockerfile... need to do in bash/python
KastanDay Nov 15, 2023
cbd9a7f
working docker builds
KastanDay Nov 15, 2023
c2cec4c
Changes for handling new comment opened
rohan-uiuc Nov 16, 2023
51e3d73
Improve Docker launching; much better image re-build on all code changes
KastanDay Nov 22, 2023
0964cc7
Revert to before reformat Docker utils @ 51e3d7373d8b412f468b61c275e…
KastanDay Nov 27, 2023
bc5054e
Replace Docker with E2B Sandbox for code and shell execution (#177)
KastanDay Dec 19, 2023
57eff15
langgraph experiment
minump Jan 22, 2024
c015c36
gitignore node modules
minump Jan 22, 2024
2be2b19
added to gitignore
minump Jan 26, 2024
0f2d9a8
removed custom file
minump Jan 26, 2024
41a25d4
add langgraph requirements
minump Jan 26, 2024
0dd9c98
use langgraph agent instead of ml4bio agent
minump Jan 26, 2024
da0106e
workflowAgnet with langgraph
minump Jan 26, 2024
40b4044
removed unwanted import
minump Jan 26, 2024
e10cb09
Add Trunk formatting, same as main branch. All files updated.
KastanDay Jan 29, 2024
432f5b1
Add requirements, beginning of prompt_function
KastanDay Jan 29, 2024
88aefdd
agentState not keeping track of intermediate steps
minump Feb 1, 2024
b8868a7
Updating requirements to make them compatible with langchain-openai==…
rohan-uiuc Feb 6, 2024
f549858
Major version updates: update reqs, update imports, fix e2b sandbox
KastanDay Feb 8, 2024
3da4f20
Clean up linting bugs
KastanDay Feb 8, 2024
104ba0d
changes to langggraph agent
minump Feb 12, 2024
59bce34
azureChat and OpenAIChat llm
minump Feb 12, 2024
099c991
Switch default model to Azure GPT-4-turbo-0125 better for coding
KastanDay Feb 14, 2024
effb850
fmt only
KastanDay Feb 14, 2024
27d3a9d
update requirements to install our fork of langchain-openai, not the …
KastanDay Feb 15, 2024
daab116
My test script for testing langgraph
KastanDay Feb 15, 2024
56aa9f3
demo notebook for replanning step
KastanDay Feb 15, 2024
1b1d339
Fix intermediate_steps double usage... add example of adding custom i…
KastanDay Feb 15, 2024
04a5a43
Integrating demo plan and execute notebook with existing agent
rohan-uiuc Feb 21, 2024
49b53f4
Changing function names since langchain has a regex validation for it.
rohan-uiuc Feb 21, 2024
d07d2ef
Updated test file for agent v2
rohan-uiuc Feb 22, 2024
88a898d
Updated the import to use the new agent and fixed typo in filename
rohan-uiuc Feb 22, 2024
cc7e845
Move github tool to Langchain_community repo, fix imports
KastanDay Feb 22, 2024
caaa7b7
minor prompt and variable changes
KastanDay Feb 22, 2024
4dd3547
Move to async endpoint, set max iterations to 100 (up from 25)
KastanDay Feb 22, 2024
154a4b7
gitignore
minump Mar 1, 2024
811d73a
lats test
minump Mar 1, 2024
7bfa51d
lats testing with separate planner and executor
minump Mar 11, 2024
586a86d
testing
minump Mar 15, 2024
2311c70
added r code run
minump Mar 21, 2024
ee2b12c
rcode e2b changes
minump Mar 22, 2024
9bac224
using langgraph agent v2
minump Jun 7, 2024
7e75879
updated requirements
minump Jun 7, 2024
9c02c56
Fix conflicting openai requirements
KastanDay Jun 14, 2024
3474e05
Trunk upgrade
KastanDay Jun 14, 2024
aab6681
Fix versions, add uv to pip install on Railway
KastanDay Jun 14, 2024
f57d7e5
Fix uv python version
KastanDay Jun 14, 2024
fce501b
Set VIRTUAL_ENV for uv
KastanDay Jun 14, 2024
32ed3a2
try uv --system for using pip without virtualenv
KastanDay Jun 14, 2024
25de90a
Upgrade uv for --system command added
KastanDay Jun 14, 2024
6960dfd
Upgrade uv for --system command added, use manual install instead of pip
KastanDay Jun 14, 2024
350912b
Give up on UV, sigh
KastanDay Jun 14, 2024
cc2c612
Comment out e2b codeintrepreter, deprecated
KastanDay Jun 14, 2024
504b48d
Add Flask[async] dep
KastanDay Jun 14, 2024
0a785df
Print payload so we can test locally
KastanDay Jun 14, 2024
4847a64
Add example payload for local testing
KastanDay Jun 14, 2024
6e24d64
Fully format all code using trunk
KastanDay Jun 14, 2024
ddb3128
Print payload so we can test locally
KastanDay Jun 14, 2024
41fce2c
Save payload to file
KastanDay Jun 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Integrating demo plan and execute notebook with existing agent
rohan-uiuc committed Feb 21, 2024
commit 04a5a4309787c6336106c608f950d169c234b5e4
146 changes: 146 additions & 0 deletions ai_ta_backend/agents/langrgraph_agent_v2.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
import getpass
import os
import platform
from typing import List, Tuple, Union, Annotated, TypedDict
from dotenv import load_dotenv
from langchain import hub
from langchain.agents import create_openai_functions_agent
from langchain_openai import AzureChatOpenAI, ChatOpenAI
from langchain.chains.openai_functions import create_structured_output_runnable, create_openai_fn_runnable
from langchain_core.prompts import ChatPromptTemplate
from langgraph.graph import StateGraph, END
from langgraph.prebuilt import create_agent_executor
from langchain_core.pydantic_v1 import BaseModel, Field
from langchain_core.messages import HumanMessage, BaseMessage
import operator

from ai_ta_backend.agents.tools import get_tools

load_dotenv(override=True)


class Plan(BaseModel):
"""Plan to follow in future"""
steps: List[str] = Field(description="different steps to follow, should be in sorted order")


class Response(BaseModel):
"""Response to user."""
response: str


class PlanExecute(TypedDict):
input: str
chat_history: list[BaseMessage]
plan: List[str]
past_steps: Annotated[List[Tuple], operator.add]
response: str


def get_user_info_string():
username = getpass.getuser()
current_working_directory = os.getcwd()
operating_system = platform.system()
default_shell = os.environ.get("SHELL")

return f"[User Info]\nName: {username}\nCWD: {current_working_directory}\nSHELL: {default_shell}\nOS: {operating_system}"


def get_llm():
if os.getenv('OPENAI_API_TYPE') == 'azure':
return AzureChatOpenAI(
azure_deployment="gpt-4-128k",
openai_api_version=os.getenv("AZURE_0125_MODEL_VERSION"),
temperature=0,
azure_endpoint=os.getenv("AZURE_0125_MODEL_ENDPOINT"),
openai_api_key=os.getenv("AZURE_0125_MODEL_API_KEY"),
)
else:
return ChatOpenAI(
model="gpt-4-turbo-preview",
temperature=0,
)


class WorkflowAgent:

def __init__(self, langsmith_run_id):
self.langsmith_run_id = langsmith_run_id
self.llm = get_llm()
self.tools = get_tools(langsmith_run_id)
self.planner_prompt = ChatPromptTemplate.from_template(
"""For the given objective, come up with a simple step by step plan. \
This plan should involve individual tasks, that if executed correctly will yield the correct answer. Do not add any superfluous steps. \
The result of the final step should be the final answer. Make sure that each step has all the information needed - do not skip steps.

{objective}""")
self.replanner_prompt = ChatPromptTemplate.from_template(
"""For the given objective, come up with a simple step by step plan. \
This plan should involve individual tasks, that if executed correctly will yield the correct answer. Do not add any superfluous steps. \
The result of the final step should be the final answer. Make sure that each step has all the information needed - do not skip steps.

Your objective was this:
{input}

Your original plan was this:
{plan}

You have currently done the follow steps:
{past_steps}

Update your plan accordingly. If no more steps are needed and you can return to the user, then respond with that. Otherwise, fill out the plan. Only add steps to the plan that still NEED to be done. Do not return previously done steps as part of the plan."""
)

self.agent_runnable = create_openai_functions_agent(self.llm, self.tools,
hub.pull("hwchase17/openai-functions-agent"))
self.agent_executor = create_agent_executor(self.agent_runnable, self.tools)
self.workflow = self.create_workflow()

def create_workflow(self):
workflow = StateGraph(PlanExecute)

async def execute_step(state: PlanExecute):
task = state["plan"][0]
agent_response = await self.agent_executor.ainvoke({"input": task, "chat_history": []})
return {"past_steps": (task, agent_response["agent_outcome"].return_values["output"])}

async def plan_step(state: PlanExecute):
planner = create_structured_output_runnable(Plan, self.llm, self.planner_prompt)
plan = await planner.ainvoke({"objective": state["input"]})
return {"plan": plan.steps}

async def replan_step(state: PlanExecute):
replanner = create_openai_fn_runnable([Plan, Response], self.llm, self.replanner_prompt)
output = await replanner.ainvoke(state)
if isinstance(output, Response):
return {"response": output.response}
else:
return {"plan": output.steps}

def should_end(state: PlanExecute):
if state["response"]:
return True
else:
return False

workflow.add_node("planner", plan_step)
workflow.add_node("agent", execute_step)
workflow.add_node("replan", replan_step)
workflow.set_entry_point("planner")
workflow.add_edge("planner", "agent")
workflow.add_edge("agent", "replan")
workflow.add_conditional_edges("replan", should_end, {True: END, False: "agent"}) #type: ignore

return workflow.compile()

async def run(self, input_prompt):
inputs = {"input": input_prompt}
async for event in self.workflow.astream(inputs, config={"recursion_limit": 50}):
for k, v in event.items():
if k != "__end__":
print(v)


# Example usage
# agent = WorkflowAgent()
# await agent.run("what is