[DOCS][CLEANUP]

pull/498/head
Kye Gomez 7 months ago
parent e4a3659fdb
commit 09838bd6f9

@ -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/) | | | | | [Connecting LLMs](https://docs.swarms.world/en/latest/swarms/models/custom_model/) | | |
| | [Customizing Agents](./how-to/Customizing-Agents) | | | | | [Customizing Agents](./how-to/Customizing-Agents) | | |
| | [Human Input on Execution](./how-to/Human-Input-on-Execution) | | | | | [Human Input on Execution](./how-to/Human-Input-on-Execution) | | |
| | [Agent Monitoring with AgentOps](./how-to/AgentOps-Observability) | | | | | [Agent Monitoring with AgentOps](https://medium.com/@kyeg/enterprise-grade-autonomous-agents-with-production-ready-monitoring-4295f6737bbf) | | |

@ -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 <a name="introduction"></a>
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 <a name="idea2image-class"></a>
The `Idea2Image` class is a fundamental module in the Swarms library, enabling the generation of images from text prompts.
### 2.1 Initialization Parameters <a name="initialization-parameters"></a>
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 <a name="methods-and-usage"></a>
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 <a name="methods-and-usage"></a>
Let's explore the methods provided by the `Idea2Image` class and how to use them effectively.
### 3.1 `llm_prompt` Method <a name="llm-prompt-method"></a>
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 <a name="generate-image-method"></a>
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 <a name="examples"></a>
Let's dive into practical examples to demonstrate the usage of the `Idea2Image` class.
### 4.1 Example 1: Generating an Image <a name="example-1-generating-an-image"></a>
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 <a name="additional-information"></a>
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 <a name="references-and-resources"></a>
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.

@ -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.

@ -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)
```

@ -1,8 +1,5 @@
# ToolAgent Documentation # 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 `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. 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.

@ -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)

@ -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.
---

@ -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 workflows 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.

@ -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)*

@ -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 speakers 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.

@ -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.

@ -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"]
```

@ -1,7 +1,5 @@
# YamlModel: A Pydantic Model for YAML Data # 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. 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 ### Purpose and Functionality

@ -7,7 +7,6 @@ from dotenv import load_dotenv
from swarms import Agent, OpenAIChat from swarms import Agent, OpenAIChat
from swarms.tools.prebuilt.bing_api import fetch_web_articles_bing_api from swarms.tools.prebuilt.bing_api import fetch_web_articles_bing_api
from swarms.utils.loguru_logger import logger
load_dotenv() load_dotenv()

Loading…
Cancel
Save