Skip to content

Demonstrates how to chat with your architecture using Amazon Bedrock's Converse API, tool use, and a knowledge base. Implemented in Python, the demo allows users to analyze architecture diagrams, evaluate effectiveness, get recommendations, and make informed decisions about their system architecture.

License

Notifications You must be signed in to change notification settings

build-on-aws/conversation-with-your-architecture

Conversation With Your Architecture Demo

This project demonstrates how to chat with your architecture using Amazon Bedrock's Converse API, tool use, and a knowledge base. Implemented in Python, the demo allows users to analyze architecture diagrams, evaluate effectiveness, get recommendations, and make informed decisions about their system architecture.

This project accompanies the following resources:

Overview

The application interacts with a foundation model on Amazon Bedrock to provide information based on an architecture diagram and user input. It utilizes three custom tools to gather information:

  1. Audit Info Tool: Provides audit information about a system based on the system name inferred from the architecture diagram file name.
  2. Joy Count Tool: Provides joy count data about a system.
  3. Best Practices Tool: Provides a company's best practices information, including best practices around how much joy the application is generating.

This demo is based on the Amazon Bedrock Tool Use Demo and parts of Amazon Bedrock: Enhance HR Support with Function Calling & Knowledge Bases blog post.

⚠️ Warning

Running this app may result in charges to your AWS account.

Repository Structure

  • architecture_chat_demo.py: Main entry point for the demo application.
  • audit_info_tool.py: Implementation of the Audit Info Tool.
  • best_practices_tool.py: Implementation of the Best Practices Tool.
  • joy_count_tool.py: Implementation of the Joy Count Tool.
  • demo/: Directory containing sample data files.
    • audit-info.json: Sample audit information for the Fluffy Puppy Joy Generator system.
    • best-practices-data.md: Sample best practices data for the organization
    • joy-count.json: Sample joy count data for the Fluffy Puppy Joy Generator system.
    • fluffy-puppy-joy-generator.png: Sample architecture diagram image for the Fluffy Puppy Joy Generator system.
    • fluffy-puppy-joy-generator.drawio: Sample architecture diagram Draw.io format for the Fluffy Puppy Joy Generator system.
  • util/: Directory containing utility functions.
    • demo_print_utils.py: Utility functions for printing demo-related messages.
  • README.md: This file, containing project documentation.

Usage Instructions

Prerequisites

To run this demo, you'll need a few bits set up first:

Setup

Amazon Bedrock Knowledge Base

You can set up a knowledge base using these instructions. Note that this can result in charges to your AWS account.

Environment Variables

Set up your custom environment variables by creating a .env file in the project root directory with the following content:

AWS_REGION=<your-aws-region>
KNOWLEDGE_BASE_ID=<your-knowledge-base-id>

Run the app

  1. To run the app, run the following command in your virtual environment:
python architecture_chat_demo.py
  1. When prompted, enter fluffy-puppy-joy-generator.png when prompted for a diagram to chat with (or check out the next section to use your own).

  2. Then enter one of the example queries to interact with the diagram or ask your questions about the architecture.

  3. To exit the demo, type x and press Enter.

Tear down

Be sure to tear down any AWS resources you're not using after working through this demo as they may result in charges to your AWS account. The resources to destroy are:

  • S3 bucket for your knowledge base data source
  • Amazon Bedrock Knowledge Base

Bring your own diagram

Want to chat with your own diagram? Drop an image file (jpg, jpeg, or png) into the demo folder and rerun the app. When prompted, enter the full name (excluding the path) of that diagram to chat with.

Sample queries

Below are some sample queries you could use to chat with an architecture diagram in this app:

  • List the AWS Services used in the architecture diagram by official AWS name and excluding any sub-titles.
  • What are the recommended strategies for unit testing this architecture?
  • How well does this architecture adhere to the AWS Well Architected Framework?
  • What improvements should be made to the resiliency of this architecture?
  • Convert the data flow from this architecture into a Mermaid formatted sequence diagram.
  • What are the quotas or limits in this architecture?
  • What is the current joy count of the system?
  • Is the current joy count good or bad?

Bonus: Generate the infrastructure code

Depending on the type of diagram you're chatting with, you could also enter the following query to generate the infrastructure code:

Can you generate the Terraform code to provision this architecture?

Data Flow

  1. User Input: The user provides input through the command-line interface.
  2. Architecture Chat Demo: The main ArchitectureChatDemo class processes the user input and manages the conversation flow.
  3. Amazon Bedrock: The user's input is sent to Amazon Bedrock's Converse API along with the system prompt and tool configurations.
  4. Tool Invocation: Based on the model's response, the appropriate tool (Audit Info, Joy Count, or Best Practices) is invoked.
  5. Tool Processing: The invoked tool fetches data from its respective source (JSON files or knowledge base).
  6. Response Generation: The tool's output is sent back to Amazon Bedrock for further processing and response generation.
  7. User Output: The final response is displayed to the user through the command-line interface.

See sequence diagram.

Troubleshooting

  • If you encounter authentication errors, ensure your AWS credentials are correctly set up in your environment or AWS credentials file.
  • If the demo fails to start, check that all required environment variables are set in the .env file.
  • For issues with tool invocations, verify that the JSON files in the demo/ directory are present and correctly formatted.

To enable debug mode, set the logging level to DEBUG in the architecture_chat_demo.py file:

logging.basicConfig(level=logging.DEBUG, format="%(message)s")

This will provide more detailed output about the conversation flow and tool invocations.

Security

See CONTRIBUTING for more information.

License

This library is licensed under the MIT-0 License. See the LICENSE file.

About

Demonstrates how to chat with your architecture using Amazon Bedrock's Converse API, tool use, and a knowledge base. Implemented in Python, the demo allows users to analyze architecture diagrams, evaluate effectiveness, get recommendations, and make informed decisions about their system architecture.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks