You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
swarms/playground/demos/developer_swarm/main.py

68 lines
1.4 KiB

"""
Swarm of developers that write documentation and tests for a given code snippet.
This is a simple example of how to use the swarms library to create a swarm of developers that write documentation and tests for a given code snippet.
The swarm is composed of two agents:
- Documentation agent: writes documentation for a given code snippet.
- Tests agent: writes tests for a given code snippet.
The swarm is initialized with a language model that is used by the agents to generate text. In this example, we use the OpenAI GPT-3 language model.
Agent:
Documentation agent -> Tests agent
"""
import os
from dotenv import load_dotenv
from swarms.models import OpenAIChat
from swarms.prompts.programming import DOCUMENTATION_SOP, TEST_SOP
from swarms.structs import Agent
load_dotenv()
api_key = os.getenv("OPENAI_API_KEY")
TASK = """
code
"""
# Initialize the language model
llm = OpenAIChat(
openai_api_key=api_key,
max_tokens=5000
)
# Documentation agent
documentation_agent = Agent(
llm=llm,
sop=DOCUMENTATION_SOP,
max_loops=1,
multi_modal=True
)
# Tests agent
tests_agent = Agent(
llm=llm,
sop=TEST_SOP,
max_loops=2,
multi_modal=True
)
# Run the documentation agent
documentation = documentation_agent.run(
f"Write documentation for the following code:{TASK}"
)
# Run the tests agent
tests = tests_agent.run(
f"Write tests for the following code:{TASK} here is the documentation: {documentation}"
)