From 1c4a9898f20aca71c53dc0de5d3ce5b819baf025 Mon Sep 17 00:00:00 2001 From: Kye Date: Mon, 6 Nov 2023 11:36:08 -0500 Subject: [PATCH] sequential workflow Former-commit-id: 71da697cc8dedac243bd73b9b6c8b09def6e3717 --- docs/examples/reliable_autonomous_agents.md | 229 ++++++++++++++++++++ pyproject.toml | 2 +- swarms/structs/__init__.py | 3 +- swarms/structs/sequential_workflow.py | 8 +- 4 files changed, 236 insertions(+), 6 deletions(-) create mode 100644 docs/examples/reliable_autonomous_agents.md diff --git a/docs/examples/reliable_autonomous_agents.md b/docs/examples/reliable_autonomous_agents.md new file mode 100644 index 00000000..21d0478b --- /dev/null +++ b/docs/examples/reliable_autonomous_agents.md @@ -0,0 +1,229 @@ +# Reliable Enterprise-Grade Autonomous Agents in Less Than 5 lines of Code +======================================================================== + +Welcome to this comprehensive walkthrough guide tutorial on the SequentialWorkflow feature of the Swarms Framework! In this tutorial, we will explore the purpose, usage, and key concepts of the SequentialWorkflow class, which is a part of the swarms package. Whether you are a beginner, intermediate, or expert developer, this tutorial will provide you with a clear understanding of how to effectively use the SequentialWorkflow class in your projects. + +AI engineering is a dynamic and evolving field that involves the development and deployment of intelligent systems and applications. In this ever-changing landscape, AI engineers often face the challenge of orchestrating complex sequences of tasks, managing data flows, and ensuring the smooth execution of AI workflows. This is where the Workflow Class, such as the SequentialWorkflow class we discussed earlier, plays a pivotal role in enabling AI engineers to achieve their goals efficiently and effectively. + +The Versatile World of AI Workflows +AI workflows encompass a wide range of tasks and processes, from data preprocessing and model training to natural language understanding and decision-making. These workflows are the backbone of AI systems, guiding them through intricate sequences of actions to deliver meaningful results. Here are some of the diverse use cases where the Workflow Class can empower AI engineers: + +1. Natural Language Processing (NLP) Pipelines +AI engineers often build NLP pipelines that involve multiple stages such as text preprocessing, tokenization, feature extraction, model inference, and post-processing. The Workflow Class enables the orderly execution of these stages, ensuring that textual data flows seamlessly through each step, resulting in accurate and coherent NLP outcomes. + +2. Data Ingestion and Transformation +AI projects frequently require the ingestion of diverse data sources, including structured databases, unstructured text, and multimedia content. The Workflow Class can be used to design data ingestion workflows that extract, transform, and load (ETL) data efficiently, making it ready for downstream AI tasks like training and analysis. + +3. Autonomous Agents and Robotics +In autonomous robotics and intelligent agent systems, workflows are essential for decision-making, sensor fusion, motion planning, and control. AI engineers can use the Workflow Class to create structured sequences of actions that guide robots and agents through dynamic environments, enabling them to make informed decisions and accomplish tasks autonomously. + +4. Machine Learning Model Training +Training machine learning models involves a series of steps, including data preprocessing, feature engineering, model selection, hyperparameter tuning, and evaluation. The Workflow Class simplifies the orchestration of these steps, allowing AI engineers to experiment with different configurations and track the progress of model training. + +5. Content Generation and Summarization +AI-driven content generation tasks, such as generating articles, reports, or summaries, often require multiple steps, including content creation and post-processing. The Workflow Class can be used to create content generation workflows, ensuring that the generated content meets quality and coherence criteria. + +6. Adaptive Decision-Making +In AI systems that make real-time decisions based on changing data and environments, workflows facilitate adaptive decision-making. Engineers can use the Workflow Class to design decision-making pipelines that take into account the latest information and make informed choices. + +Enabling Efficiency and Maintainability +The Workflow Class provides AI engineers with a structured and maintainable approach to building, executing, and managing complex AI workflows. It offers the following advantages: + +Modularity: Workflows can be modularly designed, allowing engineers to focus on individual task implementations and ensuring code reusability. + +Debugging and Testing: The Workflow Class simplifies debugging and testing by providing a clear sequence of tasks and well-defined inputs and outputs for each task. + +Scalability: As AI projects grow in complexity, the Workflow Class can help manage and scale workflows by adding or modifying tasks as needed. + +Error Handling: The class supports error handling strategies, enabling engineers to define how to handle unexpected failures gracefully. + +Maintainability: With structured workflows, AI engineers can easily maintain and update AI systems as requirements evolve or new data sources become available. + +The Workflow Class, such as the SequentialWorkflow class, is an indispensable tool in the toolkit of AI engineers. It empowers engineers to design, execute, and manage AI workflows across a diverse range of use cases. By providing structure, modularity, and maintainability to AI projects, the Workflow Class contributes significantly to the efficiency and success of AI engineering endeavors. As the field of AI continues to advance, harnessing the power of workflow orchestration will remain a key ingredient in building intelligent and adaptable systems, now let’s get started with SequentialWorkflow. + +## Official Swarms Links +Here is the Swarms website: + +Here is the Swarms Github: + +Here are the Swarms docs: + +And, join the Swarm community! + +Book a call with The Swarm Corporation here if you’re interested in high performance custom swarms! + +Now let’s begin… + +## Installation +Before we dive into the tutorial, make sure you have the following prerequisites in place: + +Python installed on your system. +The swarms library installed. You can install it via pip using the following command: + +`pip3 install --upgrade swarms` + +Additionally, you will need an API key for the OpenAIChat model to run the provided code examples. Replace "YOUR_API_KEY" with your actual API key in the code examples where applicable. + +## Getting Started +Let’s start by importing the necessary modules and initializing the OpenAIChat model, which we will use in our workflow tasks. + + +```python +from swarms.models import OpenAIChat +from swarms.structs import Flow +from swarms.structs.sequential_workflow import SequentialWorkflow + +# Replace "YOUR_API_KEY" with your actual OpenAI API key +api_key = "YOUR_API_KEY" + +# Initialize the language model flow (e.g., GPT-3) +llm = OpenAIChat( + openai_api_key=api_key, + temperature=0.5, + max_tokens=3000, +) +We have initialized the OpenAIChat model, which will be used as a callable object in our tasks. Now, let’s proceed to create the SequentialWorkflow. + +Creating a SequentialWorkflow +To create a SequentialWorkflow, follow these steps: + +# Initialize Flows for individual tasks +flow1 = Flow(llm=llm, max_loops=1, dashboard=False) +flow2 = Flow(llm=llm, max_loops=1, dashboard=False) +# Create the Sequential Workflow +workflow = SequentialWorkflow(max_loops=1) +`````` +In this code snippet, we have initialized two Flow instances (flow1 and flow2) representing individual tasks within our workflow. These flows will use the OpenAIChat model we initialized earlier. We then create a SequentialWorkflow instance named workflow with a maximum loop count of 1. The max_loops parameter determines how many times the entire workflow can be run, and we set it to 1 for this example. + +Adding Tasks to the SequentialWorkflow +Now that we have created the SequentialWorkflow, let’s add tasks to it. In our example, we’ll create two tasks: one for generating a 10,000-word blog on “health and wellness” and another for summarizing the generated blog. + +``` +### Add tasks to the workflow +workflow.add("Generate a 10,000 word blog on health and wellness.", flow1) + +`workflow.add("Summarize the generated blog", flow2)` + +The workflow.add() method is used to add tasks to the workflow. Each task is described using a human-readable description, such as "Generate a 10,000 word blog on health and wellness," and is associated with a flow (callable object) that will be executed as the task. In our example, flow1 and flow2 represent the tasks. + +Running the SequentialWorkflow +With tasks added to the SequentialWorkflow, we can now run the workflow sequentially using the workflow.run() method. + +### Run the workflow +`workflow.run()` +Executing workflow.run() will start the execution of tasks in the order they were added to the workflow. In our example, it will first generate the blog and then summarize it. + +Accessing Task Results +After running the workflow, you can access the results of each task using the get_task_results() method. + +# Get and display the results of each task in the workflow +```python +results = workflow.get_task_results() +for task_description, result in results.items(): + print(f"Task: {task_description}, Result: {result}") +``` +The workflow.get_task_results() method returns a dictionary where the keys are task descriptions, and the values are the corresponding results. You can then iterate through the results and print them, as shown in the code snippet. + +Resetting a SequentialWorkflow +Sometimes, you might need to reset a SequentialWorkflow to start fresh. You can use the workflow.reset_workflow() method for this purpose. + +### Reset the workflow +`workflow.reset_workflow()` +Resetting the workflow clears the results of each task, allowing you to rerun the workflow from the beginning without reinitializing it. + +Updating Task Arguments +You can also update the arguments of a specific task in the workflow using the workflow.update_task() method. + +### Update the arguments of a specific task in the workflow +`workflow.update_task("Generate a 10,000 word blog on health and wellness.", max_loops=2)` + +In this example, we update the max_loops argument of the task with the description "Generate a 10,000 word blog on health and wellness" to 2. This can be useful if you want to change the behavior of a specific task without recreating the entire workflow. + +# Conclusion: Mastering Workflow Orchestration in AI Engineering +In the ever-evolving landscape of artificial intelligence (AI), where the pace of innovation and complexity of tasks are ever-increasing, harnessing the power of workflow orchestration is paramount. In this comprehensive walkthrough guide, we’ve embarked on a journey through the world of workflow orchestration, focusing on the Workflow Class, with a specific emphasis on the SequentialWorkflow class. As we conclude this exploration, we’ve delved deep into the intricacies of orchestrating AI workflows, and it’s time to reflect on the valuable insights gained and the immense potential that this knowledge unlocks for AI engineers. + +The Art of Workflow Orchestration +At its core, workflow orchestration is the art of designing, managing, and executing sequences of tasks or processes in a structured and efficient manner. In the realm of AI engineering, where tasks can range from data preprocessing and model training to decision-making and autonomous actions, mastering workflow orchestration is a game-changer. It empowers AI engineers to streamline their work, ensure reliable execution, and deliver impactful results. + +The Workflow Class, and particularly the SequentialWorkflow class we’ve explored, acts as a guiding light in this intricate journey. It provides AI engineers with a toolbox of tools and techniques to conquer the challenges of orchestrating AI workflows effectively. Through a disciplined approach and adherence to best practices, AI engineers can achieve the following: + +1. Structured Workflow Design +A well-structured workflow is the cornerstone of any successful AI project. The Workflow Class encourages AI engineers to break down complex tasks into manageable units. Each task becomes a building block that contributes to the overarching goal. Whether it’s preprocessing data, training a machine learning model, or generating content, structured workflow design ensures clarity, modularity, and maintainability. + +2. Efficient Task Sequencing +In AI, the order of tasks often matters. One task’s output can be another task’s input, and ensuring the correct sequence of execution is crucial. The SequentialWorkflow class enforces this sequential execution, eliminating the risk of running tasks out of order. It ensures that the workflow progresses systematically, following the predefined sequence of tasks. + +3. Error Resilience and Recovery +AI systems must be resilient in the face of unexpected errors and failures. The Workflow Class equips AI engineers with error handling strategies, such as retries and fallbacks. These strategies provide the ability to gracefully handle issues, recover from failures, and continue the workflow’s execution without disruption. + +4. Code Modularity and Reusability +Building AI workflows often involves implementing various tasks, each with its own logic. The Workflow Class encourages code modularity, allowing AI engineers to encapsulate tasks as separate units. This modularity promotes code reusability, making it easier to adapt and expand workflows as AI projects evolve. + +5. Efficient Debugging and Testing +Debugging and testing AI workflows can be challenging without clear structure and boundaries. The Workflow Class provides a clear sequence of tasks with well-defined inputs and outputs. This structure simplifies the debugging process, as AI engineers can isolate and test individual tasks, ensuring that each component functions as intended. + +6. Scalability and Adaptability +As AI projects grow in complexity, the Workflow Class scales effortlessly. AI engineers can add or modify tasks as needed, accommodating new data sources, algorithms, or requirements. This scalability ensures that workflows remain adaptable to changing demands and evolving AI landscapes. + +7. Maintainability and Future-Proofing +Maintaining AI systems over time is a crucial aspect of engineering. The Workflow Class fosters maintainability by providing a clear roadmap of tasks and their interactions. AI engineers can revisit, update, and extend workflows with confidence, ensuring that AI systems remain effective and relevant in the long run. + +Empowering AI Engineers +The knowledge and skills gained from this walkthrough guide go beyond technical proficiency. They empower AI engineers to be architects of intelligent systems, capable of orchestrating AI workflows that solve real-world problems. The Workflow Class is a versatile instrument in their hands, enabling them to tackle diverse use cases and engineering challenges. + +Diverse Use Cases for Workflow Class +Throughout this guide, we explored a myriad of use cases where the Workflow Class shines: + +Natural Language Processing (NLP) Pipelines: In NLP, workflows involve multiple stages, and the Workflow Class ensures orderly execution, resulting in coherent NLP outcomes. +Data Ingestion and Transformation: Data is the lifeblood of AI, and structured data workflows ensure efficient data preparation for downstream tasks. +Autonomous Agents and Robotics: For robots and intelligent agents, workflows enable autonomous decision-making and task execution. +Machine Learning Model Training: Model training workflows encompass numerous steps, and structured orchestration simplifies the process. +Content Generation and Summarization: Workflows for content generation ensure that generated content meets quality and coherence criteria. +Adaptive Decision-Making: In dynamic environments, workflows facilitate adaptive decision-making based on real-time data. +Efficiency and Maintainability +AI engineers not only have the tools to tackle these use cases but also the means to do so efficiently. The Workflow Class fosters efficiency and maintainability, making AI engineering endeavors more manageable: + +Modularity: Encapsulate tasks as separate units, promoting code reusability and maintainability. +Debugging and Testing: Streamline debugging and testing through clear task boundaries and well-defined inputs and outputs. +Scalability: As AI projects grow, workflows scale with ease, accommodating new components and requirements. +Error Handling: Gracefully handle errors and failures, ensuring that AI systems continue to operate smoothly. +Maintainability: AI systems remain adaptable and maintainable, even as the AI landscape evolves and requirements change. +The Future of AI Engineering +As AI engineering continues to advance, workflow orchestration will play an increasingly pivotal role. The Workflow Class is not a static tool; it is a dynamic enabler of innovation. In the future, we can expect further enhancements and features to meet the evolving demands of AI engineering: + +1. Asynchronous Support +Support for asynchronous task execution will improve the efficiency of workflows, especially when tasks involve waiting for external events or resources. + +2. Context Managers +Introducing context manager support for tasks can simplify resource management, such as opening and closing files or database connections. + +3. Workflow History +Maintaining a detailed history of workflow execution, including timestamps, task durations, and input/output data, will facilitate debugging and performance analysis. + +4. Parallel Processing +Enhancing the module to support parallel processing with a pool of workers can significantly speed up the execution of tasks, especially for computationally intensive workflows. + +5. Error Handling Strategies +Providing built-in error handling strategies, such as retries, fallbacks, and circuit breakers, will further enhance the resilience of workflows. + +Closing Thoughts +In conclusion, the journey through workflow orchestration in AI engineering has been both enlightening and empowering. The Workflow Class, and particularly the SequentialWorkflow class, has proven to be an invaluable ally in the AI engineer’s toolkit. It offers structure, modularity, and efficiency, ensuring that AI projects progress smoothly from inception to deployment. + +As AI continues to permeate every aspect of our lives, the skills acquired in this guide will remain highly relevant and sought after. AI engineers armed with workflow orchestration expertise will continue to push the boundaries of what is possible, solving complex problems, and driving innovation. + +But beyond the technical aspects, this guide also emphasizes the importance of creativity, adaptability, and problem-solving. AI engineering is not just about mastering tools; it’s about using them to make a meaningful impact on the world. + +So, whether you’re just starting your journey into AI engineering or you’re a seasoned professional seeking to expand your horizons, remember that the power of workflow orchestration lies not only in the code but in the limitless potential it unlocks for you as an AI engineer. As you embark on your own AI adventures, may this guide serve as a reliable companion, illuminating your path and inspiring your journey towards AI excellence. + +The world of AI is waiting for your innovation and creativity. With workflow orchestration as your guide, you have the tools to shape the future. The possibilities are boundless, and the future is yours to create. + +Official Swarms Links +Here is the Swarms website: + +Here is the Swarms Github: + +Here are the Swarms docs: + +And, join the Swarm community! + +Book a call with The Swarm Corporation here if you’re interested in high performance custom swarms! \ No newline at end of file diff --git a/pyproject.toml b/pyproject.toml index 4af20ee0..e3a29e78 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api" [tool.poetry] name = "swarms" -version = "1.9.3" +version = "1.9.5" description = "Swarms - Pytorch" license = "MIT" authors = ["Kye Gomez "] diff --git a/swarms/structs/__init__.py b/swarms/structs/__init__.py index d360fa78..a842359c 100644 --- a/swarms/structs/__init__.py +++ b/swarms/structs/__init__.py @@ -1,5 +1,6 @@ from swarms.structs.workflow import Workflow from swarms.structs.task import Task from swarms.structs.flow import Flow +from swarms.structs.sequential_workflow import SequentialWorkflow -__all__ = ["Workflow", "Task", "Flow"] +__all__ = ["Workflow", "Task", "Flow", "SequentialWorkflow"] diff --git a/swarms/structs/sequential_workflow.py b/swarms/structs/sequential_workflow.py index c89175f2..802e5442 100644 --- a/swarms/structs/sequential_workflow.py +++ b/swarms/structs/sequential_workflow.py @@ -16,8 +16,8 @@ TODO: import json from dataclasses import dataclass, field from typing import Any, Callable, Dict, List, Optional, Union + from termcolor import colored -from pydantic import BaseModel, validator from swarms.structs.flow import Flow @@ -217,9 +217,9 @@ class SequentialWorkflow: json.dump(state, f, indent=4) def workflow_bootup(self, **kwargs) -> None: - bootup = print( + print( colored( - f""" + """ Sequential Workflow Initializing...""", "green", attrs=["bold", "underline"], @@ -243,7 +243,7 @@ class SequentialWorkflow: >>> workflow.workflow_dashboard() """ - dashboard = print( + print( colored( f""" Sequential Workflow Dashboard