parent
3c73261c7c
commit
978f41c245
@ -0,0 +1,127 @@
|
|||||||
|
## Swarms Framework Conceptual Breakdown
|
||||||
|
|
||||||
|
The `swarms` framework is a sophisticated structure designed to orchestrate the collaborative work of multiple agents in a hierarchical manner. This breakdown provides a conceptual and visual representation of the framework, highlighting the interactions between models, tools, memory, agents, and swarms.
|
||||||
|
|
||||||
|
### Hierarchical Structure
|
||||||
|
|
||||||
|
The framework can be visualized as a multi-layered hierarchy:
|
||||||
|
|
||||||
|
1. **Models, Tools, Memory**: These form the foundational components that agents utilize to perform tasks.
|
||||||
|
2. **Agents**: Individual entities that encapsulate specific functionalities, utilizing models, tools, and memory.
|
||||||
|
3. **Swarm**: A collection of multiple agents working together in a coordinated manner.
|
||||||
|
4. **Structs**: High-level structures that organize and manage swarms, enabling complex workflows and interactions.
|
||||||
|
|
||||||
|
### Visual Representation
|
||||||
|
|
||||||
|
Below are visual graphs illustrating the hierarchical and tree structure of the `swarms` framework.
|
||||||
|
|
||||||
|
#### 1. Foundational Components: Models, Tools, Memory
|
||||||
|
|
||||||
|
```mermaid
|
||||||
|
graph TD;
|
||||||
|
Models --> Agents
|
||||||
|
Tools --> Agents
|
||||||
|
Memory --> Agents
|
||||||
|
subgraph Foundational_Components
|
||||||
|
Models
|
||||||
|
Tools
|
||||||
|
Memory
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 2. Agents and Their Interactions
|
||||||
|
|
||||||
|
```mermaid
|
||||||
|
graph TD;
|
||||||
|
Agents --> Swarm
|
||||||
|
subgraph Agents_Collection
|
||||||
|
Agent1
|
||||||
|
Agent2
|
||||||
|
Agent3
|
||||||
|
end
|
||||||
|
subgraph Individual_Agents
|
||||||
|
Agent1 --> Models
|
||||||
|
Agent1 --> Tools
|
||||||
|
Agent1 --> Memory
|
||||||
|
Agent2 --> Models
|
||||||
|
Agent2 --> Tools
|
||||||
|
Agent2 --> Memory
|
||||||
|
Agent3 --> Models
|
||||||
|
Agent3 --> Tools
|
||||||
|
Agent3 --> Memory
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 3. Multiple Agents Form a Swarm
|
||||||
|
|
||||||
|
```mermaid
|
||||||
|
graph TD;
|
||||||
|
Swarm1 --> Struct
|
||||||
|
Swarm2 --> Struct
|
||||||
|
Swarm3 --> Struct
|
||||||
|
subgraph Swarms_Collection
|
||||||
|
Swarm1
|
||||||
|
Swarm2
|
||||||
|
Swarm3
|
||||||
|
end
|
||||||
|
subgraph Individual_Swarms
|
||||||
|
Swarm1 --> Agent1
|
||||||
|
Swarm1 --> Agent2
|
||||||
|
Swarm1 --> Agent3
|
||||||
|
Swarm2 --> Agent4
|
||||||
|
Swarm2 --> Agent5
|
||||||
|
Swarm2 --> Agent6
|
||||||
|
Swarm3 --> Agent7
|
||||||
|
Swarm3 --> Agent8
|
||||||
|
Swarm3 --> Agent9
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 4. Structs Organizing Multiple Swarms
|
||||||
|
|
||||||
|
```mermaid
|
||||||
|
graph TD;
|
||||||
|
Struct --> Swarms_Collection
|
||||||
|
subgraph High_Level_Structs
|
||||||
|
Struct1
|
||||||
|
Struct2
|
||||||
|
Struct3
|
||||||
|
end
|
||||||
|
subgraph Struct1
|
||||||
|
Swarm1
|
||||||
|
Swarm2
|
||||||
|
end
|
||||||
|
subgraph Struct2
|
||||||
|
Swarm3
|
||||||
|
end
|
||||||
|
subgraph Struct3
|
||||||
|
Swarm4
|
||||||
|
Swarm5
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
### Directory Breakdown
|
||||||
|
|
||||||
|
The directory structure of the `swarms` framework is organized to support its hierarchical architecture:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
swarms/
|
||||||
|
├── agents/
|
||||||
|
├── artifacts/
|
||||||
|
├── marketplace/
|
||||||
|
├── memory/
|
||||||
|
├── models/
|
||||||
|
├── prompts/
|
||||||
|
├── schemas/
|
||||||
|
├── structs/
|
||||||
|
├── telemetry/
|
||||||
|
├── tools/
|
||||||
|
├── utils/
|
||||||
|
└── __init__.py
|
||||||
|
```
|
||||||
|
|
||||||
|
### Summary
|
||||||
|
|
||||||
|
The `swarms` framework is designed to facilitate complex multi-agent interactions through a structured and layered approach. By leveraging foundational components like models, tools, and memory, individual agents are empowered to perform specialized tasks. These agents are then coordinated within swarms to achieve collective goals, and swarms are managed within high-level structs to orchestrate sophisticated workflows.
|
||||||
|
|
||||||
|
This hierarchical design ensures scalability, flexibility, and robustness, making the `swarms` framework a powerful tool for various applications in AI, data analysis, optimization, and beyond.
|
@ -1,127 +0,0 @@
|
|||||||
## Swarms Framework Conceptual Breakdown
|
|
||||||
|
|
||||||
The `swarms` framework is a sophisticated structure designed to orchestrate the collaborative work of multiple agents in a hierarchical manner. This breakdown provides a conceptual and visual representation of the framework, highlighting the interactions between models, tools, memory, agents, and swarms.
|
|
||||||
|
|
||||||
### Hierarchical Structure
|
|
||||||
|
|
||||||
The framework can be visualized as a multi-layered hierarchy:
|
|
||||||
|
|
||||||
1. **Models, Tools, Memory**: These form the foundational components that agents utilize to perform tasks.
|
|
||||||
2. **Agents**: Individual entities that encapsulate specific functionalities, utilizing models, tools, and memory.
|
|
||||||
3. **Swarm**: A collection of multiple agents working together in a coordinated manner.
|
|
||||||
4. **Structs**: High-level structures that organize and manage swarms, enabling complex workflows and interactions.
|
|
||||||
|
|
||||||
### Visual Representation
|
|
||||||
|
|
||||||
Below are visual graphs illustrating the hierarchical and tree structure of the `swarms` framework.
|
|
||||||
|
|
||||||
#### 1. Foundational Components: Models, Tools, Memory
|
|
||||||
|
|
||||||
```mermaid
|
|
||||||
graph TD;
|
|
||||||
Models --> Agents
|
|
||||||
Tools --> Agents
|
|
||||||
Memory --> Agents
|
|
||||||
subgraph Foundational_Components
|
|
||||||
Models
|
|
||||||
Tools
|
|
||||||
Memory
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2. Agents and Their Interactions
|
|
||||||
|
|
||||||
```mermaid
|
|
||||||
graph TD;
|
|
||||||
Agents --> Swarm
|
|
||||||
subgraph Agents_Collection
|
|
||||||
Agent1
|
|
||||||
Agent2
|
|
||||||
Agent3
|
|
||||||
end
|
|
||||||
subgraph Individual_Agents
|
|
||||||
Agent1 --> Models
|
|
||||||
Agent1 --> Tools
|
|
||||||
Agent1 --> Memory
|
|
||||||
Agent2 --> Models
|
|
||||||
Agent2 --> Tools
|
|
||||||
Agent2 --> Memory
|
|
||||||
Agent3 --> Models
|
|
||||||
Agent3 --> Tools
|
|
||||||
Agent3 --> Memory
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 3. Multiple Agents Form a Swarm
|
|
||||||
|
|
||||||
```mermaid
|
|
||||||
graph TD;
|
|
||||||
Swarm1 --> Struct
|
|
||||||
Swarm2 --> Struct
|
|
||||||
Swarm3 --> Struct
|
|
||||||
subgraph Swarms_Collection
|
|
||||||
Swarm1
|
|
||||||
Swarm2
|
|
||||||
Swarm3
|
|
||||||
end
|
|
||||||
subgraph Individual_Swarms
|
|
||||||
Swarm1 --> Agent1
|
|
||||||
Swarm1 --> Agent2
|
|
||||||
Swarm1 --> Agent3
|
|
||||||
Swarm2 --> Agent4
|
|
||||||
Swarm2 --> Agent5
|
|
||||||
Swarm2 --> Agent6
|
|
||||||
Swarm3 --> Agent7
|
|
||||||
Swarm3 --> Agent8
|
|
||||||
Swarm3 --> Agent9
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 4. Structs Organizing Multiple Swarms
|
|
||||||
|
|
||||||
```mermaid
|
|
||||||
graph TD;
|
|
||||||
Struct --> Swarms_Collection
|
|
||||||
subgraph High_Level_Structs
|
|
||||||
Struct1
|
|
||||||
Struct2
|
|
||||||
Struct3
|
|
||||||
end
|
|
||||||
subgraph Struct1
|
|
||||||
Swarm1
|
|
||||||
Swarm2
|
|
||||||
end
|
|
||||||
subgraph Struct2
|
|
||||||
Swarm3
|
|
||||||
end
|
|
||||||
subgraph Struct3
|
|
||||||
Swarm4
|
|
||||||
Swarm5
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
### Directory Breakdown
|
|
||||||
|
|
||||||
The directory structure of the `swarms` framework is organized to support its hierarchical architecture:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
swarms/
|
|
||||||
├── agents/
|
|
||||||
├── artifacts/
|
|
||||||
├── marketplace/
|
|
||||||
├── memory/
|
|
||||||
├── models/
|
|
||||||
├── prompts/
|
|
||||||
├── schemas/
|
|
||||||
├── structs/
|
|
||||||
├── telemetry/
|
|
||||||
├── tools/
|
|
||||||
├── utils/
|
|
||||||
└── __init__.py
|
|
||||||
```
|
|
||||||
|
|
||||||
### Summary
|
|
||||||
|
|
||||||
The `swarms` framework is designed to facilitate complex multi-agent interactions through a structured and layered approach. By leveraging foundational components like models, tools, and memory, individual agents are empowered to perform specialized tasks. These agents are then coordinated within swarms to achieve collective goals, and swarms are managed within high-level structs to orchestrate sophisticated workflows.
|
|
||||||
|
|
||||||
This hierarchical design ensures scalability, flexibility, and robustness, making the `swarms` framework a powerful tool for various applications in AI, data analysis, optimization, and beyond.
|
|
File diff suppressed because it is too large
Load Diff
@ -1,78 +0,0 @@
|
|||||||
import time
|
|
||||||
import uuid
|
|
||||||
|
|
||||||
from fastapi import FastAPI, HTTPException
|
|
||||||
|
|
||||||
from swarms import Agent, OpenAIChat
|
|
||||||
from swarms.schemas.assistants_api import (
|
|
||||||
AssistantRequest,
|
|
||||||
AssistantResponse,
|
|
||||||
)
|
|
||||||
|
|
||||||
# Create an instance of the FastAPI application
|
|
||||||
app = FastAPI(debug=True, title="Assistant API", version="1.0")
|
|
||||||
|
|
||||||
# In-memory store for assistants
|
|
||||||
assistants_db = {}
|
|
||||||
|
|
||||||
|
|
||||||
# Health check endpoint
|
|
||||||
@app.get("/v1/health")
|
|
||||||
def health():
|
|
||||||
return {"status": "healthy"}
|
|
||||||
|
|
||||||
|
|
||||||
# Create an agent endpoint
|
|
||||||
@app.post("/v1/agents")
|
|
||||||
def create_agent(request: AssistantRequest):
|
|
||||||
try:
|
|
||||||
# Example initialization, in practice, you'd pass in more parameters
|
|
||||||
agent = Agent(
|
|
||||||
agent_name=request.name,
|
|
||||||
agent_description=request.description,
|
|
||||||
system_prompt=request.instructions,
|
|
||||||
llm=OpenAIChat(),
|
|
||||||
max_loops="auto",
|
|
||||||
autosave=True,
|
|
||||||
verbose=True,
|
|
||||||
# long_term_memory=memory,
|
|
||||||
stopping_condition="finish",
|
|
||||||
temperature=request.temperature,
|
|
||||||
# output_type="json_object"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Simulating running a task
|
|
||||||
task = ("What are the symptoms of COVID-19?",)
|
|
||||||
out = agent.run(task)
|
|
||||||
|
|
||||||
return {
|
|
||||||
"status": "Agent created and task run successfully",
|
|
||||||
"output": out,
|
|
||||||
}
|
|
||||||
except Exception as e:
|
|
||||||
raise HTTPException(status_code=400, detail=str(e))
|
|
||||||
|
|
||||||
|
|
||||||
# Create an assistant endpoint
|
|
||||||
@app.post("/v1/assistants", response_model=AssistantResponse)
|
|
||||||
def create_assistant(request: AssistantRequest):
|
|
||||||
assistant_id = str(uuid.uuid4())
|
|
||||||
assistant_data = request.dict()
|
|
||||||
assistant_data.update(
|
|
||||||
{
|
|
||||||
"id": assistant_id,
|
|
||||||
"object": "assistant",
|
|
||||||
"created_at": int(time.time()),
|
|
||||||
}
|
|
||||||
)
|
|
||||||
assistants_db[assistant_id] = assistant_data
|
|
||||||
return AssistantResponse(**assistant_data)
|
|
||||||
|
|
||||||
|
|
||||||
# Get assistant by ID endpoint
|
|
||||||
@app.get("/v1/assistants/{assistant_id}", response_model=AssistantResponse)
|
|
||||||
def get_assistant(assistant_id: str):
|
|
||||||
assistant = assistants_db.get(assistant_id)
|
|
||||||
if not assistant:
|
|
||||||
raise HTTPException(status_code=404, detail="Assistant not found")
|
|
||||||
return AssistantResponse(**assistant)
|
|
Loading…
Reference in new issue