From 085d19a8a703f315f6a7de72adbbc84baeadbc94 Mon Sep 17 00:00:00 2001 From: Kye Date: Sun, 3 Dec 2023 01:18:18 -0800 Subject: [PATCH] [DEMO] --- flow_state.json | 15 ------ playground/demos/grupa/app.py | 6 +-- .../demos/swarm_of_mma_manufacturing/main.py | 51 ++++++++++++++++--- 3 files changed, 45 insertions(+), 27 deletions(-) delete mode 100644 flow_state.json diff --git a/flow_state.json b/flow_state.json deleted file mode 100644 index f8a05b5c..00000000 --- a/flow_state.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "memory": [ - [ - "Human:: Document the following code: In order to implement the signup system in TypeScript using Supabase based on the provided algorithmic pseudocode and codebase, we need to follow these steps:\n\n1. Import necessary modules and dependencies.\n2. Implement the `useEffect` hook to check if a user is already authenticated when the `MainPanel` component renders.\n3. Define a function `handleFormSubmit` to handle form submission.\n4. Implement the form for user signup in the `UpperPanel` component.\n5. Implement the `LowerPanel` component which will display a message or instructions based on `promptInstruction` state.\n\nLet's start by importing the necessary modules and dependencies. \n\n```typescript\nimport React, { useState, useEffect } from 'react';\nimport { Auth } from '@supabase/ui';\nimport { supabase } from './supabaseClient';\nimport UpperPanel from './UpperPanel';\nimport LowerPanel from './LowerPanel';\n```\n\nNext, we'll add the `useEffect` hook inside the `MainPanel` component to check if a user is already authenticated when the component renders. If a user is found, we'll update the `user` state with the returned user.\n\n```typescript\nconst MainPanel = () => {\n const [user, setUser] = useState(null);\n const [promptInstructionForLowerPanel, setPromptInstructionForLowerPanel] = useState(''); \n const [formData, setFormData] = useState('');\n const [isLoading, setIsLoading] = useState(false); \n\n useEffect(() => {\n const user = supabase.auth.user();\n if (user) {\n setUser(user);\n }\n }, []);\n\n return (\n
\n \n \n
\n );\n};\n```\n\nNow, let's define a function `handleFormSubmit` to handle form submission. This function will be passed as a prop to the `UpperPanel` component.\n\n```typescript\nconst handleFormSubmit = async (event) => {\n event.preventDefault();\n setIsLoading(true);\n const { user, error } = await supabase.auth.signUp(formData);\n if (error) {\n setPromptInstructionForLowerPanel(error.message);\n } else {\n setUser(user);\n }\n setIsLoading(false);\n};\n```\n\nWe'll continue with the next steps in the following code blocks.", - "AI: # TypeScript Signup System with Supabase\n\nThis documentation provides a comprehensive guide and explanation of the TypeScript signup system using Supabase. The system consists of several components including MainPanel, UpperPanel, and LowerPanel, as well as the use of the Supabase client for authentication. \n\n## Overview\n\nThe signup system is designed to authenticate users using Supabase, a modern and open-source backend service. The system is built with TypeScript and React, utilizing React's useState and useEffect hooks for state management and side effects respectively.\n\nThe system is divided into three main components:\n\n- `MainPanel`: This is the parent component that holds the state for the user, prompt instructions, form data, and loading status. It also contains the useEffect hook to check if a user is already authenticated when the component renders.\n- `UpperPanel`: This component contains the form for user signup.\n- `LowerPanel`: This component displays a message or instructions based on the `promptInstruction` state.\n\n## Importing Modules and Dependencies\n\nThe first step is to import the necessary modules and dependencies. We import React, useState, and useEffect from the 'react' library. We also import Auth from '@supabase/ui', the UI library for Supabase, and our initialized Supabase client from './supabaseClient'. Finally, we import our UpperPanel and LowerPanel components.\n\n```typescript\nimport React, { useState, useEffect } from 'react';\nimport { Auth } from '@supabase/ui';\nimport { supabase } from './supabaseClient';\nimport UpperPanel from './UpperPanel';\nimport LowerPanel from './LowerPanel';\n```\n\n## The MainPanel Component\n\nThe `MainPanel` component is the parent component that holds the state for the user, prompt instructions, form data, and loading status. It also contains the useEffect hook to check if a user is already authenticated when the component renders.\n\n```typescript\nconst MainPanel = () => {\n const [user, setUser] = useState(null);\n const [promptInstructionForLowerPanel, setPromptInstructionForLowerPanel] = useState(''); \n const [formData, setFormData] = useState('');\n const [isLoading, setIsLoading] = useState(false); \n\n useEffect(() => {\n const user = supabase.auth.user();\n if (user) {\n setUser(user);\n }\n }, []);\n\n return (\n
\n \n \n
\n );\n};\n```\n\nIn the `MainPanel` component, we define four pieces of state:\n\n- `user`: This is initially set to null and will hold the authenticated user, if one exists.\n- `promptInstructionForLowerPanel`: This holds the instructions or messages to be displayed in the `LowerPanel` component.\n- `formData`: This is initially an empty string and will hold the form data from the signup form.\n- `isLoading`: This is initially set to false and will be used to manage the loading state of the form.\n\nThe useEffect hook checks if a user is already authenticated when the component renders. If a user is found, the `user` state is updated with the returned user.\n\n## The handleFormSubmit Function\n\nNext, we define a function `handleFormSubmit` to handle form submission. This function will be passed as a prop to the `UpperPanel` component.\n\n```typescript\nconst handleFormSubmit = async (event) => {\n event.preventDefault();\n setIsLoading(true);\n const { user, error } = await supabase.auth.signUp(formData);\n if (error) {\n setPromptInstructionForLowerPanel(error.message);\n } else {\n setUser(user);\n }\n setIsLoading(false);\n};\n```\n\nIn the `handleFormSubmit` function, we first prevent the default form submission behavior with `event.preventDefault()`. We then set `isLoading` to true to indicate that the form is being submitted. \n\nWe then call `supabase.auth.signUp` with the `formData` as an argument. This function returns a promise that resolves to an object containing the user and any error that might have occurred during the signup process.\n\nIf an error occurs during the signup process, we update `promptInstructionForLowerPanel` with the error message. If the signup is successful, we update the `user` state with the returned user. Finally, we set `isLoading` to false to indicate that the form submission has completed.\n\n## Next Steps\n\nThe implementation of the `UpperPanel` and `LowerPanel` components will be covered in the following sections. The `UpperPanel` component will contain the form for user signup, while the `LowerPanel` component will display a message or instructions based on the `promptInstructionForLowerPanel` state.", - "# TypeScript Signup System with Supabase\n\nThis documentation provides a comprehensive guide and explanation of the TypeScript signup system using Supabase. The system consists of several components including MainPanel, UpperPanel, and LowerPanel, as well as the use of the Supabase client for authentication. \n\n## Overview\n\nThe signup system is designed to authenticate users using Supabase, a modern and open-source backend service. The system is built with TypeScript and React, utilizing React's useState and useEffect hooks for state management and side effects respectively.\n\nThe system is divided into three main components:\n\n- `MainPanel`: This is the parent component that holds the state for the user, prompt instructions, form data, and loading status. It also contains the useEffect hook to check if a user is already authenticated when the component renders.\n- `UpperPanel`: This component contains the form for user signup.\n- `LowerPanel`: This component displays a message or instructions based on the `promptInstruction` state.\n\n## Importing Modules and Dependencies\n\nThe first step is to import the necessary modules and dependencies. We import React, useState, and useEffect from the 'react' library. We also import Auth from '@supabase/ui', the UI library for Supabase, and our initialized Supabase client from './supabaseClient'. Finally, we import our UpperPanel and LowerPanel components.\n\n```typescript\nimport React, { useState, useEffect } from 'react';\nimport { Auth } from '@supabase/ui';\nimport { supabase } from './supabaseClient';\nimport UpperPanel from './UpperPanel';\nimport LowerPanel from './LowerPanel';\n```\n\n## The MainPanel Component\n\nThe `MainPanel` component is the parent component that holds the state for the user, prompt instructions, form data, and loading status. It also contains the useEffect hook to check if a user is already authenticated when the component renders.\n\n```typescript\nconst MainPanel = () => {\n const [user, setUser] = useState(null);\n const [promptInstructionForLowerPanel, setPromptInstructionForLowerPanel] = useState(''); \n const [formData, setFormData] = useState('');\n const [isLoading, setIsLoading] = useState(false); \n\n useEffect(() => {\n const user = supabase.auth.user();\n if (user) {\n setUser(user);\n }\n }, []);\n\n return (\n
\n \n \n
\n );\n};\n```\n\nIn the `MainPanel` component, we define four pieces of state:\n\n- `user`: This is initially set to null and will hold the authenticated user, if one exists.\n- `promptInstructionForLowerPanel`: This holds the instructions or messages to be displayed in the `LowerPanel` component.\n- `formData`: This is initially an empty string and will hold the form data from the signup form.\n- `isLoading`: This is initially set to false and will be used to manage the loading state of the form.\n\nThe useEffect hook checks if a user is already authenticated when the component renders. If a user is found, the `user` state is updated with the returned user.\n\n## The handleFormSubmit Function\n\nNext, we define a function `handleFormSubmit` to handle form submission. This function will be passed as a prop to the `UpperPanel` component.\n\n```typescript\nconst handleFormSubmit = async (event) => {\n event.preventDefault();\n setIsLoading(true);\n const { user, error } = await supabase.auth.signUp(formData);\n if (error) {\n setPromptInstructionForLowerPanel(error.message);\n } else {\n setUser(user);\n }\n setIsLoading(false);\n};\n```\n\nIn the `handleFormSubmit` function, we first prevent the default form submission behavior with `event.preventDefault()`. We then set `isLoading` to true to indicate that the form is being submitted. \n\nWe then call `supabase.auth.signUp` with the `formData` as an argument. This function returns a promise that resolves to an object containing the user and any error that might have occurred during the signup process.\n\nIf an error occurs during the signup process, we update `promptInstructionForLowerPanel` with the error message. If the signup is successful, we update the `user` state with the returned user. Finally, we set `isLoading` to false to indicate that the form submission has completed.\n\n## Next Steps\n\nThe implementation of the `UpperPanel` and `LowerPanel` components will be covered in the following sections. The `UpperPanel` component will contain the form for user signup, while the `LowerPanel` component will display a message or instructions based on the `promptInstructionForLowerPanel` state." - ] - ], - "loop_interval": 1, - "retry_attempts": 3, - "retry_interval": 1, - "interactive": false, - "dashboard": false, - "dynamic_temperature": false -} \ No newline at end of file diff --git a/playground/demos/grupa/app.py b/playground/demos/grupa/app.py index c1760b7b..3ab52e22 100644 --- a/playground/demos/grupa/app.py +++ b/playground/demos/grupa/app.py @@ -14,10 +14,8 @@ load_dotenv() FEATURE = ( "Implement an all-new signup system in typescript using supabase" ) -CODEBASE = """ - - +CODEBASE = """ import React, { useState } from 'react'; import UpperPanel from './UpperPanel'; import LowerPanel from './LowerPanel'; @@ -51,7 +49,7 @@ llm = OpenAIChat( model_name="gpt-4", openai_api_key=api_key, temperature=0.5, - max_tokens=2000, + max_tokens=4000, ) # Product Manager Agent init diff --git a/playground/demos/swarm_of_mma_manufacturing/main.py b/playground/demos/swarm_of_mma_manufacturing/main.py index 802647b5..05b0e8e5 100644 --- a/playground/demos/swarm_of_mma_manufacturing/main.py +++ b/playground/demos/swarm_of_mma_manufacturing/main.py @@ -13,16 +13,19 @@ Efficiency agent: Agent that monitors the efficiency of the factory: input image Agent: health security agent -> quality control agent -> productivity agent -> safety agent -> security agent -> sustainability agent -> efficiency agent """ -from swarms.structs import Agent import os + from dotenv import load_dotenv +from termcolor import colored + from swarms.models import GPT4VisionAPI +from swarms.structs import Agent load_dotenv() api_key = os.getenv("OPENAI_API_KEY") - -llm = GPT4VisionAPI(openai_api_key=api_key) +# GPT4VisionAPI +llm = GPT4VisionAPI(openai_api_key=api_key, max_tokens=2000) assembly_line = ( "playground/demos/swarm_of_mma_manufacturing/assembly_line.jpg" @@ -81,41 +84,73 @@ efficiency_prompt = tasks["efficiency"] health_security_agent = Agent( llm=llm, sop_list=health_safety_prompt, - max_loops=2, + max_loops=1, multi_modal=True, ) # Quality control agent productivity_check_agent = Agent( - llm=llm, sop=productivity_prompt, max_loops=2, multi_modal=True + llm=llm, + sop=productivity_prompt, + max_loops=1, + multi_modal=True, + autosave=True, ) # Security agent security_check_agent = Agent( - llm=llm, sop=security_prompt, max_loops=2, multi_modal=True + llm=llm, + sop=security_prompt, + max_loops=1, + multi_modal=True, + autosave=True, ) # Efficiency agent efficiency_check_agent = Agent( - llm=llm, sop=efficiency_prompt, max_loops=2, multi_modal=True + llm=llm, + sop=efficiency_prompt, + max_loops=1, + multi_modal=True, + autosave=True, ) +print(colored("Running the agents...", "green")) + +print(colored("Running health check agent initializing...", "cyan")) # Add the first task to the health_security_agent health_check = health_security_agent.run( "Analyze the safety of this factory", robots ) + +print( + colored( + "--------------- Productivity agents initializing...", "green" + ) +) # Add the third task to the productivity_check_agent productivity_check = productivity_check_agent.run( health_check, assembly_line ) +print( + colored( + "--------------- Security agents initializing...", "green" + ) +) # Add the fourth task to the security_check_agent -security_check = security_check_agent.add( +security_check = security_check_agent.run( productivity_check, red_robots ) + +print( + colored( + "--------------- Efficiency agents initializing...", "cyan" + ) +) # Add the fifth task to the efficiency_check_agent efficiency_check = efficiency_check_agent.run( security_check, tesla_assembly_line