This repository contains the code for MatFixer, an AI-powered system that assists users in diagnosing and fixing issues in their MATLAB code. It features a multi-agent architecture built using LangGraph, FastAPI for the backend, and a Flutter frontend.
The system follows a multi-agent workflow orchestrated by LangGraph:
- User Query: The user submits a query or describes a MATLAB problem through the Flutter application.
- Backend API: The Flutter app communicates with a FastAPI backend (
Backend1
orBackend2
). - LangGraph Workflow (Backend1 - Advanced):
- The query is processed to define the core problem.
- Multiple agents run in parallel to gather information:
- RAG Agents: Search internal knowledge bases (built from MATLAB docs, Stack Overflow dumps stored in ChromaDB) for potential root causes and solutions.
- Web Search Agent: Searches the web (using Tavily) for broader context or recent solutions.
- Synthesizer: Results from the RAG and web agents are synthesized into a coherent analysis, including root cause and proposed solutions, formatted in Markdown.
- LangGraph Workflow (Backend2 - Simpler RAG):
- Provides a direct RAG pipeline using ChromaDB and a Gemini LLM to generate answers with citations based on the knowledge bases.
- Response: The backend returns the synthesized report or direct answer as a JSON response.
- Frontend Display: The Flutter application displays the response to the user in a chat interface.
- Feedback: Users can provide feedback on the generated solutions, which is stored via Firebase for potential future improvements. An Admin dashboard allows viewing this feedback.
- MATLAB Integration (Conceptual): The architecture includes a provision for integrating with MATLAB directly (e.g., via the MATLAB Engine API for Python) for verification, though the primary implementation focuses on providing code suggestions and explanations.
graph LR
subgraph Frontend["Flutter App"]
direction LR
UI[Chat Interface]
F_API[API Provider]
FB_Auth[Firebase Auth]
FB_Store[Firestore Convos/Feedback]
end
subgraph Backend1 ["Backend 1 (Port 8000)"]
direction TB
B1_API[FastAPI: chat_api1.py]
B1_LG[LangGraph: graph.py]
B1_State[AppState: state.py]
B1_LLM[Groq LLM]
B1_Agents[Agents: RAG Root/Sol, Web, Synthesizer]
B1_Chroma[ChromaDB Docs/StackO]
B1_Tavily[Tavily Search]
B1_API --> B1_LG;
B1_LG -- Uses --> B1_State;
B1_LG -- Runs --> B1_Agents;
B1_Agents -- Uses --> B1_LLM;
B1_Agents -- RAG --> B1_Chroma;
B1_Agents -- Web --> B1_Tavily;
end
subgraph Backend2 ["Backend 2 (Port 8002)"]
direction TB
B2_API[FastAPI: chat_api2.py]
B2_LG[LangGraph in API]
B2_State[AgentState]
B2_LLM[Gemini LLM]
B2_Chroma[ChromaDB Docs/StackO]
B2_Reranker[Reranker]
B2_API -- Defines/Runs --> B2_LG;
B2_LG -- Uses --> B2_State;
B2_LG -- RAG --> B2_Chroma;
B2_LG -- Uses --> B2_LLM;
B2_LG -- Uses --> B2_Reranker;
end
subgraph Services
Firebase[Firebase: Auth, Firestore]
MATLAB[MATLAB Integration]
end
UI <--> F_API;
F_API -- Calls --> B1_API;
F_API -- Calls --> B2_API;
UI <--> FB_Auth;
UI <--> FB_Store;
B1_API --> MATLAB;
style Frontend fill:#f9f,stroke:#333,stroke-width:2px
style Backend1 fill:#ccf,stroke:#333,stroke-width:2px
style Backend2 fill:#cdf,stroke:#333,stroke-width:2px
style Services fill:#ff9,stroke:#333,stroke-width:2px
- /Backend1: Contains the primary, more complex FastAPI backend using LangGraph with separate agent nodes, Groq LLM, ChromaDB, and Tavily web search.
- /Backend2: Contains a simpler, alternative FastAPI backend using LangGraph directly within the API file, leveraging Gemini LLM and ChromaDB for RAG.
- /app: Contains the Flutter frontend application for user interaction, conversation management, and feedback.
- Frontend: Flutter, Provider
- Backend: Python, FastAPI, Uvicorn
- Orchestration: LangGraph
- AI/LLM: LangChain, Google Gemini, Groq (Llama 3), Sentence Transformers (Embeddings, Reranking)
- Vector Store: ChromaDB
- Web Search: Tavily Search API
- Persistence: Firebase (Firestore for conversations/feedback, Auth for users)
-
Clone the Repository:
git clone https://github.com/AmanSikarwar/matfixer cd matfixer
-
Setup Backend1: See
Backend1/README.md
. Requires Python, pip, and API keys for Groq and Tavily in a.env
file. -
Setup Backend2: See
Backend2/README.md
. Requires Python, pip, and a Google Gemini API Key (currently hardcoded - improvement needed). -
Setup Flutter App: See
app/README.md
. Requires Flutter SDK and Firebase project setup. Update backend URLs inapp/lib/providers/fast_api_llm_provider.dart
if necessary.
-
Start Backend1:
cd Backend1 # Activate virtual environment uvicorn chat_api1:app --host 0.0.0.0 --port 8000 --reload
-
Start Backend2:
cd Backend2 # Activate virtual environment uvicorn chat_api2:app --host 0.0.0.0 --port 8002 --reload
(Note: Backend2 also contains
smartapi.py
running on port 8001, which might be an alternative endpoint not directly used by the main app flow) -
Run Flutter App:
cd app flutter run -d <chrome|macos|windows>
Refer to the README files within each subdirectory (Backend1
, Backend2
, app
) for more detailed instructions.