From 09838bd6f90868c576f4b55cdcfbe13c289a875b Mon Sep 17 00:00:00 2001 From: Kye Gomez Date: Sat, 15 Jun 2024 19:50:06 -0700 Subject: [PATCH] [DOCS][CLEANUP] --- docs/index.md | 2 +- docs/swarms/agents/idea_to_image.md | 124 ----------- docs/swarms/agents/omni_agent.md | 94 -------- docs/swarms/agents/omnimodalagent.md | 79 ------- docs/swarms/agents/toolagent.md | 3 - docs/swarms/agents/workeragent.md | 78 ------- docs/swarms/structs/autoscaler.md | 178 ---------------- docs/swarms/structs/baseworkflow.md | 42 ---- docs/swarms/structs/groupchat.md | 147 ------------- docs/swarms/structs/groupchatmanager.md | 90 -------- docs/swarms/structs/stackoverflowswarm.md | 114 ---------- docs/swarms/structs/workflow.md | 200 ------------------ docs/swarms/structs/yaml_model.md | 2 - .../structs/search_arena/search_agents.py | 1 - 14 files changed, 1 insertion(+), 1153 deletions(-) delete mode 100644 docs/swarms/agents/idea_to_image.md delete mode 100644 docs/swarms/agents/omni_agent.md delete mode 100644 docs/swarms/agents/omnimodalagent.md delete mode 100644 docs/swarms/agents/workeragent.md delete mode 100644 docs/swarms/structs/autoscaler.md delete mode 100644 docs/swarms/structs/baseworkflow.md delete mode 100644 docs/swarms/structs/groupchat.md delete mode 100644 docs/swarms/structs/groupchatmanager.md delete mode 100644 docs/swarms/structs/stackoverflowswarm.md delete mode 100644 docs/swarms/structs/workflow.md diff --git a/docs/index.md b/docs/index.md index 9a841fc2..cfccb5be 100644 --- a/docs/index.md +++ b/docs/index.md @@ -13,4 +13,4 @@ Orchestrate enterprise-grade agents for multi-agent collaboration and orchestrat | | [Connecting LLMs](https://docs.swarms.world/en/latest/swarms/models/custom_model/) | | | | | [Customizing Agents](./how-to/Customizing-Agents) | | | | | [Human Input on Execution](./how-to/Human-Input-on-Execution) | | | -| | [Agent Monitoring with AgentOps](./how-to/AgentOps-Observability) | | | \ No newline at end of file +| | [Agent Monitoring with AgentOps](https://medium.com/@kyeg/enterprise-grade-autonomous-agents-with-production-ready-monitoring-4295f6737bbf) | | | \ No newline at end of file diff --git a/docs/swarms/agents/idea_to_image.md b/docs/swarms/agents/idea_to_image.md deleted file mode 100644 index 41d5b216..00000000 --- a/docs/swarms/agents/idea_to_image.md +++ /dev/null @@ -1,124 +0,0 @@ -# `Idea2Image` Documentation - -## Table of Contents - -1. [Introduction](#introduction) -2. [Idea2Image Class](#idea2image-class) - - [Initialization Parameters](#initialization-parameters) -3. [Methods and Usage](#methods-and-usage) - - [llm_prompt Method](#llm-prompt-method) - - [generate_image Method](#generate-image-method) -4. [Examples](#examples) - - [Example 1: Generating an Image](#example-1-generating-an-image) -5. [Additional Information](#additional-information) -6. [References and Resources](#references-and-resources) - ---- - -## 1. Introduction - -Welcome to the documentation for the Swarms library, with a focus on the `Idea2Image` class. This comprehensive guide provides in-depth information about the Swarms library and its core components. Before we dive into the details, it's crucial to understand the purpose and significance of this library. - -### 1.1 Purpose - -The Swarms library aims to simplify interactions with AI models for generating images from text prompts. The `Idea2Image` class is designed to generate images from textual descriptions using the DALLE-3 model and the OpenAI GPT-4 language model. - -### 1.2 Key Features - -- **Image Generation:** Swarms allows you to generate images based on natural language prompts, providing a bridge between textual descriptions and visual content. - -- **Integration with DALLE-3:** The `Idea2Image` class leverages the power of DALLE-3 to create images that match the given textual descriptions. - -- **Language Model Integration:** The class integrates with OpenAI's GPT-3 for prompt refinement, enhancing the specificity of image generation. - ---- - -## 2. Idea2Image Class - -The `Idea2Image` class is a fundamental module in the Swarms library, enabling the generation of images from text prompts. - -### 2.1 Initialization Parameters - -Here are the initialization parameters for the `Idea2Image` class: - -- `image` (str): Text prompt for the image to generate. - -- `openai_api_key` (str): OpenAI API key. This key is used for prompt refinement with GPT-3. If not provided, the class will attempt to use the `OPENAI_API_KEY` environment variable. - -- `cookie` (str): Cookie value for DALLE-3. This cookie is used to interact with the DALLE-3 API. If not provided, the class will attempt to use the `BING_COOKIE` environment variable. - -- `output_folder` (str): Folder to save the generated images. The default folder is "images/". - -### 2.2 Methods - -The `Idea2Image` class provides the following methods: - -- `llm_prompt()`: Returns a prompt for refining the image generation. This method helps improve the specificity of the image generation prompt. - -- `generate_image()`: Generates and downloads the image based on the prompt. It refines the prompt, opens the website with the query, retrieves image URLs, and downloads the images to the specified folder. - ---- - -## 3. Methods and Usage - -Let's explore the methods provided by the `Idea2Image` class and how to use them effectively. - -### 3.1 `llm_prompt` Method - -The `llm_prompt` method returns a refined prompt for generating the image. It's a critical step in improving the specificity and accuracy of the image generation process. The method provides a guide for refining the prompt, helping users describe the desired image more precisely. - -### 3.2 `generate_image` Method - -The `generate_image` method combines the previous methods to execute the whole process of generating and downloading images based on the provided prompt. It's a convenient way to automate the image generation process. - ---- - -## 4. Examples - -Let's dive into practical examples to demonstrate the usage of the `Idea2Image` class. - -### 4.1 Example 1: Generating an Image - -In this example, we create an instance of the `Idea2Image` class and use it to generate an image based on a text prompt: - -```python -from swarms.agents import Idea2Image - -# Create an instance of the Idea2Image class with your prompt and API keys -idea2image = Idea2Image( - image="Fish hivemind swarm in light blue avatar anime in zen garden pond concept art anime art, happy fish, anime scenery", - openai_api_key="your_openai_api_key_here", - cookie="your_cookie_value_here", -) - -# Generate and download the image -idea2image.generate_image() -``` - ---- - -## 5. Additional Information - -Here are some additional tips and information for using the Swarms library and the `Idea2Image` class effectively: - -- Refining the prompt is a crucial step to influence the style, composition, and mood of the generated image. Follow the provided guide in the `llm_prompt` method to create precise prompts. - -- Experiment with different prompts, variations, and editing techniques to create unique and interesting images. - -- You can combine separate DALLE-3 outputs into panoramas and murals by careful positioning and editing. - -- Consider sharing your creations and exploring resources in communities like Reddit r/dalle2 for inspiration and tools. - -- The `output_folder` parameter allows you to specify the folder where generated images will be saved. Ensure that you have the necessary permissions to write to that folder. - ---- - -## 6. References and Resources - -For further information and resources related to the Swarms library and DALLE-3: - -- [DALLE-3 Unofficial API Documentation](https://www.bing.com/images/create): The official documentation for the DALLE-3 Unofficial API, where you can explore additional features and capabilities. - -- [OpenAI GPT-3 Documentation](https://beta.openai.com/docs/): The documentation for OpenAI's GPT-3, which is used for prompt refinement. - -This concludes the documentation for the Swarms library and the `Idea2Image` class. You now have a comprehensive guide on how to generate images from text prompts using DALLE-3 and GPT-3 with Swarms. \ No newline at end of file diff --git a/docs/swarms/agents/omni_agent.md b/docs/swarms/agents/omni_agent.md deleted file mode 100644 index 888e824f..00000000 --- a/docs/swarms/agents/omni_agent.md +++ /dev/null @@ -1,94 +0,0 @@ -# `OmniModalAgent` Documentation - -## Overview & Architectural Analysis -The `OmniModalAgent` class is at the core of an architecture designed to facilitate dynamic interactions using various tools, through a seamless integration of planning, task execution, and response generation mechanisms. It encompasses multiple modalities including natural language processing, image processing, and more, aiming to provide comprehensive and intelligent responses. - -### Architectural Components: -1. **LLM (Language Model)**: It acts as the foundation, underpinning the understanding and generation of language-based interactions. -2. **Chat Planner**: This component drafts a blueprint for the steps necessary based on the user's input. -3. **Task Executor**: As the name suggests, it's responsible for executing the formulated tasks. -4. **Tools**: A collection of tools and utilities used to process different types of tasks. They span across areas like image captioning, translation, and more. - - -## Structure & Organization - -### Table of Contents: -1. Class Introduction and Architecture -2. Constructor (`__init__`) -3. Core Methods - - `run` - - `chat` - - `_stream_response` -4. Example Usage -5. Error Messages & Exception Handling -6. Summary & Further Reading - -### Constructor (`__init__`): -The agent is initialized with a language model (`llm`). During initialization, the agent loads a myriad of tools to facilitate a broad spectrum of tasks, from document querying to image transformations. - -### Core Methods: -#### 1. `run(self, input: str) -> str`: -Executes the OmniAgent. The agent plans its actions based on the user's input, executes those actions, and then uses a response generator to construct its reply. - -#### 2. `chat(self, msg: str, streaming: bool) -> str`: -Facilitates an interactive chat with the agent. It processes user messages, handles exceptions, and returns a response, either in streaming format or as a whole string. - -#### 3. `_stream_response(self, response: str)`: -For streaming mode, this function yields the response token by token, ensuring a smooth output agent. - -## Examples & Use Cases -Initialize the `OmniModalAgent` and communicate with it: -```python -import os - -from dotenv import load_dotenv - -from swarms.agents.omni_modal_agent import OmniModalAgent, OpenAIChat -from swarms.models import OpenAIChat - -# Load the environment variables -load_dotenv() - -# Get the API key from the environment -api_key = os.environ.get("OPENAI_API_KEY") - -# Initialize the language model -llm = OpenAIChat( - temperature=0.5, - model_name="gpt-4", - openai_api_key=api_key, -) - - -agent = OmniModalAgent(llm) -response = agent.run("Translate 'Hello' to French.") -print(response) -``` - -For a chat-based interaction: -```python -agent = OmniModalAgent(llm_instance) -print(agent.chat("How are you doing today?")) -``` - -## Error Messages & Exception Handling -The `chat` method in `OmniModalAgent` incorporates exception handling. When an error arises during message processing, it returns a formatted error message detailing the exception. This approach ensures that users receive informative feedback in case of unexpected situations. - -For example, if there's an internal processing error, the chat function would return: -``` -Error processing message: [Specific error details] -``` - -## Summary -`OmniModalAgent` epitomizes the fusion of various AI tools, planners, and executors into one cohesive unit, providing a comprehensive interface for diverse tasks and modalities. The versatility and robustness of this agent make it indispensable for applications desiring to bridge multiple AI functionalities in a unified manner. - -For more extensive documentation, API references, and advanced use-cases, users are advised to refer to the primary documentation repository associated with the parent project. Regular updates, community feedback, and patches can also be found there. - - - - - - - - - diff --git a/docs/swarms/agents/omnimodalagent.md b/docs/swarms/agents/omnimodalagent.md deleted file mode 100644 index 841a39f0..00000000 --- a/docs/swarms/agents/omnimodalagent.md +++ /dev/null @@ -1,79 +0,0 @@ -# Module/Class Name: OmniModalAgent - -The `OmniModalAgent` class is a module that operates based on the Language Model (LLM) aka Language Understanding Model, Plans, Tasks, and Tools. It is designed to be a multi-modal chatbot which uses various AI-based capabilities for fulfilling user requests. - -It has the following architecture: -1. Language Model (LLM). -2. Chat Planner - Plans -3. Task Executor - Tasks -4. Tools - Tools - -![OmniModalAgent](https://source.unsplash.com/random) - ---- - -### Usage - from swarms import OmniModalAgent, OpenAIChat - - llm = OpenAIChat() - agent = OmniModalAgent(llm) - response = agent.run("Hello, how are you? Create an image of how your are doing!") - ---- - ---- - -### Initialization - -The constructor of `OmniModalAgent` class takes two main parameters: -- `llm`: A `BaseLanguageModel` that represents the language model -- `tools`: A List of `BaseTool` instances that are used by the agent for fulfilling different requests. - -```python -def __init__( - self, - llm: BaseLanguageModel, - # tools: List[BaseTool] -): -``` - ---- - -### Methods - -The class has two main methods: -1. `run`: This method takes an input string and executes various plans and tasks using the provided tools. Ultimately, it generates a response based on the user's input and returns it. - - Parameters: - - `input`: A string representing the user's input text. - - Returns: - - A string representing the response. - - Usage: - ```python - response = agent.run("Hello, how are you? Create an image of how your are doing!") - ``` - -2. `chat`: This method is used to simulate a chat dialog with the agent. It can take user's messages and return the response (or stream the response word-by-word if required). - - Parameters: - - `msg` (optional): A string representing the message to send to the agent. - - `streaming` (optional): A boolean specifying whether to stream the response. - - Returns: - - A string representing the response from the agent. - - Usage: - ```python - response = agent.chat("Hello") - ``` - ---- - -### Streaming Response - -The class provides a method `_stream_response` that can be used to get the response token by token (i.e. word by word). It yields individual tokens from the response. - -Usage: -```python -for token in _stream_response(response): - print(token) -``` - diff --git a/docs/swarms/agents/toolagent.md b/docs/swarms/agents/toolagent.md index c358c8c9..c919866f 100644 --- a/docs/swarms/agents/toolagent.md +++ b/docs/swarms/agents/toolagent.md @@ -1,8 +1,5 @@ # ToolAgent Documentation - -### Overview and Introduction - The `ToolAgent` class represents an intelligent agent capable of performing a specific task using a pre-trained model and tokenizer. It leverages the Transformer models of the Hugging Face `transformers` library to generate outputs that adhere to a specific JSON schema. This provides developers with a flexible tool for creating bots, text generators, and conversational AI agents. The `ToolAgent` operates based on a JSON schema provided by you, the user. Using the schema, the agent applies the provided model and tokenizer to generate structured text data that matches the specified format. The primary objective of the `ToolAgent` class is to amplify the efficiency of developers and AI practitioners by simplifying the process of generating meaningful outputs that navigate the complexities of the model and tokenizer. diff --git a/docs/swarms/agents/workeragent.md b/docs/swarms/agents/workeragent.md deleted file mode 100644 index aaa71653..00000000 --- a/docs/swarms/agents/workeragent.md +++ /dev/null @@ -1,78 +0,0 @@ -# WorkerClass Documentation - -## Overview - -The Worker class represents an autonomous agent that can perform tasks through function calls or by running a chat. It can be used to create applications that demand effective user interactions like search engines, human-like conversational bots, or digital assistants. - -The `Worker` class is part of the `swarms.agents` codebase. This module is largely used in Natural Language Processing (NLP) projects where the agent undertakes conversations and other language-specific operations. - -## Class Definition - -The class `Worker` has the following arguments: - -| Argument | Type | Default Value | Description | -|-----------------------|---------------|----------------------------------|----------------------------------------------------| -| name | str | "Worker" | Name of the agent. | -| role | str | "Worker in a swarm" | Role of the agent. | -| external_tools | list | None | List of external tools available to the agent. | -| human_in_the_loop | bool | False | Determines whether human interaction is required. | -| temperature | float | 0.5 | Temperature for the autonomous agent. | -| llm | None | None | Language model. | -| openai_api_key | str | None | OpenAI API key. | -| tools | List[Any] | None | List of tools available to the agent. | -| embedding_size | int | 1536 | Size of the word embeddings. | -| search_kwargs | dict | {"k": 8} | Search parameters. | -| args | Multiple | | Additional arguments that can be passed. | -| kwargs | Multiple | | Additional keyword arguments that can be passed. | -## Usage - -#### Example 1: Creating and Running an Agent - -```python -from swarms import Worker - -worker = Worker( - name="My Worker", - role="Worker", - external_tools=[MyTool1(), MyTool2()], - human_in_the_loop=False, - temperature=0.5, - llm=some_language_model, - openai_api_key="my_key", -) -worker.run("What's the weather in Miami?") -``` - -#### Example 2: Receiving and Sending Messages - -```python -worker.receieve("User", "Hello there!") -worker.receieve("User", "Can you tell me something about history?") -worker.send() -``` - -#### Example 3: Setting up Tools - -```python -external_tools = [MyTool1(), MyTool2()] -worker = Worker( - name="My Worker", - role="Worker", - external_tools=external_tools, - human_in_the_loop=False, - temperature=0.5, -) -``` - -## Additional Information and Tips - -- The class allows the setting up of tools for the worker to operate effectively. It provides setup facilities for essential computing infrastructure, such as the agent's memory and language model. -- By setting the `human_in_the_loop` parameter to True, interactions with the worker can be made more user-centric. -- The `openai_api_key` argument can be provided for leveraging the OpenAI infrastructure and services. -- A qualified language model can be passed as an instance of the `llm` object, which can be useful when integrating with state-of-the-art text generation engines. - -## References and Resources - -- [OpenAI APIs](https://openai.com) -- [Models and Languages at HuggingFace](https://huggingface.co/models) -- [Deep Learning and Language Modeling at the Allen Institute for AI](https://allenai.org) diff --git a/docs/swarms/structs/autoscaler.md b/docs/swarms/structs/autoscaler.md deleted file mode 100644 index 6d07d3b1..00000000 --- a/docs/swarms/structs/autoscaler.md +++ /dev/null @@ -1,178 +0,0 @@ -### Enterprise Grade Documentation - ---- - -## AutoScaler Class from `swarms` Package - -The `AutoScaler` class, part of the `swarms` package, provides a dynamic mechanism to handle agents depending on the workload. This document outlines how to use it, complete with import statements and examples. - ---- - -### Importing the AutoScaler Class - -Before you can use the `AutoScaler` class, you must import it from the `swarms` package: - -```python -from swarms import AutoScaler -``` - ---- - -### Constructor: `AutoScaler.__init__()` - -**Description**: -Initializes the `AutoScaler` with a predefined number of agents and sets up configurations for scaling. - -**Parameters**: -- `initial_agents (int)`: Initial number of agents. Default is 10. -- `scale_up_factor (int)`: Multiplicative factor to scale up the number of agents. Default is 2. -- `idle_threshold (float)`: Threshold below which agents are considered idle. Expressed as a ratio (0-1). Default is 0.2. -- `busy_threshold (float)`: Threshold above which agents are considered busy. Expressed as a ratio (0-1). Default is 0.7. - -**Returns**: -- None - -**Example Usage**: -```python -from swarms import AutoScaler - -scaler = AutoScaler( - initial_agents=5, scale_up_factor=3, idle_threshold=0.1, busy_threshold=0.8 -) -``` - ---- - -### Method: `AutoScaler.add_task(task)` - -**Description**: -Enqueues the specified task into the task queue. - -**Parameters**: -- `task`: The task to be added to the queue. - -**Returns**: -- None - -**Example Usage**: -```python -task_data = "Process dataset X" -scaler.add_task(task_data) -``` - ---- - -### Method: `AutoScaler.scale_up()` - -**Description**: -Scales up the number of agents based on the specified scale-up factor. - -**Parameters**: -- None - -**Returns**: -- None - -**Example Usage**: -```python -# Called internally but can be manually invoked if necessary -scaler.scale_up() -``` - ---- - -### Method: `AutoScaler.scale_down()` - -**Description**: -Scales down the number of agents, ensuring a minimum is always present. - -**Parameters**: -- None - -**Returns**: -- None - -**Example Usage**: -```python -# Called internally but can be manually invoked if necessary -scaler.scale_down() -``` - ---- - -### Method: `AutoScaler.monitor_and_scale()` - -**Description**: -Continuously monitors the task queue and agent utilization to decide on scaling. - -**Parameters**: -- None - -**Returns**: -- None - -**Example Usage**: -```python -# This method is internally used as a thread and does not require manual invocation in most scenarios. -``` - ---- - -### Method: `AutoScaler.start()` - -**Description**: -Initiates the monitoring process and starts processing tasks from the queue. - -**Parameters**: -- None - -**Returns**: -- None - -**Example Usage**: -```python -scaler.start() -``` - ---- - -### Full Usage - -```python -from swarms import AutoScaler - -# Initialize the scaler -auto_scaler = AutoScaler( - initial_agents=15, scale_up_factor=2, idle_threshold=0.2, busy_threshold=0.7 -) - -# Start the monitoring and task processing -auto_scaler.start() - -# Simulate the addition of tasks -for i in range(100): - auto_scaler.add_task(f"Task {i}") -``` - -### Pass in Custom Agent -You can pass any agent class that adheres to the required interface (like having a run() method). If no class is passed, it defaults to using AutoBot. This makes the AutoScaler more flexible and able to handle a wider range of agent implementations. - -```python -from swarms import AutoScaler - -auto_scaler = AutoScaler(agent=YourCustomAgent) -auto_scaler.start() - -for i in range(100): # Adding tasks - auto_scaler.add_task(f"Task {i}") -``` - - ---- - -**Notes**: -1. Adjust the thresholds and scaling factors as per your specific requirements and nature of the tasks. -2. The provided implementation is a baseline. Depending on your production environment, you may need additional features, error-handling, and optimizations. -3. Ensure that the `swarms` package and its dependencies are installed in your environment. - ---- diff --git a/docs/swarms/structs/baseworkflow.md b/docs/swarms/structs/baseworkflow.md deleted file mode 100644 index 2cb4b5eb..00000000 --- a/docs/swarms/structs/baseworkflow.md +++ /dev/null @@ -1,42 +0,0 @@ -### swarms.modules.structs - - `Class Name: BaseWorkflow` - -Base class for workflows. - -`Attributes` -- Task_pool (list): A list to store tasks. - -`Methods` -- Add(task: Task = None, tasks: List[Task] = None, *args, **kwargs): Adds a task or a list of tasks to the task pool. -- Run(): Abstract method to run the workflow. - -Source Code: -```python -class BaseWorkflow(BaseStructure): -""" -Base class for workflows. - - Attributes: - task_pool (list): A list to store tasks. - - Methods: - add(task: Task = None, tasks: List[Task] = None, *args, **kwargs): - Adds a task or a list of tasks to the task pool. - run(): - Abstract method to run the workflow. -""" -``` - -For the usage examples and additional in-depth documentation please visit [BaseWorkflow](https://github.com/swarms-modules/structs/blob/main/baseworkflow.md#swarms-structs) - -Explanation: - -Initially, the `BaseWorkflow` class is a class designed to handle workflows. It contains a list within the task pool to handle various tasks and run methods. In the current structure, there are a few in-built methods such as `add`, `run`, `__sequential_loop`, `__log`, `reset`, `get_task_results`, `remove_task`, `update_task`, `delete_task`, `save_workflow_state`, `add_objective_to_workflow`, and `load_workflow_state`, each serving a unique purpose. - -The `add` method functions to add tasks or a list of tasks to the task pool while the `run` method is left as an abstract method for initializing the workflow. Considering the need to run the workflow, `__sequential_loop` is another abstract method. In cases where the user desires to log messages, `__log` can be utilized. For resetting the workflow, there is a `reset` method, complemented by `get_task_results` that returns the results of each task in the workflow. To remove a task from the workflow, `remove_task` can be employed. - -In cases where an update is required for the tasks in the workflow, `update_task` comes in handy. Deleting a task from the workflow can be achieved using the `delete_task` method. The method saves the workflow’s state to a JSON file, and the user can fix the path where the file resides. For adding objectives to the workflow, `add_objective_to_workflow` can be employed, and there is an abstract method of `load_workflow_state` for loading the workflow state from a JSON file providing the freedom to revert the workflow to a specific state. - -The class also has a method `__str__` and `__repr__` to represent the text and instantiate an object of the class, respectively. The object can be reset, task results obtained, tasks removed, tasks updated, tasks deleted, or workflow state saved. The structure provides detailed methods for altering the workflow at every level. - diff --git a/docs/swarms/structs/groupchat.md b/docs/swarms/structs/groupchat.md deleted file mode 100644 index cb2cb944..00000000 --- a/docs/swarms/structs/groupchat.md +++ /dev/null @@ -1,147 +0,0 @@ -# Module Name: Group Chat - -The `GroupChat` class is used to create a group chat containing a list of agents. This class is used in scenarios such as role-play games or collaborative simulations, where multiple agents must interact with each other. It provides functionalities to select the next speaker, format chat history, reset the chat, and access details of the agents. - -## Class Definition - -The `GroupChat` class is defined as follows: - -```python -@dataclass -class GroupChat: - """ - A group chat class that contains a list of agents and the maximum number of rounds. - - Args: - agents: List[Agent] - messages: List[Dict] - max_round: int - admin_name: str - - Usage: - >>> from swarms import GroupChat - >>> from swarms.structs.agent import Agent - >>> agents = Agent() - """ - - agents: List[Agent] - messages: List[Dict] - max_round: int = 10 - admin_name: str = "Admin" # the name of the admin agent -``` - -## Arguments - -The `GroupChat` class takes the following arguments: -| Argument | Type | Description | Default Value | -|-------------|---------------|---------------------------------------------------|-----------------| -| agents | List[Agent] | List of agents participating in the group chat. | | -| messages | List[Dict] | List of messages exchanged in the group chat. | | -| max_round | int | Maximum number of rounds for the group chat. | 10 | -| admin_name | str | Name of the admin agent. | "Admin" | - -## Methods - -1. **agent_names** - - Returns the names of the agents in the group chat. - - Returns: List of strings. - -2. **reset** - - Resets the group chat, clears all the messages. - -3. **agent_by_name** - - Finds an agent in the group chat by their name. - - Arguments: name (str) - Name of the agent to search for. - - Returns: Agent - The agent with the matching name. - - Raises: ValueError if no matching agent is found. - -4. **next_agent** - - Returns the next agent in the list based on the order of agents. - - Arguments: agent (Agent) - The current agent. - - Returns: Agent - The next agent in the list. - -5. **select_speaker_msg** - - Returns the message for selecting the next speaker. - -6. **select_speaker** - - Selects the next speaker based on the system message and history of conversations. - - Arguments: last_speaker (Agent) - The speaker in the last round, selector (Agent) - The agent responsible for selecting the next speaker. - - Returns: Agent - The agent selected as the next speaker. - -7. **_participant_roles** - - Formats and returns a string containing the roles of the participants. - - (Internal method, not intended for direct usage) - -8. **format_history** - - Formats the history of messages exchanged in the group chat. - - Arguments: messages (List[Dict]) - List of messages. - - Returns: str - Formatted history of messages. - -## Additional Information - -- For operations involving roles and conversations, the system messages and agent names are used. -- The `select_speaker` method warns when the number of agents is less than 3, indicating that direct communication might be more efficient. - -## Usage Example 1 - -```Python -from swarms import GroupChat -from swarms.structs.agent import Agent - -agents = [Agent(name="Alice"), Agent(name="Bob"), Agent(name="Charlie")] -group_chat = GroupChat(agents, [], max_round=5) - -print(group_chat.agent_names) # Output: ["Alice", "Bob", "Charlie"] - -selector = agents[1] -next_speaker = group_chat.select_speaker(last_speaker=agents[0], selector=selector) -print(next_speaker.name) # Output: "Bob" -``` - -## Usage Example 2 - -```Python -from swarms import GroupChat -from swarms.structs.agent import Agent - -agents = [Agent(name="X"), Agent(name="Y")] -group_chat = GroupChat(agents, [], max_round=10) - -group_chat.messages.append({"role": "X", "content": "Hello Y!"}) -group_chat.messages.append({"role": "Y", "content": "Hi X!"}) - -formatted_history = group_chat.format_history(group_chat.messages) -print(formatted_history) -""" -Output: -'X: Hello Y! -Y: Hi X!' -""" - -agent_charlie = Agent(name="Charlie") -group_chat.agents.append(agent_charlie) - -print(group_chat.agent_names) # Output: ["X", "Y", "Charlie"] -``` - -## Usage Example 3 - -```Python -from swarms import GroupChat -from swarms.structs.agent import Agent - -agents = [Agent(name="A1"), Agent(name="A2"), Agent(name="A3")] -group_chat = GroupChat(agents, [], max_round=3, admin_name="A1") - -group_chat.reset() -print(group_chat.messages) # Output: [] -``` - -## References - -1. [Swarms Documentation](https://docs.swarms.org/) -2. [Role-Based Conversations in Multi-Agent Systems](https://arxiv.org/abs/2010.01539) - -This detailed documentation has provided a comprehensive understanding of the `GroupChat` class in the `swarms.structs` module of the `swarms` library. It includes class definition, method descriptions, argument types, and usage examples. - -*(Sample Documentation - 950 words)* diff --git a/docs/swarms/structs/groupchatmanager.md b/docs/swarms/structs/groupchatmanager.md deleted file mode 100644 index cb2ce035..00000000 --- a/docs/swarms/structs/groupchatmanager.md +++ /dev/null @@ -1,90 +0,0 @@ -# GroupChatManager -Documentation: - -The `GroupChatManager` class is designed for managing group chat interactions between agents. It allows you to create and manage group chats among multiple agents. The `GroupChatManager` requires two main arguments - the `groupchat` of type `GroupChat` which indicates the actual group chat object and `selector` of type `Agent` which specifies the agent who is the selector or the initiator of the chat. - -This class provides a variety of features and functions such as maintaining and appending messages, managing the communication rounds, interacting between different agents and extracting replies. - -Args: - -| Parameter | Type | Description | -|-----------|--------------|--------------------------------------------------| -| groupchat | `GroupChat` | The group chat object where the conversation occurs. | -| selector | `Agent` | The agent who is the selector or the initiator of the chat. | -Usage: - -```python -from swarms import GroupChatManager -from swarms.structs.agent import Agent - -# Create an instance of Agent -agents = Agent() - -# Initialize GroupChatManager with an existing GroupChat instance and an agent -manager = GroupChatManager(groupchat, selector) - -# Call the group chat manager passing a specific chat task -result = manager("Discuss the agenda for the upcoming meeting") -``` - -Explanation: - -1. First, you import the `GroupChatManager` class and the `Agent` class from the `swarms` library. - -2. Then, you create an instance of the `Agent`. - -3. After that, you initialize the `GroupChatManager` with an existing `GroupChat` instance and an agent. - -4. Finally, you call the group chat manager, passing a specific chat task and receive the response. - -Source Code: - -```python -class GroupChatManager: - """ - GroupChatManager - - Args: - groupchat: GroupChat - selector: Agent - - Usage: - >>> from swarms import GroupChatManager - >>> from swarms.structs.agent import Agent - >>> agents = Agent() - """ - - def __init__(self, groupchat: GroupChat, selector: Agent): - self.groupchat = groupchat - self.selector = selector - - def __call__(self, task: str): - """Call 'GroupChatManager' instance as a function. - - Args: - task (str): The task to be performed during the group chat. - - Returns: - str: The response from the group chat. - """ - self.groupchat.messages.append({"role": self.selector.name, "content": task}) - for i in range(self.groupchat.max_round): - speaker = self.groupchat.select_speaker( - last_speaker=self.selector, selector=self.selector - ) - reply = speaker.generate_reply( - self.groupchat.format_history(self.groupchat.messages) - ) - self.groupchat.messages.append(reply) - print(reply) - if i == self.groupchat.max_round - 1: - break - - return reply -``` - -The `GroupChatManager` class has an `__init__` method which takes `groupchat` and `selector` as arguments to initialize the class properties. It also has a `__call__` method to perform the group chat task and provide the appropriate response. - -In the `__call__` method, it appends the message with the speaker’s role and their content. It then iterates over the communication rounds, selects speakers, generates replies and appends messages to the group chat. Finally, it returns the response. - -The above example demonstrates how to use the `GroupChatManager` class to manage group chat interactions. You can further customize this class based on specific requirements and extend its functionality as needed. diff --git a/docs/swarms/structs/stackoverflowswarm.md b/docs/swarms/structs/stackoverflowswarm.md deleted file mode 100644 index c3e83b47..00000000 --- a/docs/swarms/structs/stackoverflowswarm.md +++ /dev/null @@ -1,114 +0,0 @@ -# StackOverflowSwarm Class Documentation - -## Overview - -The `StackOverflowSwarm` class is part of the `swarms.structs` library. It is designed to simulate a collective intelligence or swarm intelligence scenario where multiple individual agents (referred to as `Agent` objects) come together to solve problems or answer questions typically found on platforms like Stack Overflow. This class is helpful in experiments involving cooperative multi-agent interactions, decision-making, and problem-solving, primarily when applied to question-and-answer scenarios. - -Swarm intelligence is modeled after social insects and natural systems where the collective behavior of decentralized, self-organized systems leads to the solving of complex tasks. `StackOverflowSwarm`, as a mini-framework within this library, provides a way to simulate such systems programmatically. - -The design of the `StackOverflowSwarm` class is intended to allow easy tracking of multi-agent interactions, the ability to autosave conversations, provide verbose outputs for monitoring purposes, and deal with problem-solving in a structured manner. This document provides a deep dive into the class' mechanisms, its architecture, and comprehensive usage examples for developers and researchers interested in swarm intelligence applications. - -## Class Definition - -### StackOverflowSwarm Attributes: - -| Attribute | Type | Description | -|-----------------|---------------------|-----------------------------------------------------------------------------| -| `agents` | `List[Agent]` | The list of agents in the swarm. | -| `autosave` | `bool` | Flag indicating whether to automatically save the conversation. | -| `verbose` | `bool` | Flag indicating whether to display verbose output. | -| `save_filepath` | `str` | The filepath to save the conversation. | -| `conversation` | `Conversation` | The conversation object for storing the interactions. | -| `eval_agent` | `Agent` or `None` | An optional evaluation agent within the swarm (not used in provided code). | -| `upvotes` | `int` | Counter for the number of upvotes per post (initialized as 0). | -| `downvotes` | `int` | Counter for the number of downvotes per post (initialized as 0). | -| `forum` | `List` | An empty list to represent the forum for the agents to interact. | - -### StackOverflowSwarm Method: `__init__` - -| Argument | Type | Default | Description | -|------------------|---------------|----------------------------------|---------------------------------------------------| -| `agents` | `List[Agent]` | Required | The list of agents in the swarm. | -| `autosave` | `bool` | `False` | Whether to automatically save the conversation. | -| `verbose` | `bool` | `False` | Whether to display verbose output. | -| `save_filepath` | `str` | `"stack_overflow_swarm.json"` | The filepath to save the conversation. | -| `eval_agent` | `Agent` | `None` | An optional eval agent (not entirely implemented).| -| `*args` | `variable` | | Variable length argument list. | -| `**kwargs` | `variable` | | Arbitrary keyword arguments. | - -### StackOverflowSwarm Method: `run` - -| Argument | Type | Description | -|-----------|----------|------------------------------------------------------------------------| -| `task` | `str` | The task to be performed by the agents. | -| `*args` | `variable`| Variable length argument list. | -| `**kwargs`| `variable`| Arbitrary keyword arguments. | - -#### Return - -| Type | Description | -|--------------|---------------------------------------------| -| `List[str]` | The conversation history as a list of strings.| - -### API Usage and Examples - -**Initializing and Running a StackOverflowSwarm** - -```python -from swarms.structs.agent import Agent -from swarms.structs.stack_overflow_swarm import StackOverflowSwarm - - -# Define custom Agents with some logic (placeholder for actual Agent implementation) -class CustomAgent(Agent): - def run(self, conversation, *args, **kwargs): - return "This is a response from CustomAgent." - - -# Initialize agents -agent1 = CustomAgent(ai_name="Agent1") -agent2 = CustomAgent(ai_name="Agent2") - -# Create a swarm -swarm = StackOverflowSwarm(agents=[agent1, agent2], autosave=True, verbose=True) - -# Define a task -task_description = "How can I iterate over a list in Python?" - -# Run the swarm with a task -conversation_history = swarm.run(task_description) - -# Output the conversation history -print(conversation_history) -``` - -### How the Swarm Works - -The `StackOverflowSwarm` starts by initializing agents, autosave preferences, conversation object, upvote/downvote counters, and a forum list to manage inter-agent communication. When the `run` method is invoked, it adds the given task to the conversation, logging this addition if verbose mode is enabled. - -Each agent in the swarm runs its logic, possibly taking the current conversation history into consideration (the exact logic depends on the agent's implementation) and then responds to the task. Each agent's response is added to the conversation and logged. - -If autosave is enabled, the conversation is saved to the specified file path. The `run` method ultimately returns the conversation history as a string, which could also be a serialized JSON depending on the implementation of `Agent` and `Conversation`. - -### Considerations - -- This is a high-level conceptual example and lacks the detailed implementations of `Agent`, `Conversation`, and the actual `run` logic within each `Agent`. -- The `eval_agent` attribute and related logic have not been implemented in the provided code. - -### Common Issues - -- Since the implementation of `Agent` and `Conversation` is not provided, one must ensure these components are compatible with the `StackOverflowSwarm` class for the interconnectivity and conversation saving/management to function correctly. -- It is essential to handle exceptions and errors within the `run` methods of each `Agent` to ensure that the failure of one agent does not halt the entire swarm. - -### Additional Resources - -For further exploration into swarm intelligence, collective behavior in natural and artificial systems, and multi-agent problem solving: - -1. Bonabeau, E., Dorigo, M., & Theraulaz, G. (1999). Swarm Intelligence: From Natural to Artificial Systems. Oxford University Press. -2. Kennedy, J., Eberhart, R. C., & Shi, Y. (2001). Swarm Intelligence. Morgan Kaufmann. -3. [Multi-Agent Systems Virtual Labs](http://multiagent.fr) -4. [PyTorch – Deep Learning and Artificial Intelligence](https://pytorch.org) - -### Note - -This documentation provides an overview of the `StackOverflowSwarm` class, its attributes, and methods. It should be adapted and expanded upon with actual code implementations for proper functionality and achieving the desired behavior in a swarm-based system. diff --git a/docs/swarms/structs/workflow.md b/docs/swarms/structs/workflow.md deleted file mode 100644 index 2ab1a6e2..00000000 --- a/docs/swarms/structs/workflow.md +++ /dev/null @@ -1,200 +0,0 @@ -# Module/Class Name: Workflow -=========================== - -The `Workflow` class is a part of the `swarms` library and is used to create and execute a workflow of tasks. It provides a way to define a sequence of tasks and execute them in order, with the output of each task being used as the input for the next task. - -## Overview and Introduction -------------------------- - -The `Workflow` class is designed to simplify the execution of a series of tasks by providing a structured way to define and execute them. It allows for sequential execution of tasks, with the output of each task being passed as input to the next task. This makes it easy to create complex workflows and automate multi-step processes. - - -## Class Definition: Workflow - - -The `Workflow` class is a powerful tool provided by the `swarms` library that allows users to create and execute a sequence of tasks in a structured and automated manner. It simplifies the process of defining and executing complex workflows by providing a clear and intuitive interface. - -## Why Use Workflows? ------------------- - -Workflows are essential in many domains, including data processing, automation, and task management. They enable the automation of multi-step processes, where the output of one task serves as the input for the next task. By using workflows, users can streamline their work, reduce manual effort, and ensure consistent and reliable execution of tasks. - -The `Workflow` class provides a way to define and execute workflows in a flexible and efficient manner. It allows users to define the sequence of tasks, specify dependencies between tasks, and execute them in order. This makes it easier to manage complex processes and automate repetitive tasks. - -## How Does it Work? ------------------ - -The `Workflow` class consists of two main components: the `Task` class and the `Workflow` class itself. Let's explore each of these components in detail. - -### Task Class - -The `Task` class represents an individual task within a workflow. Each task is defined by a string description. It contains attributes such as `parents`, `children`, `output`, and `structure`. - -The `parents` attribute is a list that stores references to the parent tasks of the current task. Similarly, the `children` attribute is a list that stores references to the child tasks of the current task. These attributes allow for the definition of task dependencies and the establishment of the workflow's structure. - -The `output` attribute stores the output of the task, which is generated when the task is executed. Initially, the output is set to `None`, indicating that the task has not been executed yet. - -The `structure` attribute refers to the `Workflow` object that the task belongs to. This attribute is set when the task is added to the workflow. - -The `Task` class also provides methods such as `add_child` and `execute`. The `add_child` method allows users to add child tasks to the current task, thereby defining the workflow's structure. The `execute` method is responsible for executing the task by running the associated agent's `run` method with the task as input. It returns the response generated by the agent's `run` method. - -### Workflow Class - -The `Workflow` class is the main class that orchestrates the execution of tasks in a workflow. It takes an agent object as input, which is responsible for executing the tasks. The agent object should have a `run` method that accepts a task as input and returns a response. - -The `Workflow` class provides methods such as `add`, `run`, and `context`. The `add` method allows users to add tasks to the workflow. It returns the newly created task object, which can be used to define task dependencies. The `run` method executes the workflow by running each task in order. It returns the last task in the workflow. The `context` method returns a dictionary containing the context information for a given task, including the parent output, parent task, and child task. - -The `Workflow` class also has attributes such as `tasks` and `parallel`. The `tasks` attribute is a list that stores references to all the tasks in the workflow. The `parallel` attribute is a boolean flag that determines whether the tasks should be executed in parallel or sequentially. - -When executing the workflow, the `run` method iterates over the tasks in the workflow and executes each task in order. If the `parallel` flag is set to `True`, the tasks are executed in parallel using a `ThreadPoolExecutor`. Otherwise, the tasks are executed sequentially. - -## Benefits and Use Cases ----------------------- - -The `Workflow` class provides several benefits and use cases: - -- Automation: Workflows automate multi-step processes, reducing manual effort and increasing efficiency. By defining the sequence of tasks and their dependencies, users can automate repetitive tasks and ensure consistent execution. - -- Flexibility: Workflows can be easily customized and modified to suit specific needs. Users can add, remove, or rearrange tasks as required, allowing for dynamic and adaptable workflows. - -- Error Handling: Workflows provide a structured approach to error handling. If an error occurs during the execution of a task, the workflow can be designed to handle the error gracefully and continue with the remaining tasks. - -- Collaboration: Workflows facilitate collaboration by providing a shared structure for task execution. Multiple users can contribute to the workflow by adding or modifying tasks, enabling teamwork and coordination. - -- Reproducibility: Workflows ensure reproducibility by defining a clear sequence of tasks. By following the same workflow, users can achieve consistent results and easily reproduce previous analyses or processes. - -Overall, the `Workflow` class is a valuable tool for managing and executing complex processes. It simplifies the creation - - -## Class Parameters ----------------- - -- `agent` (Any): The agent object that will be used to execute the tasks. It should have a `run` method that takes a task as input and returns a response. -- `parallel` (bool): If `True`, the tasks will be executed in parallel using a `ThreadPoolExecutor`. Default: `False`. - -## Class Methods -------------- - -### `add(task: str) -> Task` - -Adds a new task to the workflow. - -- `task` (str): The task to be added. - -Returns: - -- `Task`: The newly created task object. - -### `run(*args) -> Task` - -Executes the workflow by running each task in order. - -Returns: - -- `Task`: The last task in the workflow. - -### `context(task: Task) -> Dict[str, Any]` - -Returns a dictionary containing the context information for a given task. The context includes the parent output, parent task, and child task. - -- `task` (Task): The task for which the context information is required. - -Returns: - -- `Dict[str, Any]`: A dictionary containing the context information. - -## Task Class ----------- - -The `Task` class is a nested class within the `Workflow` class. It represents an individual task in the workflow. - -### Task Parameters - -- `task` (str): The task description. - -### Task Methods - -### `add_child(child: 'Workflow.Task')` - -Adds a child task to the current task. - -- `child` ('Workflow.Task'): The child task to be added. - -### `execute() -> Any` - -Executes the task by running the associated agent's `run` method with the task as input. - -Returns: - -- `Any`: The response from the agent's `run` method. - - -## Functionality and Usage ------------------------------------ - -To use the `Workflow` class, follow these steps: - -1. Create an instance of the `Workflow` class, providing an agent object that has a `run` method. This agent will be responsible for executing the tasks in the workflow. - -``` -from swarms import Workflow - -# Create an instance of the Workflow class -workflow = Workflow(agent=my_agent) -``` - - -1. Add tasks to the workflow using the `add` method. Each task should be a string description. - -``` -# Add tasks to the workflow -task1 = workflow.add("Task 1") -task2 = workflow.add("Task 2") -task3 = workflow.add("Task 3") -``` - - -1. Define the sequence of tasks by adding child tasks to each task using the `add_child` method. - -``` -# Define the sequence of tasks -task1.add_child(task2) -task2.add_child(task3) -``` - - -1. Execute the workflow using the `run` method. This will run each task in order, with the output of each task being passed as input to the next task. - -``` -# Execute the workflow -workflow.run() -``` - - -1. Access the output of each task using the `output` attribute of the task object. - -``` -# Access the output of each task -output1 = task1.output -output2 = task2.output -output3 = task3.output -``` - - -1. Optionally, you can run the tasks in parallel by setting the `parallel` parameter to `True` when creating the `Workflow` object. - -``` -# Create a parallel workflow -parallel_workflow = Workflow(agent=my_agent, parallel=True) -``` - - -1. You can also access the context information for a task using the `context` method. This method returns a dictionary containing the parent output, parent task, and child task for the given task. - -``` -# Access the context information for a task -context = workflow.context(task2) -parent_output = context["parent_output"] -parent_task = context["parent"] -child_task = context["child"] -``` diff --git a/docs/swarms/structs/yaml_model.md b/docs/swarms/structs/yaml_model.md index 4b261415..010e5e85 100644 --- a/docs/swarms/structs/yaml_model.md +++ b/docs/swarms/structs/yaml_model.md @@ -1,7 +1,5 @@ # YamlModel: A Pydantic Model for YAML Data -### Introduction - The `YamlModel` class, derived from `BaseModel` in Pydantic, offers a convenient way to work with YAML data in your Python applications. It provides methods for serialization (converting to YAML), deserialization (creating an instance from YAML), and schema generation. This documentation will delve into the functionalities of `YamlModel` and guide you through its usage with illustrative examples. ### Purpose and Functionality diff --git a/playground/structs/search_arena/search_agents.py b/playground/structs/search_arena/search_agents.py index 7d0c9fd3..595338d2 100644 --- a/playground/structs/search_arena/search_agents.py +++ b/playground/structs/search_arena/search_agents.py @@ -7,7 +7,6 @@ from dotenv import load_dotenv from swarms import Agent, OpenAIChat from swarms.tools.prebuilt.bing_api import fetch_web_articles_bing_api -from swarms.utils.loguru_logger import logger load_dotenv()