pull/474/head
Kye 8 months ago
parent 3292174dbc
commit f06198fd64

@ -1,4 +1,5 @@
from swarms import Agent, OpenAIChat from swarms import Agent
from swarms.models.llama3_hosted import llama3Hosted
# Initialize the agent # Initialize the agent
@ -7,7 +8,7 @@ agent = Agent(
agent_description=( agent_description=(
"Generate a transcript for a youtube video on what swarms" " are!" "Generate a transcript for a youtube video on what swarms" " are!"
), ),
llm=OpenAIChat(), llm=llama3Hosted(),
max_loops="auto", max_loops="auto",
autosave=True, autosave=True,
dashboard=False, dashboard=False,

@ -5,7 +5,7 @@ build-backend = "poetry.core.masonry.api"
[tool.poetry] [tool.poetry]
name = "swarms" name = "swarms"
version = "5.0.3" version = "5.0.4"
description = "Swarms - Pytorch" description = "Swarms - Pytorch"
license = "MIT" license = "MIT"
authors = ["Kye Gomez <kye@apac.ai>"] authors = ["Kye Gomez <kye@apac.ai>"]

@ -1,89 +0,0 @@
import json
from typing import Any
from transformers import AutoModelForCausalLM, AutoTokenizer
from swarms.models.base_llm import BaseLLM
class FireFunctionCaller(BaseLLM):
"""
A class that represents a caller for the FireFunction model.
Args:
model_name (str): The name of the model to be used.
device (str): The device to be used.
function_spec (Any): The specification of the function.
max_tokens (int): The maximum number of tokens.
system_prompt (str): The system prompt.
*args: Variable length argument list.
**kwargs: Arbitrary keyword arguments.
Methods:
run(self, task: str, *args, **kwargs) -> None: Run the function with the given task and arguments.
Examples:
>>> fire_function_caller = FireFunctionCaller()
>>> fire_function_caller.run("Add 2 and 3")
"""
def __init__(
self,
model_name: str = "fireworks-ai/firefunction-v1",
device: str = "cuda",
function_spec: Any = None,
max_tokens: int = 3000,
system_prompt: str = "You are a helpful assistant with access to functions. Use them if required.",
*args,
**kwargs,
):
super().__init__(model_name, device)
self.model_name = model_name
self.device = device
self.fucntion_spec = function_spec
self.max_tokens = max_tokens
self.system_prompt = system_prompt
self.model = AutoModelForCausalLM.from_pretrained(
model_name, device_map="auto", *args, **kwargs
)
self.tokenizer = AutoTokenizer.from_pretrained(model_name)
self.functions = json.dumps(function_spec, indent=4)
def run(self, task: str, *args, **kwargs):
"""
Run the function with the given task and arguments.
Args:
task (str): The task to be performed.
*args: Variable length argument list.
**kwargs: Arbitrary keyword arguments.
Returns:
None
"""
messages = [
{"role": "functions", "content": self.functions},
{
"role": "system",
"content": self.system_prompt,
},
{
"role": "user",
"content": task,
},
]
model_inputs = self.tokenizer.apply_chat_template(
messages, return_tensors="pt"
).to(self.model.device)
generated_ids = self.model.generate(
model_inputs,
max_new_tokens=self.max_tokens,
*args,
**kwargs,
)
decoded = self.tokenizer.batch_decode(generated_ids)
print(decoded[0])

@ -1,6 +1,6 @@
import requests import requests
import json import json
from swarms import BaseLLM from swarms.models.base_llm import BaseLLM
class llama3Hosted(BaseLLM): class llama3Hosted(BaseLLM):

@ -1,172 +0,0 @@
"""
SpeechT5 (TTS task)
SpeechT5 model fine-tuned for speech synthesis (text-to-speech) on LibriTTS.
This model was introduced in SpeechT5: Unified-Modal Encoder-Decoder Pre-Training for Spoken Language Processing by Junyi Ao, Rui Wang, Long Zhou, Chengyi Wang, Shuo Ren, Yu Wu, Shujie Liu, Tom Ko, Qing Li, Yu Zhang, Zhihua Wei, Yao Qian, Jinyu Li, Furu Wei.
SpeechT5 was first released in this repository, original weights. The license used is MIT.
Model Description
Motivated by the success of T5 (Text-To-Text Transfer Transformer) in pre-trained natural language processing models, we propose a unified-modal SpeechT5 framework that explores the encoder-decoder pre-training for self-supervised speech/text representation learning. The SpeechT5 framework consists of a shared encoder-decoder network and six modal-specific (speech/text) pre/post-nets. After preprocessing the input speech/text through the pre-nets, the shared encoder-decoder network models the sequence-to-sequence transformation, and then the post-nets generate the output in the speech/text modality based on the output of the decoder.
Leveraging large-scale unlabeled speech and text data, we pre-train SpeechT5 to learn a unified-modal representation, hoping to improve the modeling capability for both speech and text. To align the textual and speech information into this unified semantic space, we propose a cross-modal vector quantization approach that randomly mixes up speech/text states with latent units as the interface between encoder and decoder.
Extensive evaluations show the superiority of the proposed SpeechT5 framework on a wide variety of spoken language processing tasks, including automatic speech recognition, speech synthesis, speech translation, voice conversion, speech enhancement, and speaker identification.
Developed by: Junyi Ao, Rui Wang, Long Zhou, Chengyi Wang, Shuo Ren, Yu Wu, Shujie Liu, Tom Ko, Qing Li, Yu Zhang, Zhihua Wei, Yao Qian, Jinyu Li, Furu Wei.
Shared by [optional]: Matthijs Hollemans
Model type: text-to-speech
Language(s) (NLP): [More Information Needed]
License: MIT
Finetuned from model [optional]: [More Information Needed]
Model Sources [optional]
Repository: [https://github.com/microsoft/SpeechT5/]
Paper: [https://arxiv.org/pdf/2110.07205.pdf]
Blog Post: [https://huggingface.co/blog/speecht5]
Demo: [https://huggingface.co/spaces/Matthijs/speecht5-tts-demo]
"""
import soundfile as sf
import torch
from datasets import load_dataset
from transformers import (
SpeechT5ForTextToSpeech,
SpeechT5HifiGan,
SpeechT5Processor,
pipeline,
)
class SpeechT5:
"""
SpeechT5Wrapper
Args:
model_name (str, optional): Model name or path. Defaults to "microsoft/speecht5_tts".
vocoder_name (str, optional): Vocoder name or path. Defaults to "microsoft/speecht5_hifigan".
dataset_name (str, optional): Dataset name or path. Defaults to "Matthijs/cmu-arctic-xvectors".
Attributes:
model_name (str): Model name or path.
vocoder_name (str): Vocoder name or path.
dataset_name (str): Dataset name or path.
processor (SpeechT5Processor): Processor for the SpeechT5 model.
model (SpeechT5ForTextToSpeech): SpeechT5 model.
vocoder (SpeechT5HifiGan): SpeechT5 vocoder.
embeddings_dataset (datasets.Dataset): Dataset containing speaker embeddings.
Methods
__call__: Synthesize speech from text.
save_speech: Save speech to a file.
set_model: Change the model.
set_vocoder: Change the vocoder.
set_embeddings_dataset: Change the embeddings dataset.
get_sampling_rate: Get the sampling rate of the model.
print_model_details: Print details of the model.
quick_synthesize: Customize pipeline method for quick synthesis.
change_dataset_split: Change dataset split (train, validation, test).
load_custom_embedding: Load a custom speaker embedding (xvector) for the text.
Usage:
>>> speechT5 = SpeechT5Wrapper()
>>> result = speechT5("Hello, how are you?")
>>> speechT5.save_speech(result)
>>> print("Speech saved successfully!")
"""
def __init__(
self,
model_name="microsoft/speecht5_tts",
vocoder_name="microsoft/speecht5_hifigan",
dataset_name="Matthijs/cmu-arctic-xvectors",
):
self.model_name = model_name
self.vocoder_name = vocoder_name
self.dataset_name = dataset_name
self.processor = SpeechT5Processor.from_pretrained(self.model_name)
self.model = SpeechT5ForTextToSpeech.from_pretrained(
self.model_name
)
self.vocoder = SpeechT5HifiGan.from_pretrained(self.vocoder_name)
self.embeddings_dataset = load_dataset(
self.dataset_name, split="validation"
)
def __call__(self, text: str, speaker_id: float = 7306):
"""Call the model on some text and return the speech."""
speaker_embedding = torch.tensor(
self.embeddings_dataset[speaker_id]["xvector"]
).unsqueeze(0)
inputs = self.processor(text=text, return_tensors="pt")
speech = self.model.generate_speech(
inputs["input_ids"],
speaker_embedding,
vocoder=self.vocoder,
)
return speech
def save_speech(self, speech, filename="speech.wav"):
"""Save Speech to a file."""
sf.write(filename, speech.numpy(), samplerate=16000)
def set_model(self, model_name: str):
"""Set the model to a new model."""
self.model_name = model_name
self.processor = SpeechT5Processor.from_pretrained(self.model_name)
self.model = SpeechT5ForTextToSpeech.from_pretrained(
self.model_name
)
def set_vocoder(self, vocoder_name):
"""Set the vocoder to a new vocoder."""
self.vocoder_name = vocoder_name
self.vocoder = SpeechT5HifiGan.from_pretrained(self.vocoder_name)
def set_embeddings_dataset(self, dataset_name):
"""Set the embeddings dataset to a new dataset."""
self.dataset_name = dataset_name
self.embeddings_dataset = load_dataset(
self.dataset_name, split="validation"
)
# Feature 1: Get sampling rate
def get_sampling_rate(self):
"""Get sampling rate of the model."""
return 16000
# Feature 2: Print details of the model
def print_model_details(self):
"""Print details of the model."""
print(f"Model Name: {self.model_name}")
print(f"Vocoder Name: {self.vocoder_name}")
# Feature 3: Customize pipeline method for quick synthesis
def quick_synthesize(self, text):
"""Customize pipeline method for quick synthesis."""
synthesiser = pipeline("text-to-speech", self.model_name)
speech = synthesiser(text)
return speech
# Feature 4: Change dataset split (train, validation, test)
def change_dataset_split(self, split="train"):
"""Change dataset split (train, validation, test)."""
self.embeddings_dataset = load_dataset(
self.dataset_name, split=split
)
# Feature 5: Load a custom speaker embedding (xvector) for the text
def load_custom_embedding(self, xvector):
"""Load a custom speaker embedding (xvector) for the text."""
return torch.tensor(xvector).unsqueeze(0)
# if __name__ == "__main__":
# speechT5 = SpeechT5Wrapper()
# result = speechT5("Hello, how are you?")
# speechT5.save_speech(result)
# print("Speech saved successfully!")

@ -12,6 +12,7 @@ from swarms.structs.block_wrapper import block
from swarms.structs.concurrent_workflow import ConcurrentWorkflow from swarms.structs.concurrent_workflow import ConcurrentWorkflow
from swarms.structs.conversation import Conversation from swarms.structs.conversation import Conversation
from swarms.structs.groupchat import GroupChat, GroupChatManager from swarms.structs.groupchat import GroupChat, GroupChatManager
from swarms.structs.hiearchical_swarm import HiearchicalSwarm
from swarms.structs.majority_voting import ( from swarms.structs.majority_voting import (
MajorityVoting, MajorityVoting,
majority_voting, majority_voting,
@ -19,6 +20,7 @@ from swarms.structs.majority_voting import (
parse_code_completion, parse_code_completion,
) )
from swarms.structs.message import Message from swarms.structs.message import Message
from swarms.structs.message_pool import MessagePool
from swarms.structs.model_parallizer import ModelParallelizer from swarms.structs.model_parallizer import ModelParallelizer
from swarms.structs.multi_agent_collab import MultiAgentCollaboration from swarms.structs.multi_agent_collab import MultiAgentCollaboration
from swarms.structs.multi_process_workflow import ( from swarms.structs.multi_process_workflow import (
@ -28,7 +30,9 @@ from swarms.structs.multi_threaded_workflow import (
MultiThreadedWorkflow, MultiThreadedWorkflow,
) )
from swarms.structs.plan import Plan from swarms.structs.plan import Plan
from swarms.structs.rearrange import AgentRearrange, rearrange
from swarms.structs.recursive_workflow import RecursiveWorkflow from swarms.structs.recursive_workflow import RecursiveWorkflow
from swarms.structs.round_robin import RoundRobinSwarm
from swarms.structs.schemas import ( from swarms.structs.schemas import (
Artifact, Artifact,
ArtifactUpload, ArtifactUpload,
@ -75,16 +79,12 @@ from swarms.structs.utils import (
find_token_in_text, find_token_in_text,
parse_tasks, parse_tasks,
) )
from swarms.structs.rearrange import AgentRearrange, rearrange
from swarms.structs.yaml_model import ( from swarms.structs.yaml_model import (
get_type_name, YamlModel,
create_yaml_schema_from_dict, create_yaml_schema_from_dict,
get_type_name,
pydantic_type_to_yaml_schema, pydantic_type_to_yaml_schema,
YamlModel,
) )
from swarms.structs.message_pool import MessagePool
from swarms.structs.round_robin import RoundRobinSwarm
__all__ = [ __all__ = [
"Agent", "Agent",
@ -158,4 +158,5 @@ __all__ = [
"MessagePool", "MessagePool",
"rearrange", "rearrange",
"RoundRobinSwarm", "RoundRobinSwarm",
"HiearchicalSwarm",
] ]

@ -5,10 +5,11 @@ from typing import Any, Callable, List, Optional
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.structs.task import Task from swarms.structs.task import Task
from swarms.utils.logger import logger from swarms.utils.logger import logger
from swarms.structs.base_swarm import BaseSwarm
@dataclass @dataclass
class AsyncWorkflow: class AsyncWorkflow(BaseSwarm):
""" """
Represents an asynchronous workflow to run tasks. Represents an asynchronous workflow to run tasks.

@ -116,6 +116,7 @@ class AutoSwarm(BaseSwarm):
custom_preprocess: Optional[Callable] = None, custom_preprocess: Optional[Callable] = None,
custom_postprocess: Optional[Callable] = None, custom_postprocess: Optional[Callable] = None,
custom_router: Optional[Callable] = None, custom_router: Optional[Callable] = None,
max_loops: int = 1,
*args, *args,
**kwargs, **kwargs,
): ):
@ -126,6 +127,8 @@ class AutoSwarm(BaseSwarm):
self.custom_params = custom_params self.custom_params = custom_params
self.custom_preprocess = custom_preprocess self.custom_preprocess = custom_preprocess
self.custom_postprocess = custom_postprocess self.custom_postprocess = custom_postprocess
self.custom_router = custom_router
self.max_loops = max_loops
self.router = AutoSwarmRouter( self.router = AutoSwarmRouter(
name=name, name=name,
description=description, description=description,
@ -141,7 +144,32 @@ class AutoSwarm(BaseSwarm):
def run(self, task: str = None, *args, **kwargs): def run(self, task: str = None, *args, **kwargs):
"""Run the swarm simulation.""" """Run the swarm simulation."""
try: try:
return self.router.run(task, *args, **kwargs) loop = 0
while loop < self.max_loops:
if self.custom_preprocess:
# If custom preprocess function is provided then run it
logger.info("Running custom preprocess function.")
task, args, kwargs = self.custom_preprocess(
task, args, kwargs
)
if self.custom_router:
# If custom router function is provided then use it to route the task
logger.info("Running custom router function.")
out = self.custom_router(self, task, *args, **kwargs)
else:
out = self.router.run(task, *args, **kwargs)
if self.custom_postprocess:
# If custom postprocess function is provided then run it
out = self.custom_postprocess(out)
# LOOP
loop += 1
return out
except Exception as e: except Exception as e:
logger.error( logger.error(
f"Error: {e} try optimizing the inputs and try again." f"Error: {e} try optimizing the inputs and try again."

@ -4,10 +4,10 @@ from typing import Dict, List, Optional, Union
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.structs.conversation import Conversation from swarms.structs.conversation import Conversation
from swarms.utils.logger import logger from swarms.utils.logger import logger
from swarms.structs.base_swarm import BaseSwarm
@dataclass @dataclass
class Company: class Company(BaseSwarm):
""" """
Represents a company with a hierarchical organizational structure. Represents a company with a hierarchical organizational structure.
""" """

@ -4,6 +4,7 @@ from datetime import datetime
from typing import List from typing import List
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.structs.base_swarm import BaseSwarm
NAME_LIST = [ NAME_LIST = [
"Affirmative side", "Affirmative side",
@ -26,7 +27,7 @@ class DebatePlayer(Agent):
super().__init__(llm=llm, agent_name=name, *args, **kwargs) super().__init__(llm=llm, agent_name=name, *args, **kwargs)
class Debate: class Debate(BaseSwarm):
"""Create a debate """Create a debate
Args: Args:

@ -3,10 +3,11 @@ from typing import List
from swarms.structs.conversation import Conversation from swarms.structs.conversation import Conversation
from swarms.utils.loguru_logger import logger from swarms.utils.loguru_logger import logger
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.structs.base_swarm import BaseSwarm
@dataclass @dataclass
class GroupChat: class GroupChat(BaseSwarm):
""" """
A group chat class that contains a list of agents and the maximum number of rounds. A group chat class that contains a list of agents and the maximum number of rounds.

@ -9,7 +9,6 @@ from swarms.utils.loguru_logger import logger
class HiearchicalSwarm(BaseSwarm): class HiearchicalSwarm(BaseSwarm):
@beartype @beartype
def __init__( def __init__(
self, self,
@ -27,6 +26,7 @@ class HiearchicalSwarm(BaseSwarm):
self.long_term_memory_system = long_term_memory_system self.long_term_memory_system = long_term_memory_system
# Set the director to max_one loop # Set the director to max_one loop
if self.director.max_loops > 1:
self.director.max_loops = 1 self.director.max_loops = 1
# Set the long term memory system of every agent to long term memory system # Set the long term memory system of every agent to long term memory system
@ -34,8 +34,6 @@ class HiearchicalSwarm(BaseSwarm):
for agent in agents: for agent in agents:
agent.long_term_memory = long_term_memory_system agent.long_term_memory = long_term_memory_system
def parse_function_activate_agent( def parse_function_activate_agent(
self, json_data: str = None, *args, **kwargs self, json_data: str = None, *args, **kwargs
): ):

@ -4,6 +4,7 @@ from typing import Callable, List, Optional, Sequence, Union
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.utils.loguru_logger import logger from swarms.utils.loguru_logger import logger
from swarms.structs.base_swarm import BaseSwarm
def _hash(input: str): def _hash(input: str):
@ -42,7 +43,7 @@ def msg_hash(
) )
class MessagePool: class MessagePool(BaseSwarm):
""" """
A class representing a message pool for agents in a swarm. A class representing a message pool for agents in a swarm.

@ -19,12 +19,12 @@ class ModelParallelizer:
Args: Args:
llms (List[Callable]): A list of language models. llms (List[Callable]): A list of language models.
retry_attempts (int): The number of retry attempts. retry_attempts (int): The number of retry attempts.
iters (int): The number of iterations to run the task. max_loops (int): The number of iterations to run the task.
Attributes: Attributes:
llms (List[Callable]): A list of language models. llms (List[Callable]): A list of language models.
retry_attempts (int): The number of retry attempts. retry_attempts (int): The number of retry attempts.
iters (int): The number of iterations to run the task. max_loops (int): The number of iterations to run the task.
last_responses (List[str]): The last responses from the language last_responses (List[str]): The last responses from the language
models. models.
task_history (List[str]): The task history. task_history (List[str]): The task history.
@ -52,20 +52,20 @@ class ModelParallelizer:
self, self,
llms: List[Callable] = None, llms: List[Callable] = None,
retry_attempts: int = 3, retry_attempts: int = 3,
iters: int = None, max_loops: int = None,
*args, *args,
**kwargs, **kwargs,
): ):
self.llms = llms self.llms = llms
self.retry_attempts = retry_attempts self.retry_attempts = retry_attempts
self.iters = iters self.max_loops = max_loops
self.last_responses = None self.last_responses = None
self.task_history = [] self.task_history = []
def run(self, task: str): def run(self, task: str):
"""Run the task string""" """Run the task string"""
try: try:
for i in range(self.iters): for i in range(self.max_loops):
with ThreadPoolExecutor() as executor: with ThreadPoolExecutor() as executor:
responses = executor.map( responses = executor.map(
lambda llm: llm(task), self.llms lambda llm: llm(task), self.llms

@ -1,10 +1,10 @@
from typing import List from typing import Callable, Dict, List, Optional
from swarms.memory.base_vectordb import BaseVectorDatabase from swarms.memory.base_vectordb import BaseVectorDatabase
from swarms.structs.agent import Agent
from swarms.structs.base_swarm import BaseSwarm from swarms.structs.base_swarm import BaseSwarm
from swarms.utils.loguru_logger import logger
from typing import Optional, Callable, Dict
from swarms.structs.omni_agent_types import Agent from swarms.structs.omni_agent_types import Agent
from swarms.structs.agent import Agent from swarms.utils.loguru_logger import logger
class AgentRearrange(BaseSwarm): class AgentRearrange(BaseSwarm):
@ -283,56 +283,3 @@ def rearrange(
agents=agents, flow=flow, *args, **kwargs agents=agents, flow=flow, *args, **kwargs
) )
return agent_system.run(task, *args, **kwargs) return agent_system.run(task, *args, **kwargs)
# # Initialize the director agent
# director = Agent(
# agent_name="Director",
# system_prompt="Directs the tasks for the workers",
# llm=Anthropic(),
# max_loops=1,
# dashboard=False,
# streaming_on=True,
# verbose=True,
# stopping_token="<DONE>",
# state_save_file_type="json",
# saved_state_path="director.json",
# )
# # Initialize worker 1
# worker1 = Agent(
# agent_name="Worker1",
# system_prompt="Generates a transcript for a youtube video on what swarms are",
# llm=Anthropic(),
# max_loops=1,
# dashboard=False,
# streaming_on=True,
# verbose=True,
# stopping_token="<DONE>",
# state_save_file_type="json",
# saved_state_path="worker1.json",
# )
# # Initialize worker 2
# worker2 = Agent(
# agent_name="Worker2",
# system_prompt="Summarizes the transcript generated by Worker1",
# llm=Anthropic(),
# max_loops=1,
# dashboard=False,
# streaming_on=True,
# verbose=True,
# stopping_token="<DONE>",
# state_save_file_type="json",
# saved_state_path="worker2.json",
# )
# flow = "Director -> Worker1 -> Worker2"
# agent_system = AgentRearrange(
# agents=[director, worker1, worker2], flow=flow
# )
# # Run the system
# output = agent_system.run(
# "Create a format to express and communicate swarms of llms in a structured manner for youtube"
# )

@ -34,6 +34,9 @@ class RecursiveWorkflow(BaseStructure):
self, self,
stop_token: str = "<DONE>", stop_token: str = "<DONE>",
stopping_conditions: callable = None, stopping_conditions: callable = None,
max_loops: int = 1,
*args,
**kwargs,
): ):
self.stop_token = stop_token self.stop_token = stop_token
self.stopping_conditions = stopping_conditions self.stopping_conditions = stopping_conditions
@ -75,12 +78,20 @@ class RecursiveWorkflow(BaseStructure):
None None
""" """
try: try:
loop = 0
while loop < self.max_loops:
for task in self.task_pool: for task in self.task_pool:
while True: while True:
result = task.run() result = task.run()
if result is not None and self.stop_token in result: if (
result is not None
and self.stop_token in result
):
break break
print(f"{result}") print(f"{result}")
loop += 1
return result
except Exception as error: except Exception as error:
logger.warning(f"[ERROR][RecursiveWorkflow] {error}") logger.warning(f"[ERROR][RecursiveWorkflow] {error}")
raise error raise error

@ -50,7 +50,9 @@ class SermonSwarm(BaseSwarm):
agent.add_message_to_memory(sermon) agent.add_message_to_memory(sermon)
# Then run the agents # Then run the agents
for _ in range(self.max_loops): loop = 0
# for _ in range(self.max_loops):
while loop < self.max_loops:
for agent in self.agents: for agent in self.agents:
preach = agent.run(task, *args, **kwargs) preach = agent.run(task, *args, **kwargs)
@ -63,3 +65,6 @@ class SermonSwarm(BaseSwarm):
elif self.stop_condition in preach: elif self.stop_condition in preach:
break break
loop += 1
return preach

@ -7,6 +7,7 @@ from typing import Any, Callable, Dict, List, Union
from swarms.structs.agent import Agent from swarms.structs.agent import Agent
from swarms.structs.conversation import Conversation from swarms.structs.conversation import Conversation
from swarms.utils.logger import logger from swarms.utils.logger import logger
from swarms.structs.omni_agent_types import AgentType
@dataclass @dataclass
@ -51,7 +52,7 @@ class Task:
""" """
agent: Union[Callable, Agent] agent: Union[Callable, Agent, AgentType] = None
description: str = None description: str = None
result: Any = None result: Any = None
history: List[Any] = field(default_factory=list) history: List[Any] = field(default_factory=list)

Loading…
Cancel
Save