Skip to content
This repository has been archived by the owner on Jan 6, 2025. It is now read-only.

Project: MyFitnessBuddy - AI powered Fitness Assistant [RAGHack] #145

Open
5 of 9 tasks
JeevaSaravanan opened this issue Sep 17, 2024 · 6 comments
Open
5 of 9 tasks

Comments

@JeevaSaravanan
Copy link

JeevaSaravanan commented Sep 17, 2024

Project Name

MyFitnessBuddy - AI powered Fitness Assistant

Description

RagHack - GenAI Fitness Advisor App

Problem Definition:

banner

  1. Personalized Fitness Guidance: MyFitnessBuddy is a GenAI Fitness Advisor App that provides customized workout routines, diet plans, and a food calorie calculator, addressing the limitations of generic fitness apps.

  2. Advanced Retrieval-Augmented Generation: It leverages a hybrid approach combining Retrieval-Augmented Generation (RAG) and Graph Retrieval-Augmented Generation (GRAG) to deliver accurate and context-aware responses to user queries.

  3. Showcasing Innovation at RAGHack: Developed for the RAGHack hackathon, MyFitnessBuddy demonstrates the power of RAG technologies in creating engaging and effective AI-driven fitness solutions using Azure AI and popular frameworks.

Architecture and Implementation:

Architecture Overview:

alt text

Fig.1 Architecture

MyFitnessBuddy uses a hybrid architecture combining Retrieval-Augmented Generation (RAG) and Graph Retrieval-Augmented Generation (GRAG). Data is extracted using a Python script and ingested into Azure Blob Storage for structured data and Azure Cosmos DB (Gremlin API) for unstructured data. Azure AI Search indexes the structured data, while the graph database manages complex relationships in the unstructured data.
The application utilizes Azure AI Studio and Prompt Flow to define chat logic and connect data sources. User queries are processed by the app server, retrieving relevant information from Azure AI Search and Cosmos DB, which is then sent to Azure OpenAI Services (ChatGPT) to generate personalized responses.
This hybrid approach ensures accurate, context-aware, and personalized fitness guidance for users.

Implementation Overview:

Data Extraction and Ingestion:

ArchitectureGraphRag

Fig 2. Data Extraction Architecture

  • The process begins with a Python script that extracts structured and unstructured data from various sources. This data is then ingested into two different storage systems:
    • Azure Blob Storage: Used for structured data, which is chunked and indexed.
    • Azure Cosmos DB (Gremlin API): Used for unstructured data, ingested as GraphDoc to enable graph-based retrieval.

Hybrid RAG Approach:

ArchitectureGraphRag

Fig 3. Hybrid RAG Architecture

  • RAG (Retrieval-Augmented Generation):
    • The structured data ingested into Azure Blob Storage is connected to Azure AI Search for indexing and retrieval.
    • Azure AI Studio facilitates the chunking and indexing of data, defining chat logic, and generating endpoints using Azure Prompt Flow.
    • When a user query is received, Azure AI Search retrieves relevant information from the indexed data.
  • Graph RAG (Graph Retrieval-Augmented Generation):
    • Azure Cosmos DB stores the unstructured data in a graph format using the Gremlin API. This approach allows the application to understand complex relationships between entities such as food items, exercises, and user health metrics.
    • The Graph RAG retrieves contextually relevant knowledge from Azure Cosmos DB, which is then combined with structured data for enhanced response generation.

AzureCosmoDB
AzureCosmoDB

Fig 4. Example of how Unstructured Data is stored as Graph in Azure CosmoDB(Gremlin API)

Azure AI Studio:

AzureCosmoDB

Fig 5. Azure AI Studio Architecture

Prompt Flow

We deployed two endpoints using Azure Prompt Flow. One is a rewrite intent endpoint, and the other is a My Fitness Buddy. These endpoints are designed to solve two different use cases: one focuses on optimizing document retrieval through query generation, while the other offers personalized fitness advice within predefined safe boundaries with the knowledge base of the RAG.

1. Rewrite Intent Endpoint

Purpose: This endpoint was designed to handle a specific task: generating search queries based on a user's question and previous conversation history. By combining the "current user question" and prior context, the endpoint generates a single canonical query that includes all necessary details, without variants. This is employed for document retrieval systems, where generating these precise queries and intent leading to more accurate results.

rewrite intent

Fig 6. Flow of Rewrite Intent endpoint

2. My Fitness Buddy endpoint

Purpose: The second endpoint is a My Fitness Buddy that offers personalized fitness advice, workout plans, and nutrition tips based on user input. The assistant is programmed to avoid medical advice and stick solely to the provided dataset to ensure that all recommendations are safe, motivational, and evidence-based and the knowledge base is retreived for the chuncks of documents configured as search indexes.

rewite intent

Fig 7. Flow of My Fitness Buddy endpoint

Application Flow:

  • The user interacts with the MyFitnessBuddy app through a Python Streamlit-based chatbot interface.
  • The application server processes the user's query and directs it to the appropriate retrieval system (Azure AI Search for structured data or Azure Cosmos DB for unstructured data) based on the query type.
  • Relevant information is retrieved from the selected data source and sent to Azure OpenAI Services (ChatGPT) along with a crafted prompt to generate a personalized response.
  • The final response, enriched with contextually relevant information, is returned to the user via the Streamlit app, providing tailored fitness advice and recommendations.

Application
Application
Application
Application
Application
Application

Fig 8. Application

Application

Fig 9. Testing tool for endpoints

Technologies Used:

  • Data Storage and Retrieval: Azure Blob Storage, Azure Cosmos DB (Gremlin API), Azure AI Search.
  • AI and Language Models: Azure OpenAI Services (ChatGPT).
  • Data Processing and Logic Flow: Azure AI Studio, Azure Prompt Flow.
  • Backend and Application Server: Python for data extraction and preprocessing, with multiple integration points for data ingestion and retrieval.

Target Audience:

  • Fitness Enthusiasts: Individuals who are passionate about fitness and are looking for personalized workout routines and diet plans to optimize their fitness journey.
  • Health-Conscious Individuals: People who prioritize a healthy lifestyle and want easy access to accurate nutritional information, calorie tracking, and tailored dietary advice.
  • Beginners in Fitness: Newcomers who need guidance on starting their fitness journey, including basic workout routines, dietary recommendations, and answers to common fitness-related questions.
  • Busy Professionals: Users with limited time for fitness planning who seek convenient, on-demand access to customized fitness guidance and quick answers to health-related queries.
  • Individuals with Specific Health Goals: Those with unique fitness goals or health conditions who require personalized plans and advice that consider their specific needs and preferences.

Conclusion and Future Works:

Conclusion

MyFitnessBuddy demonstrates the potential of combining advanced AI techniques like Retrieval-Augmented Generation (RAG) and Graph Retrieval-Augmented Generation (GRAG) to create a highly personalized and context-aware fitness advisor. By leveraging Azure AI's capabilities and integrating multiple data sources, the app provides customized workout routines, dietary plans, and accurate responses to user queries. This approach enhances user engagement and satisfaction by delivering tailored and relevant fitness guidance.

Future Work

  • Enhanced Personalization: Further refine the models to provide more granular customization based on user feedback, behavior, and preferences.
  • Multilingual Support: Implement multilingual capabilities to reach a broader audience globally.
  • Advanced Analytics: Develop advanced analytics features to provide users with deeper insights into their fitness progress, habits, and trends.
  • Expanded Data Sources: Incorporate additional data sources such as medical databases and user-generated content to enhance the app’s knowledge base and improve recommendation accuracy.

Developers:

Rohan Ponramesh
Jeeva Saravana Bhavanandam

Technology & Languages

  • JavaScript
  • Java
  • .NET
  • Python
  • AI Studio
  • AI Search
  • PostgreSQL
  • Cosmos DB
  • Azure SQL

Project Repository URL

https://github.com/rohanramesh38/RagHack/tree/main

Deployed Endpoint URL

No response

Project Video

https://www.youtube.com/watch?v=qELr2ZOh-GU

Team Members

@JeevaSaravanan [[email protected]] , @rohanramesh38 [[email protected]]

@jeremiah-louis
Copy link

Really love you guy's entries goodluck ✨

@JeevaSaravanan
Copy link
Author

Really love you guy's entries goodluck ✨

Thanks

@jeremiah-louis
Copy link

You're welcome. I also dropped a follow

@jaydestro
Copy link

@JeevaSaravanan do you have a deployed version I can demo?

@rohanramesh38
Copy link

@JeevaSaravanan do you have a deployed version I can demo?

To minimize costs and API usage, we chose not to deploy it publicly. Feel free to send me an email, and we can arrange a private demo if that works for you.

@multispark
Copy link
Collaborator

Hello @JeevaSaravanan, thank you for participating in RAG Hack!

The team is working hard to distribute badges. Please have each team member fill out this form:
aka.ms/raghack/badge-dist

Thank you!

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants