• Stars
    star
    740
  • Rank 61,282 (Top 2 %)
  • Language
    Python
  • License
    MIT License
  • Created 12 months ago
  • Updated 9 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Agents Capable of Self-Editing Their Prompts / Python Code

Microagents Framework

An experimental framework for dynamically creating self-improving agents in response to tasks.

View Demo Β· Report Bug Β· Request Feature


About The Project

Microagents represents a new approach to creating self-improving agents. Small, microservice-sized (hence, microagents) agents are dynamically generated in response to tasks assigned by the user to the assistant, assessed for their functionality, and, upon successful validation, stored for future reuse. This enables learning across chat sessions, enabling the system to independently deduce methods for task execution.

Built With

This project leverages the following technologies:

  • Python
  • OpenAI's GPT-4 Turbo
  • Text-Embedding-Ada-002

Getting Started

To get a local copy up and running follow these simple steps.

Prerequisites

  • OpenAI Account: Make sure you have an OpenAI account with access to gpt-4-turbo and text-embedding-ada-002.

Installation

  1. Clone the repo
    git clone https://github.com/aymenfurter/microagents.git
  2. Install Python packages
    pip install -r requirements.txt
  3. Set the environment variable
    • In case you want to use Open AI API:
      export OPENAI_KEY='your_api_key_here'
    • In case you want to use Azure Open AI with api key:
      export AZURE_OPENAI_API_KEY='your_api_key_here'
      export AZURE_OPENAI_ENDPOINT='https://my_endpoint_name_here.openai.azure.com/'
      # export OPENAI_EMBEDDING=''       # optionally set the azure deployment name of your ada embedding (in case the name is not text-embedding-ada-002)
      # export OPENAI_MODEL=''           # optionally set the azure deployment name of your gpt 4 (in case the name is not gpt-4-1106-preview)
    • In case you want to use Azure Open AI with Entra ID (AAD):
      export AZURE_OPENAI_ENDPOINT='https://my_endpoint_name_here.openai.azure.com/'
      export AZURE_OPENAI_USE_AAD='true' # enables DefaultAzureCredential
      # export AZURE_OPENAI_AD_TOKEN=''  # optionally specify the AAD token here
      # export AZURE_CLIENT_ID=''        # optionally specify the client id of the managed identity
      # export OPENAI_EMBEDDING=''       # optionally set the azure deployment name of your ada embedding (in case the name is not text-embedding-ada-002)
      # export OPENAI_MODEL=''           # optionally set the azure deployment name of your gpt 4 (in case the name is not gpt-4-1106-preview)

Usage

Caution

Microagents execute Python code directly and currently do not operate within a sandbox. It's highly recommended to run them in isolated environments such as GitHub Codespaces or Docker (README-Docker.md) to limit potential damage. Be mindful of the costs associated with using OpenAI's services.

For a demo run, execute:

 python main.py

For an interactive chat experience:

 python app.py

To remove all agents, simply delete the "agents.db" file.

Demo

Demo

Synthesized Agent Prompts

Fetch Weather Forecast Agent

You are an adept weather informant. Fetch the weather forecast by accessing public API data using this Python code snippet:

``python
import requests
import json

def fetch_weather_forecast(location, date):
    response = requests.get(f"https://api.met.no/weatherapi/locationforecast/2.0/compact?lat={location[0]}&lon={location[1]}")
    weather_data = response.json()
    for day_data in weather_data['properties']['timeseries']:
        if date in day_data['time']:
            print(day_data['data']['instant']['details'])
            break
``
# Example usage: fetch_weather_forecast((47.3769, 8.5417), '2024-01-22T12:00:00Z')
Note: Replace the (47.3769, 8.5417) with the actual latitude and longitude of the location and the date string accordingly.

IPBasedLocationFetcher Agent

You are a skilled IP-based location retriever. Use Python's requests library to obtain geolocation data from a public IP address. Here is a sample code snippet you may adapt:

``python
import requests

def fetch_location_from_ip(ip_address):
    response = requests.get(f'http://ip-api.com/json/{ip_address}')
    data = response.json()
    return data.get('country'), data.get('city')
``

# Example usage: 
# print(fetch_location_from_ip('8.8.8.8'))
Ensure that the code is capable of extracting location information such as country and city from the provided IP address.
How are agents created?

Changelog

Release v0.1.0 (21.01.2024)

This is the first release of Microagents, and a lot has happened since the initial project publication. Here are the key updates:

  • Pull Requests: The project has received a total of 6 Pull Requests, highlighting the interest from the community.

  • Two User Interfaces: We now offer two user interfaces for interacting with the agents:

    • For console enthusiasts, there is a Command Line Interface (CLI) available, which can be started using the textual-app.py file. This interface is a community contribution by bearney74.
    • Additionally, we provide a feature-rich web interface based on Gradio.
  • Parallelization: Microagents now support parallelism! When a new agent is created, three agents are actually spawned in parallel. The first agent to successfully complete its task is retained, while the others are disposed of.

  • Pretrained Agents: We have introduced 28 pretrained agents that are included for testing. These agents enable a wide range of tasks, from interacting with OpenStreetMap to providing current weather information. All of these agents were trained using Microagents.

  • Validation Phase ("Judge"): A new 'Judge' phase has been added to ensure that agents that claim to be working actually perform as expected. This additional validation step ensures that only fully functional agents are included in the catalog of working agents.

  • Persistent Agent Storage: Agents are now stored across runs, with SQLite being used for this purpose.

  • Improved Agent Memory: Agents now have the ability to remember only the agents they have previously created. This approach enhances the robustness of agent creation, as it avoids unnecessary depth changes during execution.

These updates represent a significant enhancement to Microagents. I am looking forward to further improvements and contributions from the community.

Contributing

Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

License

Distributed under the MIT License. See LICENSE for more information.

More Repositories

1

x

Solve complex tasks (e.g. writing and testing code) using LLM-Chains
Go
22
star
2

InsightGPT

InsightGPT is a project utilizing the power of Azure OpenAI Service to identify patterns and gain new insights from unstructured text.
TypeScript
21
star
3

Self-Determining-Agents

AI agents that can define their own goals to interact with a game environment. Powered by GPT-4o.
Python
17
star
4

azure-transcript-search-openai-demo

Sample ChatGPT-style Q&A app via RAG-pattern on Video transcripts.
Bicep
14
star
5

smartrag

Elevating RAG with Multi-Agent Systems
Python
8
star
6

nicehash-autoswitch-linux

A simple shell script to automatically switch algos on nicehash using the Nicehash Calculator.
Shell
5
star
7

c14r.io

open source container inspection tool
TypeScript
4
star
8

copilot-insurance-claim-demo

How a Picture of Car Damage Can File Your Insurance Claim
Java
4
star
9

florencellm

FlorenceLLM, a GPT-3.5 chatbot, finds help by examining git repos and identifying experts.
Go
3
star
10

azure-chat-with-your-photos-demo

Chatbot that comprehends uploaded images and engages in detailed conversations about their content.
Bicep
3
star
11

azure-openai-batch-demo

A demo on how to run Azure OpenAI generation batch jobs on ACA
Python
2
star
12

thunderbird-jira-integration

Create Jira Tickets directly from within Mozilla Thunderbird.
JavaScript
2
star
13

anlageanton

AnlageAnton is an AI-based wealth management solution using GPT-4 to provide optimal retirement plans for users. It utilizes a conversational AI interface to gather information and provide recommendations.
Python
2
star
14

ChatGPT-on-autopilot

Handing over a shell to ChatGPT through ReAct logic - What could possible go wrong? πŸ€“
JavaScript
2
star
15

playwright-testing-service-demo

Demo of cross-browser chatbot testing using Microsoft's Playwright Testing Service
JavaScript
2
star
16

aks-challenges

Python
1
star
17

tf-dcgan

Tensorflow based DC-GAN implementation for 64x64 RGB images
Python
1
star
18

GitHub-Advanced-Security-ADO-Conditional-Run

Demo project showcasing how to conditionally run GitHub Advanced Security based on its enablement status for a specific Azure DevOps Repository.
1
star
19

upskiller

A bot, dedicated to guiding you through the vast expanse of Azure-related content
C#
1
star
20

azautomation-pipeline-example

This example Azure DevOps pipeline deploys PowerShell runbooks to Azure Automation.
PowerShell
1
star
21

talend-docker

Talend 7.1.1 Docker Image
Dockerfile
1
star
22

kibana-sshactivity

1
star
23

ai-cryptoskins-botty

AI Cryptoskins are skins created by Artificial Intelligence.
Python
1
star
24

ai-podcast-generator

GPT-4o-Realtime based AI Podcast Generator
Python
1
star
25

landscape

CSS
1
star