diff --git a/docs/examples/flow.md b/docs/examples/flow.md index 8a82c8ca..454bd244 100644 --- a/docs/examples/flow.md +++ b/docs/examples/flow.md @@ -1,107 +1,126 @@ -# Walkthrough Guide: Getting Started with Swarms Module's Flow Feature +# Reliable Enterprise-Grade Autonomous Agents in Less Than 5 lines of Code +======================================================================== -## Introduction +Welcome to the walkthrough guide for beginners on using the "Flow" feature within the Swarms framework. This guide is designed to help you understand and utilize the capabilities of the Flow class for seamless and reliable interactions with autonomous agents. -Welcome to the walkthrough guide for beginners on using the "Flow" feature within the Swarms module. This guide is designed to help you understand and utilize the capabilities of the Flow class for seamless interactions with AI language models. +## Official Swarms Links +===================== +[Swarms website:](https://www.swarms.world/) -### Table of Contents +[Swarms Github:](https://github.com/kyegomez/swarms) -1. **Introduction to Swarms Flow Module** - - 1.1 What is Swarms? - - 1.2 Understanding the Flow Module +[Swarms docs:](https://swarms.apac.ai/en/latest/) -2. **Setting Up Your Development Environment** - - 2.1 Installing Required Dependencies - - 2.2 API Key Setup - - 2.3 Creating Your First Flow +[Swarm Community!](https://discord.gg/39j5kwTuW4)! -3. **Creating Your First Flow** - - 3.1 Importing Necessary Libraries - - 3.2 Defining Constants - - 3.3 Initializing the Flow Object - - 3.4 Initializing the Language Model - - 3.5 Running Your Flow - - 3.6 Understanding Flow Options +[Book a call with The Swarm Corporation here if you're interested in high performance custom swarms!](https://calendly.com/swarm-corp/30min) -4. **Advanced Flow Concepts** - - 4.1 Custom Stopping Conditions - - 4.2 Dynamic Temperature Handling - - 4.3 Providing Feedback on Responses - - 4.4 Retry Mechanism - - 4.5 Response Filtering - - 4.6 Interactive Mode +Now let's begin... -5. **Saving and Loading Flows** - - 5.1 Saving Flow State - - 5.2 Loading a Saved Flow +## [Table of Contents](https://github.com/kyegomez/swarms) +=========================================================================================================== -6. **Troubleshooting and Tips** - - 6.1 Analyzing Feedback - - 6.2 Troubleshooting Common Issues +1. Introduction to Swarms Flow Module -7. **Conclusion** +- 1.1 What is Swarms? +- 1.2 Understanding the Flow Module ---- +2. Setting Up Your Development Environment -### 1. Introduction to Swarms Flow Module +- 2.1 Installing Required Dependencies +- 2.2 API Key Setup +- 2.3 Creating Your First Flow -#### 1.1 What is Swarms? +3. Creating Your First Flow -Swarms is a powerful framework designed to provide tools and capabilities for working with language models and automating various tasks. It allows developers to interact with language models seamlessly. +- 3.1 Importing Necessary Libraries +- 3.2 Defining Constants +- 3.3 Initializing the Flow Object +- 3.4 Initializing the Language Model +- 3.5 Running Your Flow +- 3.6 Understanding Flow Options -## 1.2 Understanding the Flow Feature +4. Advanced Flow Concepts -### What is the Flow Feature? +- 4.1 Custom Stopping Conditions +- 4.2 Dynamic Temperature Handling +- 4.3 Providing Feedback on Responses +- 4.4 Retry Mechanism +- 4.5 Response Filtering +- 4.6 Interactive Mode -The Flow feature is a powerful component of the Swarms framework that allows developers to create a sequential, conversational interaction with AI language models. It enables developers to build multi-step conversations, generate long-form content, and perform complex tasks using AI. The Flow class provides autonomy to language models, enabling them to generate responses in a structured manner. +5. Saving and Loading Flows -### Key Concepts +- 5.1 Saving Flow State +- 5.2 Loading a Saved Flow -Before diving into the practical aspects, let's clarify some key concepts related to the Flow feature: +6. Troubleshooting and Tips + +- 6.1 Analyzing Feedback +- 6.2 Troubleshooting Common Issues + +7. Conclusion -- **Flow:** A Flow is an instance of the Flow class that represents an ongoing interaction with an AI language model. It consists of a series of steps and responses. +## [1. Introduction to Swarms Flow Module](https://github.com/kyegomez/swarms) +=================================================================================================================================================== + +### [1.1 What is Swarms?](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------- + +Swarms is a powerful framework designed to provide tools and capabilities for working with language models and automating various tasks. It allows developers to interact with language models seamlessly. + +## 1.2 Understanding the Flow Feature +================================== -- **Stopping Condition:** A stopping condition is a criterion that, when met, allows the Flow to stop generating responses. This can be user-defined and can depend on the content of the responses. +### [What is the Flow Feature?](https://github.com/kyegomez/swarms) +-------------------------------------------------------------------------------------------------------------------------- -- **Loop Interval:** The loop interval specifies the time delay between consecutive interactions with the AI model. +The Flow feature is a powerful component of the Swarms framework that allows developers to create a sequential, conversational interaction with AI language models. It enables developers to build multi-step conversations, generate long-form content, and perform complex tasks using AI. The Flow class provides autonomy to language models, enabling them to generate responses in a structured manner. -- **Retry Mechanism:** In case of errors or failures during AI model interactions, the Flow can be configured to make multiple retry attempts with a specified interval. +### [Key Concepts](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------- -- **Interactive Mode:** Interactive mode allows developers to have a back-and-forth conversation with the AI model, making it suitable for real-time interactions. +Before diving into the practical aspects, let's clarify some key concepts related to the Flow feature: +- Flow: A Flow is an instance of the Flow class that represents an ongoing interaction with an AI language model. It consists of a series of steps and responses. +- Stopping Condition: A stopping condition is a criterion that, when met, allows the Flow to stop generating responses. This can be user-defined and can depend on the content of the responses. +- Loop Interval: The loop interval specifies the time delay between consecutive interactions with the AI model. +- Retry Mechanism: In case of errors or failures during AI model interactions, the Flow can be configured to make multiple retry attempts with a specified interval. +- Interactive Mode: Interactive mode allows developers to have a back-and-forth conversation with the AI model, making it suitable for real-time interactions. -### 2. Setting Up Your Development Environment +## [2. Setting Up Your Development Environment](https://github.com/kyegomez/swarms) +============================================================================================================================================================= -#### 2.1 Installing Required Dependencies +### [2.1 Installing Required Dependencies](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------------------ Before you can start using the Swarms Flow module, you need to set up your development environment. First, you'll need to install the necessary dependencies, including Swarms itself. -```bash # Install Swarms and required libraries -pip3 install --upgrade swarms -``` +`pip3 install --upgrade swarms` -#### 2 Creating Your First Flow +## [2. Creating Your First Flow](https://github.com/kyegomez/swarms) +----------------------------------------------------------------------------------------------------------------------------- Now, let's create your first Flow. A Flow represents a chain-like structure that allows you to engage in multi-step conversations with language models. The Flow structure is what gives an LLM autonomy. It's the Mitochondria of an autonomous agent. -```python # Import necessary modules +```python from swarms.models import OpenAIChat # Zephr, Mistral from swarms.structs import Flow -api_key = "" +api_key = ""# Initialize the language model (LLM) +llm = OpenAIChat(openai_api_key=api_key, temperature=0.5, max_tokens=3000)# Initialize the Flow object -# Initialize the language model (LLM) -llm = OpenAIChat(openai_api_key=api_key, temperature=0.5, max_tokens=3000) +flow = Flow(llm=llm, max_loops=5)# Run the flow +out = flow.run("Create an financial analysis on the following metrics") +print(out) -# Initialize the Flow object -flow = Flow(llm=llm, max_loops=5) ``` - -#### 3.3 Initializing the Flow Object +### [3. Initializing the Flow Object](https://github.com/kyegomez/swarms) +---------------------------------------------------------------------------------------------------------------------------------------- Create a Flow object that will be the backbone of your conversational flow. @@ -120,11 +139,12 @@ flow = Flow( ) ``` -#### 3.4 Initializing the Language Model +### [3.2 Initializing the Language Model](https://github.com/kyegomez/swarms) +---------------------------------------------------------------------------------------------------------------------------------------------- Initialize the language model (LLM) that your Flow will interact with. In this example, we're using OpenAI's GPT-3 as the LLM. -- You can also use `Mistral` or `Zephr` or any of other models! +- You can also use `Mistral` or `Zephr` or any of other models! ```python # Initialize the language model (LLM) @@ -135,13 +155,14 @@ llm = OpenAIChat( ) ``` -#### 3.5 Running Your Flow +### [3.3 Running Your Flow](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------ Now, you're ready to run your Flow and start interacting with the language model. If you are using a multi modality model, you can pass in the image path as another parameter -```python +``` # Run your Flow out = flow.run( "Generate a 10,000 word blog on health and wellness.", @@ -153,191 +174,205 @@ print(out) This code will initiate a conversation with the language model, and you'll receive responses accordingly. -### 4. Advanced Flow Concepts +## [4. Advanced Flow Concepts](https://github.com/kyegomez/swarms) +=========================================================================================================================== In this section, we'll explore advanced concepts that can enhance your experience with the Swarms Flow module. -#### 4.1 Custom Stopping Conditions +### [4.1 Custom Stopping Conditions](https://github.com/kyegomez/swarms) You can define custom stopping conditions for your Flow. For example, you might want the Flow to stop when a specific word is mentioned in the response. -```python # Custom stopping condition example +```python def stop_when_repeats(response: str) -> bool: return "Stop" in response.lower() +``` # Set the stopping condition in your Flow -flow.stopping_condition = stop_when_repeats -``` +```flow.stopping_condition = stop_when_repeats``` -#### 4.2 Dynamic Temperature Handling +### [4.2 Dynamic Temperature Handling](https://github.com/kyegomez/swarms) +---------------------------------------------------------------------------------------------------------------------------------------- Dynamic temperature handling allows you to adjust the temperature attribute of the language model during the conversation. -```python # Enable dynamic temperature handling in your Flow -flow.dynamic_temperature = True -``` +`flow.dynamic_temperature = True` This feature randomly changes the temperature attribute for each loop, providing a variety of responses. -#### 4.3 Providing Feedback on Responses +### [4.3 Providing Feedback on Responses](https://github.com/kyegomez/swarms) +---------------------------------------------------------------------------------------------------------------------------------------------- -You can provide feedback on responses generated by the language model using the `provide_feedback` method. +You can provide feedback on responses generated by the language model using the `provide_feedback` method. -```python -# Provide feedback on a response -flow.provide_feedback("The response was helpful.") -``` +- Provide feedback on a response +`flow.provide_feedback("The response was helpful.")` This feedback can be valuable for improving the quality of responses. -#### 4.4 Retry Mechanism +### [4.4 Retry Mechanism](https://github.com/kyegomez/swarms) +-------------------------------------------------------------------------------------------------------------- In case of errors or issues during conversation, you can implement a retry mechanism to attempt generating a response again. +# Set the number of retry attempts and interval ```python -# Set the number - - of retry attempts and interval flow.retry_attempts = 3 flow.retry_interval = 1 # in seconds ``` - -#### 4.5 Response Filtering +### [4.5 Response Filtering](https://github.com/kyegomez/swarms) +-------------------------------------------------------------------------------------------------------------------- You can add response filters to filter out certain words or phrases from the responses. -```python # Add a response filter +```python flow.add_response_filter("inappropriate_word") ``` - This helps in controlling the content generated by the language model. -#### 4.6 Interactive Mode +### [4.6 Interactive Mode](https://github.com/kyegomez/swarms) +---------------------------------------------------------------------------------------------------------------- Interactive mode allows you to have a back-and-forth conversation with the language model. When enabled, the Flow will prompt for user input after each response. -```python # Enable interactive mode -flow.interactive = True -``` +`flow.interactive = True` This is useful for real-time conversations with the model. -### 5. Saving and Loading Flows +## [5. Saving and Loading Flows](https://github.com/kyegomez/swarms) +=============================================================================================================================== -#### 5.1 Saving Flow State +### [5.1 Saving Flow State](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------ You can save the state of your Flow, including the conversation history, for future use. -```python # Save the Flow state to a file -flow.save("path/to/flow_state.json") -``` +`flow.save("path/to/flow_state.json")`` -#### 5.2 Loading a Saved Flow +### [5.2 Loading a Saved Flow](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------ To continue a conversation or reuse a Flow, you can load a previously saved state. -```python # Load a saved Flow state -flow.load("path/to/flow_state.json") -``` +`flow.load("path/to/flow_state.json")`` -### 6. Troubleshooting and Tips +## [6. Troubleshooting and Tips](https://github.com/kyegomez/swarms) +=============================================================================================================================== -#### 6.1 Analyzing Feedback +### [6.1 Analyzing Feedback](https://github.com/kyegomez/swarms) +-------------------------------------------------------------------------------------------------------------------- You can analyze the feedback provided during the conversation to identify issues and improve the quality of interactions. -```python # Analyze feedback -flow.analyze_feedback() -``` +`flow.analyze_feedback()` -#### 6.2 Troubleshooting Common Issues +### [6.2 Troubleshooting Common Issues](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------------ If you encounter issues during conversation, refer to the troubleshooting section for guidance on resolving common problems. -# 7. Conclusion: Empowering Developers with Swarms Framework and Flow Structure for Automation +# [7. Conclusion: Empowering Developers with Swarms Framework and Flow Structure for Automation](https://github.com/kyegomez/swarms) +================================================================================================================================================================================================================================================================ In a world where digital tasks continue to multiply and diversify, the need for automation has never been more critical. Developers find themselves at the forefront of this automation revolution, tasked with creating reliable solutions that can seamlessly handle an array of digital tasks. Enter the Swarms framework and the Flow structure, a dynamic duo that empowers developers to build autonomous agents capable of efficiently and effectively automating a wide range of digital tasks. -## The Automation Imperative +[The Automation Imperative](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------- Automation is the driving force behind increased efficiency, productivity, and scalability across various industries. From mundane data entry and content generation to complex data analysis and customer support, the possibilities for automation are vast. Developers play a pivotal role in realizing these possibilities, and they require robust tools and frameworks to do so effectively. -## Swarms Framework: A Developer's Swiss Army Knife +[Swarms Framework: A Developer's Swiss Army Knife](https://github.com/kyegomez/swarms) +----------------------------------------------------------------------------------------------------------------------------------------------------------------------- The Swarms framework emerges as a comprehensive toolkit designed to empower developers in their automation endeavors. It equips developers with the tools and capabilities needed to create autonomous agents capable of interacting with language models, orchestrating multi-step workflows, and handling error scenarios gracefully. Let's explore why the Swarms framework is a game-changer for developers: -### 1. Language Model Integration +[1. Language Model Integration](https://github.com/kyegomez/swarms) +----------------------------------------------------------------------------------------------------------------------------------- One of the standout features of Swarms is its seamless integration with state-of-the-art language models, such as GPT-3. These language models have the ability to understand and generate human-like text, making them invaluable for tasks like content creation, translation, code generation, and more. By leveraging Swarms, developers can effortlessly incorporate these language models into their applications and workflows. For instance, they can build chatbots that provide intelligent responses to customer inquiries or generate lengthy documents with minimal manual intervention. This not only saves time but also enhances overall productivity. -### 2. Multi-Step Conversational Flows +[2. Multi-Step Conversational Flows](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------------------------- Swarms excels in orchestrating multi-step conversational flows. Developers can define intricate sequences of interactions, where the system generates responses, and users provide input at various stages. This functionality is a game-changer for building chatbots, virtual assistants, or any application requiring dynamic and context-aware conversations. These conversational flows can be tailored to handle a wide range of scenarios, from customer support interactions to data analysis. By providing a structured framework for conversations, Swarms empowers developers to create intelligent and interactive systems that mimic human-like interactions. -### 3. Customization and Extensibility +[3. Customization and Extensibility](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------------------------- Every development project comes with its unique requirements and challenges. Swarms acknowledges this by offering a high degree of customization and extensibility. Developers can define custom stopping conditions, implement dynamic temperature handling for language models, and even add response filters to control the generated content. Moreover, Swarms supports an interactive mode, allowing developers to engage in real-time conversations with the language model. This feature is invaluable for rapid prototyping, testing, and fine-tuning the behavior of autonomous agents. -### 4. Feedback-Driven Improvement +[4. Feedback-Driven Improvement](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------- Swarms encourages the collection of feedback on generated responses. Developers and users alike can provide feedback to improve the quality and accuracy of interactions over time. This iterative feedback loop ensures that applications built with Swarms continually improve, becoming more reliable and capable of autonomously handling complex tasks. -### 5. Handling Errors and Retries +[5. Handling Errors and Retries](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------- Error handling is a critical aspect of any automation framework. Swarms simplifies this process by offering a retry mechanism. In case of errors or issues during conversations, developers can configure the framework to attempt generating responses again, ensuring robust and resilient automation. -### 6. Saving and Loading Flows +[6. Saving and Loading Flows](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------- Developers can save the state of their conversational flows, allowing for seamless continuity and reusability. This feature is particularly beneficial when working on long-term projects or scenarios where conversations need to be resumed from a specific point. -## Unleashing the Potential of Automation with Swarms and Flow +[Unleashing the Potential of Automation with Swarms and Flow](https://github.com/kyegomez/swarms) +=============================================================================================================================================================================================== The combined power of the Swarms framework and the Flow structure creates a synergy that empowers developers to automate a multitude of digital tasks. These tools provide versatility, customization, and extensibility, making them ideal for a wide range of applications. Let's explore some of the remarkable ways in which developers can leverage Swarms and Flow for automation: -### 1. Customer Support and Service Automation +[1. Customer Support and Service Automation](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------------------------------- Swarms and Flow enable the creation of AI-powered customer support chatbots that excel at handling common inquiries, troubleshooting issues, and escalating complex problems to human agents when necessary. This level of automation not only reduces response times but also enhances the overall customer experience. -### 2. Content Generation and Curation +[2. Content Generation and Curation](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------------------------- Developers can harness the power of Swarms and Flow to automate content generation tasks, such as writing articles, reports, or product descriptions. By providing an initial prompt, the system can generate high-quality content that adheres to specific guidelines and styles. Furthermore, these tools can automate content curation by summarizing lengthy articles, extracting key insights from research papers, and even translating content into multiple languages. -### 3. Data Analysis and Reporting +[3. Data Analysis and Reporting](https://github.com/kyegomez/swarms) +------------------------------------------------------------------------------------------------------------------------------------- Automation in data analysis and reporting is fundamental for data-driven decision-making. Swarms and Flow simplify these processes by enabling developers to create flows that interact with databases, query data, and generate reports based on user-defined criteria. This empowers businesses to derive insights quickly and make informed decisions. -### 4. Programming and Code Generation +[4. Programming and Code Generation](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------------------------- Swarms and Flow streamline code generation and programming tasks. Developers can create flows to assist in writing code snippets, auto-completing code, or providing solutions to common programming challenges. This accelerates software development and reduces the likelihood of coding errors. -### 5. Language Translation and Localization +[5. Language Translation and Localization](https://github.com/kyegomez/swarms) +--------------------------------------------------------------------------------------------------------------------------------------------------------- With the ability to interface with language models, Swarms and Flow can automate language translation tasks. They can seamlessly translate content from one language to another, making it easier for businesses to reach global audiences and localize their offerings effectively. -### 6. Virtual Assistants and AI Applications +[6. Virtual Assistants and AI Applications](https://github.com/kyegomez/swarms) +----------------------------------------------------------------------------------------------------------------------------------------------------------- Developers can build virtual assistants and AI applications that offer personalized experiences. These applications can automate tasks such as setting reminders, answering questions, providing recommendations, and much more. Swarms and Flow provide the foundation for creating intelligent, interactive virtual assistants. -## Future Opportunities and Challenges +[Future Opportunities and Challenges](https://github.com/kyegomez/swarms) +----------------------------------------------------------------------------------------------------------------------------------------------- As Swarms and Flow continue to evolve, developers can look forward to even more advanced features and capabilities. However, with great power comes great responsibility. Developers must remain vigilant about the ethical use of automation and language models. Ensuring that automated systems provide accurate and unbiased information is an ongoing challenge that the developer community must address. -## In Conclusion +# [In Conclusion](https://github.com/kyegomez/swarms) +=================================================================================================== The Swarms framework and the Flow structure empower developers to automate an extensive array of digital tasks by offering versatility, customization, and extensibility. From natural language understanding and generation to orchestrating multi-step conversational flows, these tools simplify complex automation scenarios.