An assistive AI app for dementia care. Mementor combines smart-glasses style UI, on-device cues, and backend face recognition so users can recognize people, stay safe, and follow simple task prompts.
- Smart Glasses Camera UI (Expo/React Native)
- Landscape camera overlay with status, time, location
- Continuous 10s audio capture for context
- Task reminders with concise LLM-generated steps shown in a popup
- Person recognition overlay: shows name + relationship on the right and a color border around the screen
- Face Recognition Backend
- Python FastAPI service (
python-face-service/) handles face detection & recognition - MCP Server (
mcp-server/) exposes a clean tool API for agents and services - Integration guide and architecture docs included
- Python FastAPI service (
- Safety and Care
- "Are you lost?" alert if the user strays >1km from a saved home location, with quick actions to call caretaker or get directions home
HackMIT/
├─ frontend/ # Expo React Native app (Mementor)
├─ python-face-service/ # FastAPI microservice for face recognition
├─ mcp-server/ # MCP server exposing recognize_face tool
├─ AGENT_INTEGRATION_GUIDE.md # How agents should call the system
├─ INTEGRATED_ARCHITECTURE.md # High-level integration diagram & flow
├─ start-services.sh # Helper script to run backend services
└─ README.md # This file
Prerequisites: Node.js 18+, npm, Expo CLI; iOS Simulator or Android Emulator (or Expo Go on device).
- Install deps
cd frontend
npm install- Configure environment (optional)
- Anthropic key for LLM task prompts (optional fallback exists):
- Create
frontend/.envand add:EXPO_PUBLIC_ANTHROPIC_API_KEY=sk-ant-...
- Create
- Run the app
npm startChoose iOS/Android/Web from the Expo menu.
- File:
components/CameraScreen.tsx- Continuous audio capture (10s segments) and auto-upload to backend agent
- Person recognition UI: name + relationship panel on right; border color matches backend
color - Task reminders invoke Anthropic to simplify instructions; alerts are length-limited for readability
- Lost detection using Location + Contacts integration
Prerequisites: Python 3.10+, pip; Node.js 18+ for MCP server.
- One-shot startup for both services
./start-services.shThis launches:
- Python Face Service on http://localhost:8001
- MCP Server in dev mode (see its console for port)
- Manual startup
- Python service
cd python-face-service
pip install -r requirements.txt
python face_service.py- MCP server
cd mcp-server
npm install
npm run dev- Endpoint:
POST /search-person - Request JSON:
{
"image_data": "...",
"person_name": "John Doe", // optional
"person_relationship": "Friend" // optional
}- Response JSON:
{
"success": true,
"person": "John Doe",
"relationship": "Friend",
"confidence": 0.95,
"color": "#45B7D1",
"is_new_person": false,
"message": "Found existing person: John Doe (Friend)"
}More details in AGENT_INTEGRATION_GUIDE.md and INTEGRATED_ARCHITECTURE.md.
The frontend sends base64 image and audio to an agent endpoint. Expected success payload contains person, relationship, and color. The UI updates accordingly:
- Right-side info card shows name and relationship
- A dynamic border uses the returned
color
In case of backend errors, the app logs them and can fall back to demo data for UI testing.
- Backend error: "the JSON object must be str, bytes or bytearray, not dict"
- Cause: Double-parsing JSON on backend; remove extra
json.loads()if the request body is already parsed by the framework.
- Cause: Double-parsing JSON on backend; remove extra
- Backend error:
'tool_result'- Cause: Accessing a non-existent key; ensure your backend returns
{ success, person, relationship, color, ... }directly (or unwrap nested fields).
- Cause: Accessing a non-existent key; ensure your backend returns
- Expo permissions
- Ensure Camera, Microphone, Location permissions are granted on device/emulator.
- Anthropic key missing
- The app falls back to a plain reminder string if no key is provided.
- Preload a home location in Settings
- Add a few tasks with different times to showcase reminders
- Use a known face image to show recognition result (name/relationship/border)
- Check out our slide deck: https://docs.google.com/presentation/d/15DfLmtCiV6k9NrEOcIAQf_5hdCcV5W4XxeaW9ZBsfbw/edit?slide=id.gf04aff5e11_8_183#slide=id.gf04aff5e11_8_183
