diff --git a/docs/swarms/structs/swarm_network.md b/docs/swarms/structs/swarm_network.md new file mode 100644 index 00000000..6c81fc20 --- /dev/null +++ b/docs/swarms/structs/swarm_network.md @@ -0,0 +1,404 @@ +# SwarmNetwork Documentation + +The `SwarmNetwork` class is a powerful tool for managing a pool of agents, orchestrating task distribution, and scaling resources based on workload. It is designed to handle tasks efficiently by dynamically adjusting the number of agents according to the current demand. This class also provides an optional API for interacting with the agent pool, making it accessible for integration with other systems. + +### Key Features +- **Agent Pool Management**: Dynamically manage a pool of agents. +- **Task Queue Management**: Handle tasks through a queue system. +- **Agent Health Monitoring**: Monitor the health of agents. +- **Agent Pool Scaling**: Scale the agent pool up or down based on workload. +- **API**: Interact with the agent pool and task queue through a simple API. +- **Agent Deployment Options**: Run agents on threads, processes, containers, machines, or clusters. + +### Parameters + +| Parameter | Type | Default Value | Description | +|-----------------|--------------------|---------------|-----------------------------------------------------------------------------| +| name | str | None | The name of the swarm network. | +| description | str | None | A description of the swarm network. | +| agents | List[Agent] | None | A list of agents in the pool. | +| idle_threshold | float | 0.2 | The idle threshold for the agents. | +| busy_threshold | float | 0.7 | The busy threshold for the agents. | +| api_enabled | Optional[bool] | False | A flag to enable/disable the API. | +| logging_enabled | Optional[bool] | False | A flag to enable/disable logging. | +| api_on | Optional[bool] | False | A flag to enable/disable the FastAPI instance. | +| host | str | "0.0.0.0" | The host address for the FastAPI instance. | +| port | int | 8000 | The port number for the FastAPI instance. | +| swarm_callable | Optional[callable] | None | A callable to be executed by the swarm network. | +| *args | tuple | | Additional positional arguments. | +| **kwargs | dict | | Additional keyword arguments. | + +### Attributes + +| Attribute | Type | Description | +|------------------|--------------------|----------------------------------------------------------------| +| task_queue | queue.Queue | A queue for storing tasks. | +| idle_threshold | float | The idle threshold for the agents. | +| busy_threshold | float | The busy threshold for the agents. | +| agents | List[Agent] | A list of agents in the pool. | +| api_enabled | bool | A flag to enable/disable the API. | +| logging_enabled | bool | A flag to enable/disable logging. | +| host | str | The host address for the FastAPI instance. | +| port | int | The port number for the FastAPI instance. | +| swarm_callable | Optional[callable] | A callable to be executed by the swarm network. | +| agent_dict | dict | A dictionary of agents for easy access. | +| lock | threading.Lock | A lock for synchronizing access to shared resources. | + +## Methods + +#### Description +Initializes a new instance of the `SwarmNetwork` class. + +#### Parameters +- `name` (str): The name of the swarm network. +- `description` (str): A description of the swarm network. +- `agents` (List[Agent]): A list of agents in the pool. +- `idle_threshold` (float): The idle threshold for the agents. +- `busy_threshold` (float): The busy threshold for the agents. +- `api_enabled` (Optional[bool]): A flag to enable/disable the API. +- `logging_enabled` (Optional[bool]): A flag to enable/disable logging. +- `api_on` (Optional[bool]): A flag to enable/disable the FastAPI instance. +- `host` (str): The host address for the FastAPI instance. +- `port` (int): The port number for the FastAPI instance. +- `swarm_callable` (Optional[callable]): A callable to be executed by the swarm network. +- `*args`: Additional positional arguments. +- `**kwargs`: Additional keyword arguments. + +### `add_task` + +```python +def add_task(self, task) +``` + +#### Description +Adds a task to the task queue. + +#### Parameters +- `task` (_type_): The task to be added to the queue. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +swarm.add_task("task") +``` + +### `async_add_task` + +```python +async def async_add_task(self, task) +``` + +#### Description +Adds a task to the task queue asynchronously. + +#### Parameters +- `task` (_type_): The task to be added to the queue. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +await swarm.async_add_task("task") +``` + +### `run_single_agent` + +```python +def run_single_agent(self, agent_id, task: Optional[str], *args, **kwargs) +``` + +#### Description +Runs a task on a specific agent by ID. + +#### Parameters +- `agent_id` (_type_): The ID of the agent. +- `task` (str, optional): The task to be executed by the agent. +- `*args`: Additional positional arguments. +- `**kwargs`: Additional keyword arguments. + +#### Returns +- `_type_`: The output of the agent running the task. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +result = swarm.run_single_agent(agent.id, "task") +``` + +### `run_many_agents` + +```python +def run_many_agents(self, task: Optional[str] = None, *args, **kwargs) -> List +``` + +#### Description +Runs a task on all agents in the pool. + +#### Parameters +- `task` (str, optional): The task to be executed by the agents. +- `*args`: Additional positional arguments. +- `**kwargs`: Additional keyword arguments. + +#### Returns +- `List`: The output of all agents running the task. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent1 = Agent() +agent2 = Agent() +swarm = SwarmNetwork(agents=[agent1, agent2]) +results = swarm.run_many_agents("task") +``` + +### `list_agents` + +```python +def list_agents(self) +``` + +#### Description +Lists all agents in the pool. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +swarm.list_agents() +``` + +### `get_agent` + +```python +def get_agent(self, agent_id) +``` + +#### Description +Gets an agent by ID. + +#### Parameters +- `agent_id` (_type_): The ID of the agent to retrieve. + +#### Returns +- `_type_`: The agent with the specified ID. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +retrieved_agent = swarm.get_agent(agent.id) +``` + +### `add_agent` + +```python +def add_agent(self, agent: Agent) +``` + +#### Description +Adds an agent to the agent pool. + +#### Parameters +- `agent` (_type_): The agent to be added to the pool. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[]) +swarm.add_agent(agent) +``` + +### `remove_agent` + +```python +def remove_agent(self, agent_id) +``` + +#### Description +Removes an agent from the agent pool. + +#### Parameters +- `agent_id` (_type_): The ID of the agent to be removed. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +swarm.remove_agent(agent.id) +``` + +### ` + +async_remove_agent` + +```python +async def async_remove_agent(self, agent_id) +``` + +#### Description +Removes an agent from the agent pool asynchronously. + +#### Parameters +- `agent_id` (_type_): The ID of the agent to be removed. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +await swarm.async_remove_agent(agent.id) +``` + +### `scale_up` + +```python +def scale_up(self, num_agents: int = 1) +``` + +#### Description +Scales up the agent pool by adding new agents. + +#### Parameters +- `num_agents` (int, optional): The number of agents to add. Defaults to 1. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +swarm.scale_up(2) +``` + +### `scale_down` + +```python +def scale_down(self, num_agents: int = 1) +``` + +#### Description +Scales down the agent pool by removing agents. + +#### Parameters +- `num_agents` (int, optional): The number of agents to remove. Defaults to 1. + +#### Example + +```python +from swarms.structs.agent import Agent +from swarms.structs.swarm_net import SwarmNetwork + +agent = Agent() +swarm = SwarmNetwork(agents=[agent]) +swarm.scale_down(1) +``` + +### `run` + +#### Description +Runs the swarm network, starting the FastAPI application. + +#### Example + +```python + +import os + +from dotenv import load_dotenv + +# Import the OpenAIChat model and the Agent struct +from swarms import Agent, OpenAIChat, SwarmNetwork + +# 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, + openai_api_key=api_key, +) + +## Initialize the workflow +agent = Agent(llm=llm, max_loops=1, agent_name="Social Media Manager") +agent2 = Agent(llm=llm, max_loops=1, agent_name=" Product Manager") +agent3 = Agent(llm=llm, max_loops=1, agent_name="SEO Manager") + + +# Load the swarmnet with the agents +swarmnet = SwarmNetwork( + agents=[agent, agent2, agent3], +) + +# List the agents in the swarm network +out = swarmnet.list_agents() +print(out) + +# Run the workflow on a task +out = swarmnet.run_single_agent( + agent2.id, "Generate a 10,000 word blog on health and wellness." +) +print(out) + + +# Run all the agents in the swarm network on a task +out = swarmnet.run_many_agents("Generate a 10,000 word blog on health and wellness.") +print(out) +``` + +## Additional Information and Tips + +- **Error Handling**: Make use of try-except blocks to handle potential errors when adding tasks, running tasks, and managing agents. +- **Logging**: Enable logging to track the activity and status of the swarm network. +- **API**: The provided API allows for easy interaction with the swarm network and can be extended as needed. +- **Asynchronous Operations**: Utilize the asynchronous methods for non-blocking operations, especially in a production environment. +- **Scaling**: Adjust the scaling thresholds (`idle_threshold` and `busy_threshold`) based on the specific needs and workload patterns. + +## References and Resources + +- [Python Queue Documentation](https://docs.python.org/3/library/queue.html) +- [Threading in Python](https://docs.python.org/3/library/threading.html) +- [FastAPI Documentation](https://fastapi.tiangolo.com/) +- [Tenacity Documentation](https://tenacity.readthedocs.io/en/latest/) + +By following this documentation, users can effectively manage and utilize the `SwarmNetwork` class to handle dynamic workloads and maintain an efficient pool of agents. diff --git a/docs/swarms/structs/swarmnetwork.md b/docs/swarms/structs/swarmnetwork.md deleted file mode 100644 index efbdf279..00000000 --- a/docs/swarms/structs/swarmnetwork.md +++ /dev/null @@ -1,167 +0,0 @@ -```markdown -# Class Name: SwarmNetwork - -## Overview and Introduction -The `SwarmNetwork` class is responsible for managing the agents pool and the task queue. It also monitors the health of the agents and scales the pool up or down based on the number of pending tasks and the current load of the agents. - -## Class Definition - -The `SwarmNetwork` class has the following parameters: - -| Parameter | Type | Description | -|-------------------|-------------------|-------------------------------------------------------------------------------| -| idle_threshold | float | Threshold for idle agents to trigger scaling down | -| busy_threshold | float | Threshold for busy agents to trigger scaling up | -| agents | List[Agent] | List of agent instances to be added to the pool | -| api_enabled | Optional[bool] | Flag to enable/disable the API functionality | -| logging_enabled | Optional[bool] | Flag to enable/disable logging | -| other arguments | *args | Additional arguments | -| other keyword | **kwargs | Additional keyword arguments | - -## Function Explanation and Usage - -### Function: `add_task` -- Adds a task to the task queue -- Parameters: - - `task`: The task to be added to the queue -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.add_task("task") - ``` - -### Function: `async_add_task` -- Asynchronous function to add a task to the task queue -- Parameters: - - `task`: The task to be added to the queue -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - await swarm.async_add_task("task") - ``` - -### Function: `run_single_agent` -- Executes a task on a single agent -- Parameters: - - `agent_id`: ID of the agent to run the task on - - `task`: The task to be executed by the agent (optional) -- Returns: - - Result of the task execution -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.run_single_agent(agent_id, "task") - ``` - -### Function: `run_many_agents` -- Executes a task on all the agents in the pool -- Parameters: - - `task`: The task to be executed by the agents (optional) -- Returns: - - List of results from each agent -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.run_many_agents("task") - ``` - -### Function: `list_agents` -- Lists all the agents in the pool -- Returns: - - List of active agents -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.list_agents() - ``` - -### Function: `add_agent` -- Adds an agent to the agent pool -- Parameters: - - `agent`: Agent instance to be added to the pool -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork() - swarm.add_agent(agent) - ``` - -### Function: `remove_agent` -- Removes an agent from the agent pool -- Parameters: - - `agent_id`: ID of the agent to be removed from the pool -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.remove_agent(agent_id) - ``` - -### Function: `scale_up` -- Scales up the agent pool by adding new agents -- Parameters: - - `num_agents`: Number of agents to be added (optional) -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - swarm = SwarmNetwork() - swarm.scale_up(num_agents=5) - ``` - -### Function: `scale_down` -- Scales down the agent pool by removing existing agents -- Parameters: - - `num_agents`: Number of agents to be removed (optional) -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - swarm = SwarmNetwork(agents=[agent1, agent2, agent3, agent4, agent5]) - swarm.scale_down(num_agents=2) - ``` - -### Function: `create_apis_for_agents` -- Creates APIs for each agent in the pool (optional) -- Example: - ```python - from swarms.structs.agent import Agent - from swarms.structs.swarm_net import SwarmNetwork - - agent = Agent() - swarm = SwarmNetwork(agents=[agent]) - swarm.create_apis_for_agents() - ``` - -## Additional Information -- The `SwarmNetwork` class is an essential part of the swarms.structs library, enabling efficient management and scaling of agent pools. - -```