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

58 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,
)
# Tests agent
tests_agent = Agent(llm=llm, sop=TEST_SOP, max_loops=2,)
# 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:"
f" {documentation}"
)