Skip to content

Latest commit

 

History

History
250 lines (183 loc) · 8.24 KB

File metadata and controls

250 lines (183 loc) · 8.24 KB

AI Agents from Scratch

AI Agents from Scratch

Table of Contents

Overview

The Multi-Agents AI System from Scratch is a Python-based application leveraging OpenAI's GPT-4o model to perform specialized tasks through a collaborative multi-agent architecture. Built with Streamlit for an intuitive web interface without any Agents frameworks/libraries, this system includes agents for summarizing medical texts, writing research articles, and sanitizing medical data (Protected Health Information - PHI). Each primary agent is paired with a corresponding validator agent to ensure the quality and accuracy of the outputs. Built it for beginners so they can understand that Agents can be built without orchestration frameworks like Crew AI, AutoGen, LangGraph, etc.

Features

  • Summarize Medical Texts: Generate concise summaries of lengthy medical documents.
  • Write Research Articles: Create detailed research articles based on a given topic and optional outline.
  • Sanitize Medical Data (PHI): Remove sensitive health information from medical datasets.
  • Quality Validation: Each primary task is accompanied by a validator agent to assess and ensure output quality.
  • Robust Logging: Comprehensive logging for monitoring and debugging purposes.
  • User-Friendly Interface: Streamlit-based web app for easy interaction and task management.

Architecture

+-------------------+
|       User        |
+---------+---------+
          |
          | Interacts via
          v
+---------+---------+
|    Streamlit App  |
+---------+---------+
          |
          | Sends task requests to
          v
+---------+---------+
|  Agent Manager    |
+---------+---------+
          |
          +---------------------------------------------+
          |                      |                      |
          v                      v                      v
+---------+---------+  +---------+---------+  +---------+---------+
|  Summarize Agent  |  |  Write Article    |  |  Sanitize Data    |
|  (Generates summary)| |  (Generates draft)| |  (Removes PHI)    |
+---------+---------+  +---------+---------+  +---------+---------+
          |                      |                      |
          v                      v                      v
+---------+---------+  +---------+---------+  +---------+---------+
|Summarize Validator|  | Refiner Agent      |  |Sanitize Validator |
|      Agent        |  |  (Enhances draft)  |  |      Agent        |
+---------+---------+  +---------+----------+ +----------+--------+
          |                      |                      |
          |                      |                      |
          +-----------+----------+-----------+----------+
                      |                      |
                      v                      v
                +-----+-------+        +-----+-------+
                |   Logger    |        |   Logger    |
                +-------------+        +-------------+

Components Breakdown

  1. User

    • Interacts with the system via the Streamlit web interface.
    • Selects tasks and provides input data.
  2. Streamlit App

    • Frontend interface for user interaction.
    • Sends user requests to the Agent Manager.
    • Displays results and validation feedback.
  3. Agent Manager

    • Central coordinator for all agents.
    • Delegates tasks to appropriate main and validator agents.
  4. Main Agents

    • Summarize Agent: Generates summaries of medical texts.
    • Write Article Agent: Creates drafts of research articles.
    • Sanitize Data Agent: Removes PHI from medical data.
  5. Validator Agents

    • Summarize Validator Agent: Assesses the quality of summaries.
    • Refiner Agent: Enhances drafts for better quality.
    • Sanitize Validator Agent: Ensures all PHI has been removed.
  6. Logger

    • Records all interactions, inputs, outputs, and errors.
    • Facilitates monitoring and debugging.

Installation

Prerequisites

Steps

  1. Clone the Repository

    git clone https://github.com/AIAnytime/Multi-Agents-System-from-Scratch.git
    cd Multi-Agents-System-from-Scratch
  2. Create a Virtual Environment

    python3 -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
  3. Install Dependencies

    pip install -r requirements.txt
  4. Set Up Environment Variables

    Create a .env file in the project root:

    OPENAI_API_KEY=your-api-key-here

    Alternatively, set the environment variable directly:

    • Unix/MacOS:

      export OPENAI_API_KEY='your-api-key-here'
    • Windows:

      set OPENAI_API_KEY=your-api-key-here

Usage

  1. Activate the Virtual Environment

    source venv/bin/activate  # On Windows: venv\Scripts\activate
  2. Run the Streamlit App

    streamlit run app.py
  3. Access the App

    Open the URL provided by Streamlit (usually http://localhost:8501) in your web browser.

  4. Interact with the Tasks

    • Summarize Medical Text: Input medical texts to receive concise summaries.
    • Write and Refine Research Article: Provide a topic and optional outline to generate and refine research articles.
    • Sanitize Medical Data (PHI): Input medical data to remove sensitive information.

Agents

Main Agents

  • Summarize Agent

    • Function: Generates summaries of provided medical texts.
    • Usage: Input the text, and receive a concise summary.
  • Write Article Agent

    • Function: Creates drafts of research articles based on a topic and optional outline.
    • Usage: Provide a topic and outline to generate an initial draft.
  • Sanitize Data Agent

    • Function: Removes Protected Health Information (PHI) from medical data.
    • Usage: Input medical data containing PHI to receive sanitized data.

Validator Agents

  • Summarize Validator Agent

    • Function: Validates the accuracy and quality of summaries.
    • Usage: Receives the original text and its summary to assess quality.
  • Refiner Agent

    • Function: Enhances and refines research article drafts for better clarity and coherence.
    • Usage: Receives a draft article and returns an enhanced version.
  • Sanitize Validator Agent

    • Function: Ensures that all PHI has been removed from sanitized data.
    • Usage: Receives original and sanitized data to verify PHI removal.

Logging

  • Location: Logs are stored in the logs/ directory.
  • Files:
    • multi_agent_system.log: Contains detailed logs for monitoring and debugging.
  • Configuration: Logging is handled using the loguru library, configured in utils/logger.py.

Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the Repository

  2. Create a Feature Branch

    git checkout -b feature/YourFeature
  3. Commit Your Changes

    git commit -m "Add your feature"
  4. Push to the Branch

    git push origin feature/YourFeature
  5. Open a Pull Request

License

This project is licensed under the MIT License.

Acknowledgements

  • OpenAI for providing the GPT-4 model.
  • Streamlit for the web application framework.
  • Loguru for the logging library.
  • Inspired by collaborative multi-agent system architectures and prompt engineering techniques like Chain-of-Thought (CoT) and ReAct.