AI Agent to analyze blood reports and provide detailed health insights.
Features | Tech Stack | Installation | Project Structure | Contributing | Author
- Agent-based architecture
- Analysis Agent: Report analysis with in-context learning from previous analyses and a built-in knowledge base
- Chat Agent: RAG-powered follow-up Q&A over your report (FAISS + HuggingFace embeddings)
- Multi-model cascade via Groq with automatic fallback (primary β secondary β tertiary β fallback)
- Chat sessions: Create multiple analysis sessions; each session stores report, analysis, and follow-up messages in Supabase
- Report sources: Upload your own PDF or use the built-in sample report for quick testing
- PDF handling: Upload up to 20MB, max 50 pages; validation for file type and medical-report content
- Daily analysis limit: Configurable cap (default 15/day) with countdown in the sidebar
- Secure auth: Supabase Auth (sign up / sign in), session validation, and configurable session timeout
- Session history: View, switch, and delete past sessions; report text persisted for follow-up chat across reloads
- Modern UI: Responsive Streamlit app with sidebar session list, user greeting, and real-time feedback
- Frontend: Streamlit (1.42+)
- AI / LLM
- Report analysis: Groq with multi-model fallback via
ModelManager- Primary:
meta-llama/llama-4-maverick-17b-128e-instruct - Secondary:
llama-3.3-70b-versatile - Tertiary:
llama-3.1-8b-instant - Fallback:
llama3-70b-8192
- Primary:
- Follow-up chat: RAG with LangChain, HuggingFace embeddings (
all-MiniLM-L6-v2), FAISS vector store, and Groq (llama-3.3-70b-versatile)
- Report analysis: Groq with multi-model fallback via
- Database: Supabase (PostgreSQL)
- Tables:
users,chat_sessions,chat_messages
- Tables:
- Auth: Supabase Auth, Gotrue
- PDF: PDFPlumber (text extraction), filetype (file validation)
- Libraries: LangChain, LangChain Community, LangChain HuggingFace, LangChain Text Splitters, sentence-transformers, FAISS (CPU)
- Python 3.8+
- Streamlit 1.42+
- Supabase account
- Groq API key
- PDFPlumber, filetype
- Clone the repository:
git clone https://github.com/harshhh28/hia.git
cd hia- Install dependencies:
pip install -r requirements.txt- Required environment variables (in
.streamlit/secrets.toml):
SUPABASE_URL = "your-supabase-url"
SUPABASE_KEY = "your-supabase-key"
GROQ_API_KEY = "your-groq-api-key"- Set up Supabase database schema:
The application uses three tables: users, chat_sessions, and chat_messages. Use the SQL script at public/db/script.sql to create them.
(You can turn off email confirmation on signup in Supabase: Authentication β Providers β Email β Confirm email.)
- Run the application:
streamlit run src\main.pyhia/
βββ requirements.txt
βββ README.md
βββ src/
β βββ main.py # Application entry point; chat UI and session flow
β βββ auth/
β β βββ auth_service.py # Supabase auth, sessions, chat message persistence
β β βββ session_manager.py # Session init, timeout, create/delete chat sessions
β βββ components/
β β βββ analysis_form.py # Report source (upload/sample), patient form, analysis trigger
β β βββ auth_pages.py # Login / signup pages
β β βββ footer.py # Footer component
β β βββ header.py # User greeting
β β βββ sidebar.py # Session list, new session, daily limit, logout
β βββ config/
β β βββ app_config.py # App name, limits (upload, pages, analysis, timeout)
β β βββ prompts.py # Specialist prompts for report analysis
β β βββ sample_data.py # Sample blood report for "Use Sample PDF"
β βββ services/
β β βββ ai_service.py # Analysis + chat entry points; vector store caching
β βββ agents/
β β βββ analysis_agent.py # Report analysis, rate limits, knowledge base, in-context learning
β β βββ chat_agent.py # RAG pipeline (embeddings, FAISS, query contextualization)
β β βββ model_manager.py # Groq multi-model cascade and fallback
β βββ utils/
β βββ validators.py # Email, password, PDF file and content validation
β βββ pdf_extractor.py # PDF text extraction and validation
βββ public/
β βββ db/
β βββ script.sql # Supabase schema (users, chat_sessions, chat_messages)
β βββ schema.png # Schema diagram
Contributions are welcome! Please read our Contributing Guidelines for details on how to submit pull requests, the development workflow, coding standards, and more.
We appreciate all contributions, from reporting bugs and improving documentation to implementing new features.
Thanks to all the amazing contributors who have helped improve this project!
| Avatar | Name | GitHub | Role | Contributions | PR(s) | Notes |
|---|---|---|---|---|---|---|
![]() |
Harsh Gajjar | harshhh28 | Project Creator & Maintainer | Core implementation, Documentation | N/A | Lead Developer |
![]() |
Gaurav | gaurav98095 | Contributor | DB Schema, bugs | #1, #5, #6, #7 | Database Design, bugs |
This project is licensed under the MIT License - see the LICENSE file for details.
Created by Harsh Gajjar



