pull/488/head
Kye Gomez 7 months ago
parent 7f577acca3
commit c0829035a9

@ -38,17 +38,17 @@ Orchestrate enterprise-grade agents for multi-agent collaboration and orchestrat
</li>
</ul>
</div>
<div style="width:30%">
<div style="width:25%">
<h2>How-To Guides</h2>
<ul>
<li>
<a href="./how-to/Installing-Swarms">
<a href="swarms/install/install.md">
Installing Swarms
</a>
</li>
<li>
<a href="./how-to/Creating-a-Crew-and-kick-it-off">
Getting Started
<a href="swarms/install/docker_setup.md">
Docker Setup
</a>
</li>
<li>
@ -57,13 +57,13 @@ Orchestrate enterprise-grade agents for multi-agent collaboration and orchestrat
</a>
</li>
<li>
<a href="./how-to/Sequential">
Using Sequential Process
<a href="swarms/structs/agent_rearrange.md">
Multi-Agent Flows
</a>
</li>
<li>
<a href="./how-to/Hierarchical">
Using Hierarchical Process
<a href="swarms/structs/sequential_workflow.md">
Sequential Workflows
</a>
</li>
<li>
@ -88,22 +88,22 @@ Orchestrate enterprise-grade agents for multi-agent collaboration and orchestrat
</li>
</ul>
</div>
<div style="width:30%">
<div style="width:25%">
<h2>Examples</h2>
<ul>
<li>
<a target='_blank' href="https://github.com/kyegomez/Swarms-examples/tree/main/prep-for-a-meeting">
Prepare for meetings
<a target='_blank' href="applications/business-analyst-agent.md">
Swarm of Buisness Analysts for Business Reports
</a>
</li>
<li>
<a target='_blank' href="https://github.com/kyegomez/Swarms-examples/tree/main/trip_planner">
Trip Planner Crew
<a target='_blank' href="https://medium.com/@kyeg/building-compliance-agents-with-chroma-db-llama3-sop-prompting-0ed3e73559d2">
Compliance Swarm for Customer Privacy
</a>
</li>
<li>
<a target='_blank' href="https://github.com/kyegomez/Swarms-examples/tree/main/instagram_post">
Create Instagram Post
<a target='_blank' href="https://medium.com/@kyeg/announcing-neosapiens-self-replicating-swarms-0a47410aafa7">
Self-Replicating Hiearchical Swarms
</a>
</li>
<li>
@ -128,4 +128,29 @@ Orchestrate enterprise-grade agents for multi-agent collaboration and orchestrat
</li>
</ul>
</div>
<div style="width:25%">
<h2>Community</h2>
<ul>
<li>
<a target='_blank' href="https://discord.gg/3Zck7nX6">
Join the Swarms Community!
</a>
</li>
<li>
<a target='_blank' href="https://github.com/kyegomez/swarm-ecosystem">
Swarms Ecosystem
</a>
</li>
<li>
<a target='_blank' href="https://cal.com/swarms/swarms-onboarding-session">
Support Team
</a>
</li>
<li>
<a target='_blank' href="https://cal.com/swarms/swarms-onboarding-session">
Book a 1 on 1 Call With Founder: Kye
</a>
</li>
</ul>
</div>
</div>

@ -0,0 +1,151 @@
"""
$ pip install swarms
- Add docs into the database
- Use better llm
- use better prompts [System and SOPs]
- Use a open source model like Command R
- Better SOPS ++ System Prompts
-
"""
from swarms import Agent, OpenAIChat
from playground.memory.chromadb_example import ChromaDB
from swarms.tools.prebuilt.bing_api import fetch_web_articles_bing_api
import os
from dotenv import load_dotenv
load_dotenv()
# Let's create a text file with the provided prompt.
research_system_prompt = """
Research Agent LLM Prompt: Summarizing Sources and Content
Objective:
Your task is to summarize the provided sources and the content within those sources. The goal is to create concise, accurate, and informative summaries that capture the key points of the original content.
Instructions:
1. Identify Key Information:
- Extract the most important information from each source. Focus on key facts, main ideas, significant arguments, and critical data.
2. Summarize Clearly and Concisely:
- Use clear and straightforward language. Avoid unnecessary details and keep the summary concise.
- Ensure that the summary is coherent and easy to understand.
3. Preserve Original Meaning:
- While summarizing, maintain the original meaning and intent of the content. Do not omit essential information that changes the context or understanding.
4. Include Relevant Details:
- Mention the source title, author, publication date, and any other relevant details that provide context.
5. Structure:
- Begin with a brief introduction to the source.
- Follow with a summary of the main content.
- Conclude with any significant conclusions or implications presented in the source.
"""
def movers_agent_system_prompt():
return """
The Movers Agent is responsible for providing users with fixed-cost estimates for moving services
based on the distance between their current location and destination, and the number of rooms in their home.
Additionally, the agent allows users to attempt negotiation for better deals using the Retell API.
Responsibilities:
- Provide fixed-cost estimates based on distance and room size.
- Allow users to attempt negotiation for better deals using the Retell API.
Details:
- Fixed Costs: Predefined costs for each of the 10 moving companies, with variations based on distance and number of rooms.
- Distance Calculation: Use a fixed formula to estimate distances and costs.
- Room Size: Standard sizes based on the number of rooms will be used to determine the base cost.
- Negotiation: Users can click a "negotiate" button to initiate negotiation via Retell API.
Tools and Resources Used:
- Google Maps API: For calculating distances between the current location and destination.
- Retell API: For simulating negotiation conversations.
- Streamlit: For displaying estimates and handling user interactions.
Example Workflow:
1. User inputs their current location, destination, and number of rooms.
2. The agent calculates the distance and estimates the cost using predefined rates.
3. Displays the estimates from 10 different moving companies.
4. Users can click "negotiate" to simulate negotiation via Retell API, adjusting the price within a predefined range.
"""
# Example usage
# Initialize
memory = ChromaDB(
output_dir="research_base",
n_results=2,
)
llm = OpenAIChat(
temperature=0.2,
max_tokens=3500,
openai_api_key=os.getenv("OPENAI_API_KEY"),
)
# Initialize the agent
agent = Agent(
agent_name="Research Agent",
system_prompt=research_system_prompt,
llm=llm,
max_loops="auto",
autosave=True,
dashboard=False,
interactive=True,
# long_term_memory=memory,
tools=[fetch_web_articles_bing_api],
)
# # Initialize the agent
# agent = Agent(
# agent_name="Movers Agent",
# system_prompt=movers_agent_system_prompt(),
# llm=llm,
# max_loops=1,
# autosave=True,
# dashboard=False,
# interactive=True,
# # long_term_memory=memory,
# # tools=[fetch_web_articles_bing_api],
# )
def perplexity_agent(task: str = None, *args, **kwargs):
"""
This function takes a task as input and uses the Bing API to fetch web articles related to the task.
It then combines the task and the fetched articles as prompts and runs them through an agent.
The agent generates a response based on the prompts and returns it.
Args:
task (str): The task for which web articles need to be fetched.
Returns:
str: The response generated by the agent.
"""
out = fetch_web_articles_bing_api(
task,
)
# Sources
sources = [task, out]
sources_prompts = "".join(sources)
# Run a question
agent_response = agent.run(sources_prompts)
return agent_response
out = perplexity_agent(
"What are the indian food restaurant names in standford university avenue? What are their cost ratios"
)
print(out)

@ -35,8 +35,6 @@ def parse_and_merge_logs(logs: List[Dict[str, str]]) -> str:
def fetch_web_articles_bing_api(
query: str = None,
subscription_key: str = check_bing_api_key(),
return_str: bool = False,
) -> List[Dict[str, str]]:
"""
Fetches four articles from Bing Web Search API based on the given query.
@ -48,8 +46,7 @@ def fetch_web_articles_bing_api(
Returns:
List[Dict[str, str]]: A list of dictionaries containing article details.
"""
if subscription_key is None:
subscription_key = check_bing_api_key()
subscription_key = check_bing_api_key()
url = "https://api.bing.microsoft.com/v7.0/search"
headers = {"Ocp-Apim-Subscription-Key": subscription_key}

Loading…
Cancel
Save