math-solver / README.md
Cuong2004
Deploy API from GitHub Actions
395651c
metadata
title: Math Solver Backend
emoji: 📐
colorFrom: blue
colorTo: indigo
sdk: docker
app_port: 7860
pinned: false

Visual Math Solver - Backend (Hugging Face Space)

Hệ thống AI giải toán hình học sử dụng Multi-Agent và Manim. Hiện đã nâng cấp lên phiên bản v5.1.

Tính năng mới (v5.1)

  • Symbolic Solver: Tích hợp SymPy để tự động hóa việc tính toán các giá trị hình học (diện tích, chu vi, độ dài) với độ chính xác tuyệt đối và trình bày các bước giải chi tiết.
  • 3D Video Support: Nâng cấp công cụ Manim để hỗ trợ hiển thị và xoay camera cho các bài toán hình học không gian (Hình chóp, Hình lăng trụ, v.v.).

Kiến trúc Pipeline (Agentic Flow)

  1. OCR Agent: Nhận diện văn bản từ hình ảnh câu hỏi.
  2. Parser Agent: Chuyển đổi ngôn ngữ tự nhiên thành Geometry DSL.
  3. Knowledge Agent: Bổ sung kiến thức chuyên sâu về hình học.
  4. Geometry Engine: Giải hệ phương trình tọa độ để dựng hình.
  5. Solver Agent (New): Thực hiện các phép tính toán học hình thức (Symbolic Math).
  6. Renderer Agent: Sinh mã Manim và render video (hỗ trợ cả 2D và 3D).

Triển khai

Space này chạy Docker container chứa FastAPI và môi trường Manim. Để chạy cục bộ, tham khảo setup.sh.env.example.

Kiểm thử (pytest)

  • Nhanh (mặc định): từ thư mục backend, cài pip install -r requirements.txt, rồi PYTHONPATH=. python -m pytest tests/. Các marker real_api, real_agents, slow, v.v. bị loại theo pytest.ini để không cần server hay API key.
  • CI API (mock video + eager Celery): chmod +x scripts/run_real_integration.sh && ./scripts/run_real_integration.sh ci — khởi động API, chạy smoke + full suite, ghi integration_report.mdtemp_suite_results.json.
  • Tích hợp thật (worker / Manim / OpenRouter): ./scripts/run_real_integration.sh real với backend + worker đang chạy (Redis, .env đầy đủ). Bật từng phần bằng RUN_REAL_WORKER_OCR=1, RUN_REAL_WORKER_MANIM=1 (cần MOCK_VIDEO=false). Đặt TEST_SUPABASE_USER_ID trong .env cho user Supabase hợp lệ (xem .env.example).