parent
d5d9da1b5a
commit
351b322091
@ -0,0 +1,141 @@
|
||||
import subprocess
|
||||
|
||||
|
||||
from swarms import (
|
||||
Agent,
|
||||
Anthropic,
|
||||
GroupChat,
|
||||
GroupChatManager,
|
||||
tool,
|
||||
)
|
||||
|
||||
# Model
|
||||
llm = Anthropic(
|
||||
temperature=0.1,
|
||||
)
|
||||
|
||||
|
||||
# Tools
|
||||
@tool
|
||||
def terminal(
|
||||
code: str,
|
||||
):
|
||||
"""
|
||||
Run code in the terminal.
|
||||
|
||||
Args:
|
||||
code (str): The code to run in the terminal.
|
||||
|
||||
Returns:
|
||||
str: The output of the code.
|
||||
"""
|
||||
out = subprocess.run(
|
||||
code, shell=True, capture_output=True, text=True
|
||||
).stdout
|
||||
return str(out)
|
||||
|
||||
|
||||
@tool
|
||||
def browser(query: str):
|
||||
"""
|
||||
Search the query in the browser with the `browser` tool.
|
||||
|
||||
Args:
|
||||
query (str): The query to search in the browser.
|
||||
|
||||
Returns:
|
||||
str: The search results.
|
||||
"""
|
||||
import webbrowser
|
||||
|
||||
url = f"https://www.google.com/search?q={query}"
|
||||
webbrowser.open(url)
|
||||
return f"Searching for {query} in the browser."
|
||||
|
||||
|
||||
@tool
|
||||
def create_file(file_path: str, content: str):
|
||||
"""
|
||||
Create a file using the file editor tool.
|
||||
|
||||
Args:
|
||||
file_path (str): The path to the file.
|
||||
content (str): The content to write to the file.
|
||||
|
||||
Returns:
|
||||
str: The result of the file creation operation.
|
||||
"""
|
||||
with open(file_path, "w") as file:
|
||||
file.write(content)
|
||||
return f"File {file_path} created successfully."
|
||||
|
||||
|
||||
@tool
|
||||
def file_editor(file_path: str, mode: str, content: str):
|
||||
"""
|
||||
Edit a file using the file editor tool.
|
||||
|
||||
Args:
|
||||
file_path (str): The path to the file.
|
||||
mode (str): The mode to open the file in.
|
||||
content (str): The content to write to the file.
|
||||
|
||||
Returns:
|
||||
str: The result of the file editing operation.
|
||||
"""
|
||||
with open(file_path, mode) as file:
|
||||
file.write(content)
|
||||
return f"File {file_path} edited successfully."
|
||||
|
||||
|
||||
# Agent
|
||||
agent = Agent(
|
||||
agent_name="Devin",
|
||||
system_prompt=(
|
||||
"Autonomous agent that can interact with humans and other"
|
||||
" agents. Be Helpful and Kind. Use the tools provided to"
|
||||
" assist the user. Return all code in markdown format."
|
||||
),
|
||||
llm=llm,
|
||||
max_loops=1,
|
||||
autosave=False,
|
||||
dashboard=False,
|
||||
streaming_on=True,
|
||||
verbose=True,
|
||||
stopping_token="<DONE>",
|
||||
tools=[terminal, browser, file_editor, create_file],
|
||||
)
|
||||
|
||||
# Agent
|
||||
agent_two = Agent(
|
||||
agent_name="Devin Worker 2",
|
||||
system_prompt=(
|
||||
"Autonomous agent that can interact with humans and other"
|
||||
" agents. Be Helpful and Kind. Use the tools provided to"
|
||||
" assist the user. Return all code in markdown format."
|
||||
),
|
||||
llm=llm,
|
||||
max_loops=1,
|
||||
autosave=False,
|
||||
dashboard=False,
|
||||
streaming_on=True,
|
||||
verbose=True,
|
||||
stopping_token="<DONE>",
|
||||
tools=[terminal, browser, file_editor, create_file],
|
||||
)
|
||||
|
||||
|
||||
# Initialize the group chat
|
||||
group_chat = GroupChat(
|
||||
agents=[agent, agent_two],
|
||||
max_round=2,
|
||||
admin_name="Supreme Commander Kye",
|
||||
group_objective="Research everyone at Goldman Sachs",
|
||||
)
|
||||
|
||||
# Initialize the group chat manager
|
||||
manager = GroupChatManager(groupchat=group_chat, selector=agent)
|
||||
|
||||
# Run the group chat manager on a task
|
||||
out = manager("Generate a 10,000 word blog on health and wellness.")
|
||||
print(out)
|
@ -1,173 +0,0 @@
|
||||
import logging
|
||||
|
||||
from swarms.structs.base_structure import BaseStructure
|
||||
|
||||
|
||||
class GraphWorkflow(BaseStructure):
|
||||
"""
|
||||
Represents a graph-based workflow structure.
|
||||
|
||||
Attributes:
|
||||
graph (dict): A dictionary representing the nodes and edges of the graph.
|
||||
entry_point (str): The name of the entry point node in the graph.
|
||||
|
||||
Methods:
|
||||
add(node, node_value): Adds a node to the graph with the specified value.
|
||||
start(node_name): Sets the starting node for the workflow.
|
||||
connect(from_node, to_node): Connects two nodes in the graph.
|
||||
set_entry_point(node_name): Sets the entry point node for the workflow.
|
||||
add_edge(from_node, to_node): Adds an edge between two nodes in the graph.
|
||||
add_conditional_edges(from_node, condition, edge_dict): Adds conditional edges from a node to multiple nodes based on a condition.
|
||||
run(): Runs the workflow and returns the graph.
|
||||
|
||||
Examples:
|
||||
>>> from swarms.structs import GraphWorkflow
|
||||
>>> graph = GraphWorkflow()
|
||||
>>> graph.add("start", "Start")
|
||||
>>> graph.add("end", "End")
|
||||
>>> graph.start("start")
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.graph = {}
|
||||
self.entry_point = None
|
||||
|
||||
def add(self, node, node_value):
|
||||
"""
|
||||
Adds a node to the graph with the specified value.
|
||||
|
||||
Args:
|
||||
node (str): The name of the node.
|
||||
node_value (str): The value of the node.
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
self.graph[node] = {"value": node_value, "edges": {}}
|
||||
logging.info(f"Added node: {node}")
|
||||
|
||||
def start(self, node_name):
|
||||
"""
|
||||
Sets the starting node for the workflow.
|
||||
|
||||
Args:
|
||||
node_name (str): The name of the starting node.
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
self._check_node_exists(node_name)
|
||||
|
||||
def connect(self, from_node, to_node):
|
||||
"""
|
||||
Connects two nodes in the graph.
|
||||
|
||||
Args:
|
||||
from_node (str): The name of the source node.
|
||||
to_node (str): The name of the target node.
|
||||
|
||||
Returns:
|
||||
None
|
||||
"""
|
||||
self._check_node_exists(from_node, to_node)
|
||||
|
||||
def set_entry_point(self, node_name):
|
||||
"""
|
||||
Sets the entry point node for the workflow.
|
||||
|
||||
Args:
|
||||
node_name (str): The name of the entry point node.
|
||||
|
||||
Returns:
|
||||
None
|
||||
|
||||
Raises:
|
||||
ValueError: If the specified node does not exist in the graph.
|
||||
"""
|
||||
if node_name is self.graph:
|
||||
self.entry_point = node_name
|
||||
else:
|
||||
raise ValueError("Node does not exist in graph")
|
||||
|
||||
def add_edge(self, from_node, to_node):
|
||||
"""
|
||||
Adds an edge between two nodes in the graph.
|
||||
|
||||
Args:
|
||||
from_node (str): The name of the source node.
|
||||
to_node (str): The name of the target node.
|
||||
|
||||
Returns:
|
||||
None
|
||||
|
||||
Raises:
|
||||
ValueError: If either the source or target node does not exist in the graph.
|
||||
"""
|
||||
if from_node in self.graph and to_node in self.graph:
|
||||
self.graph[from_node]["edges"][to_node] = "edge"
|
||||
else:
|
||||
raise ValueError("Node does not exist in graph")
|
||||
|
||||
def add_conditional_edges(self, from_node, condition, edge_dict):
|
||||
"""
|
||||
Adds conditional edges from a node to multiple nodes based on a condition.
|
||||
|
||||
Args:
|
||||
from_node (str): The name of the source node.
|
||||
condition: The condition for the conditional edges.
|
||||
edge_dict (dict): A dictionary mapping condition values to target nodes.
|
||||
|
||||
Returns:
|
||||
None
|
||||
|
||||
Raises:
|
||||
ValueError: If the source node or any of the target nodes do not exist in the graph.
|
||||
"""
|
||||
if from_node in self.graph:
|
||||
for condition_value, to_node in edge_dict.items():
|
||||
if to_node in self.graph:
|
||||
self.graph[from_node]["edges"][to_node] = condition
|
||||
else:
|
||||
raise ValueError("Node does not exist in graph")
|
||||
else:
|
||||
raise ValueError(f"Node {from_node} does not exist in graph")
|
||||
|
||||
def run(self):
|
||||
"""
|
||||
Runs the workflow and returns the graph.
|
||||
|
||||
Returns:
|
||||
dict: The graph representing the nodes and edges.
|
||||
|
||||
Raises:
|
||||
ValueError: If the entry point is not set.
|
||||
"""
|
||||
if self.entry_point is None:
|
||||
raise ValueError("Entry point not set")
|
||||
return self.graph
|
||||
|
||||
def _check_node_exists(self, node_name):
|
||||
"""Checks if a node exists in the graph.
|
||||
|
||||
Args:
|
||||
node_name (_type_): _description_
|
||||
|
||||
Raises:
|
||||
ValueError: _description_
|
||||
"""
|
||||
if node_name not in self.graph:
|
||||
raise ValueError(f"Node {node_name} does not exist in graph")
|
||||
|
||||
def _check_nodes_exist(self, from_node, to_node):
|
||||
"""
|
||||
Checks if the given from_node and to_node exist in the graph.
|
||||
|
||||
Args:
|
||||
from_node: The starting node of the edge.
|
||||
to_node: The ending node of the edge.
|
||||
|
||||
Raises:
|
||||
NodeNotFoundError: If either from_node or to_node does not exist in the graph.
|
||||
"""
|
||||
self._check_node_exists(from_node)
|
||||
self._check_node_exists(to_node)
|
Loading…
Reference in new issue