parent
072f129d85
commit
a01711fd23
@ -1,132 +1,80 @@
|
|||||||
from dataclass import dataclass, field
|
from dataclasses import dataclass, field
|
||||||
|
from typing import (
|
||||||
|
Any,
|
||||||
|
Callable,
|
||||||
|
Dict,
|
||||||
|
List,
|
||||||
|
Optional,
|
||||||
|
Sequence,
|
||||||
|
Union,
|
||||||
|
)
|
||||||
|
|
||||||
from swarms.structs.agent import Agent
|
from swarms.structs.agent import Agent
|
||||||
from typing import Optional
|
|
||||||
from typing import List, Dict, Any, Sequence
|
|
||||||
|
|
||||||
|
|
||||||
|
# Define a generic Task that can handle different types of callable objects
|
||||||
@dataclass
|
@dataclass
|
||||||
class Task:
|
class Task:
|
||||||
"""
|
"""
|
||||||
Task is a unit of work that can be executed by a set of agents.
|
Task class for running a task in a sequential workflow.
|
||||||
|
|
||||||
A task is defined by a task name and a set of agents that can execute the task.
|
|
||||||
The task can also have a set of dependencies, which are the names of other tasks
|
|
||||||
that must be executed before this task can be executed.
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
id (str): The name of the task.
|
description (str): The description of the task.
|
||||||
description (Optional[str]): A description of the task.
|
agent (Union[Callable, Agent]): The model or agent to execute the task.
|
||||||
task (str): The name of the task.
|
args (List[Any]): Additional arguments to pass to the task execution.
|
||||||
result (Any): The result of the task.
|
kwargs (Dict[str, Any]): Additional keyword arguments to pass to the task execution.
|
||||||
agents (Sequence[Agent]): A list of agents that can execute the task.
|
result (Any): The result of the task execution.
|
||||||
dependencies (List[str], optional): A list of task names that must be executed before this task can be executed. Defaults to [].
|
history (List[Any]): The history of the task execution.
|
||||||
args (List[Any], optional): A list of arguments to pass to the agents. Defaults to field(default_factory=list).
|
|
||||||
kwargs (List[Any], optional): A list of keyword arguments to pass to the agents. Defaults to field(default_factory=list).
|
|
||||||
|
|
||||||
Methods:
|
Methods:
|
||||||
execute: Executes the task by passing the results of the parent tasks to the agents.
|
execute: Execute the task.
|
||||||
|
|
||||||
Examples:
|
|
||||||
import os
|
|
||||||
from swarms.models import OpenAIChat
|
|
||||||
from swarms.structs import Agent
|
|
||||||
from swarms.structs.sequential_workflow import SequentialWorkflow
|
|
||||||
from dotenv import load_dotenv
|
|
||||||
|
|
||||||
load_dotenv()
|
|
||||||
|
|
||||||
# Load the environment variables
|
|
||||||
api_key = os.getenv("OPENAI_API_KEY")
|
|
||||||
|
|
||||||
|
|
||||||
# Initialize the language agent
|
|
||||||
llm = OpenAIChat(
|
|
||||||
openai_api_key=api_key,
|
|
||||||
temperature=0.5,
|
|
||||||
max_tokens=3000,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
# Initialize the agent with the language agent
|
|
||||||
agent1 = Agent(llm=llm, max_loops=1)
|
|
||||||
|
|
||||||
# Create another agent for a different task
|
|
||||||
agent2 = Agent(llm=llm, max_loops=1)
|
|
||||||
|
|
||||||
# Create the workflow
|
|
||||||
workflow = SequentialWorkflow(max_loops=1)
|
|
||||||
|
|
||||||
# Add tasks to the workflow
|
Examples:
|
||||||
workflow.add(
|
>>> from swarms.structs import Task, Agent
|
||||||
agent1, "Generate a 10,000 word blog on health and wellness.",
|
>>> from swarms.models import OpenAIChat
|
||||||
)
|
>>> agent = Agent(llm=OpenAIChat(openai_api_key=""), max_loops=1, dashboard=False)
|
||||||
|
>>> task = Task(description="What's the weather in miami", agent=agent)
|
||||||
# Suppose the next task takes the output of the first task as input
|
>>> task.execute()
|
||||||
workflow.add(
|
>>> task.result
|
||||||
agent2, "Summarize the generated blog",
|
|
||||||
)
|
|
||||||
|
|
||||||
# Run the workflow
|
|
||||||
workflow.run()
|
|
||||||
|
|
||||||
# Output the results
|
|
||||||
for task in workflow.tasks:
|
|
||||||
print(f"Task: {task.description}, Result: {task.result}")
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(
|
description: str
|
||||||
self,
|
agent: Union[Callable, Agent]
|
||||||
id: str,
|
args: List[Any] = field(default_factory=list)
|
||||||
description: Optional[str],
|
kwargs: Dict[str, Any] = field(default_factory=dict)
|
||||||
task: str,
|
result: Any = None
|
||||||
result: Any,
|
history: List[Any] = field(default_factory=list)
|
||||||
agents: Sequence[Agent],
|
# logger = logging.getLogger(__name__)
|
||||||
dependencies: List[str] = [],
|
|
||||||
args: List[Any] = field(default_factory=list),
|
|
||||||
kwargs: List[Any] = field(default_factory=list),
|
|
||||||
):
|
|
||||||
self.id = id
|
|
||||||
self.description = description
|
|
||||||
self.task = task
|
|
||||||
self.result = result
|
|
||||||
self.agents = agents
|
|
||||||
self.dependencies = dependencies
|
|
||||||
self.results = []
|
|
||||||
self.args = args
|
|
||||||
self.kwargs = kwargs
|
|
||||||
|
|
||||||
def execute(self, parent_results: Dict[str, Any]):
|
def execute(self):
|
||||||
"""Executes the task by passing the results of the parent tasks to the agents.
|
"""
|
||||||
|
Execute the task.
|
||||||
Args:
|
|
||||||
parent_results (Dict[str, Any]): A dictionary of task names and their results.
|
|
||||||
|
|
||||||
Examples:
|
Raises:
|
||||||
|
ValueError: If a Agent instance is used as a task and the 'task' argument is not provided.
|
||||||
"""
|
"""
|
||||||
args = [parent_results[dep] for dep in self.dependencies]
|
if isinstance(self.agent, Agent):
|
||||||
for agent in self.agents:
|
# Add a prompt to notify the Agent of the sequential workflow
|
||||||
if isinstance(agent, Agent):
|
|
||||||
if "prompt" in self.kwargs:
|
if "prompt" in self.kwargs:
|
||||||
self.kwargs["prompt"] += (
|
self.kwargs["prompt"] += (
|
||||||
f"\n\nPrevious output: {self.results[-1]}"
|
f"\n\nPrevious output: {self.result}"
|
||||||
if self.results
|
if self.result
|
||||||
else ""
|
else ""
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
self.kwargs["prompt"] = (
|
self.kwargs["prompt"] = (
|
||||||
f"Main task: {self.description}"
|
f"Main task: {self.description}"
|
||||||
+ (
|
+ (
|
||||||
f"\n\nPrevious output: {self.results[-1]}"
|
f"\n\nPrevious output: {self.result}"
|
||||||
if self.results
|
if self.result
|
||||||
else ""
|
else ""
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
result = agent.run(
|
self.result = self.agent.run(*self.args, **self.kwargs)
|
||||||
self.description, *args, **self.kwargs
|
|
||||||
)
|
|
||||||
else:
|
else:
|
||||||
result = agent(self.description, *args, **self.kwargs)
|
self.result = self.agent(*self.args, **self.kwargs)
|
||||||
self.results.append(result)
|
|
||||||
args = [result]
|
self.history.append(self.result)
|
||||||
self.history.append(result)
|
|
||||||
|
Loading…
Reference in new issue