Skip to main content

Modular, production-grade face recognition system with swappable backends

Project description

FaceStack

A modular, production-ready face recognition system covering detection, alignment, recognition, tracking, attendance logging, cloud APIs, edge deployment, and a web dashboard.

Built as an educational project with 31 notebooks, but architected for real-world use.

Features

  • 3 face detectors: SCRFD, YuNet, MediaPipe — see MODEL_CHOICES.md for the curation rationale
  • 3 face recognizers: ArcFace, AdaFace, SFace
  • 3 aligners: Five-point, MediaPipe Mesh, InsightFace
  • Anti-spoofing: Liveness detection to prevent photo/video attacks
  • Multi-camera tracking: Centroid tracker with entry/exit zone logic
  • Attendance system: Automatic logging with cooldown, daily summaries, CSV/JSON/Excel export
  • 4 cloud backends: AWS Rekognition, Azure Face, Google Vision, Face++
  • Edge deployment: ONNX export, TensorRT optimization, Raspberry Pi and Jetson configs
  • Web dashboard: Streamlit app with live feed, enrollment, attendance, benchmark, and settings
  • CLI interface: Full-featured command-line tool

Quick Start

Option A — pip install (self-contained)

pip install "facestack[onnx]"

# Download models (writes to ./models/)
facestack-download-models

# Run with webcam (SCRFD + ArcFace by default)
facestack

# Run with custom backends
facestack --detector yunet --recognizer sface

# Launch web dashboard
facestack --dashboard          # or: facestack-dashboard

Option B — from a repo checkout (for contributors)

git clone https://github.com/fullstackcv/facestack.git
cd facestack
pip install -e ".[onnx]"

python scripts/download_models.py   # (thin shim — same as facestack-download-models)
python app.py                       # (thin shim — same as the `facestack` command)

Both options expose the same CLI. The app.py and scripts/*.py files at the repo root are kept as thin shims so notebook, blog, and Makefile references continue to work unchanged.

CLI Usage

# Live recognition
facestack                                           # Webcam, default backends
facestack --detector mediapipe --recognizer adaface # Custom combo
facestack --source video.mp4                        # Video file
facestack --source rtsp://camera:554/stream         # RTSP stream
facestack --anti-spoof                              # Enable liveness detection

# Enrollment
facestack --enroll --name "Alice" --images ./photos/alice/
facestack --enroll --name "Bob" --images ./photos/bob/ --employee-id EMP002

# Benchmark
facestack --benchmark --source test_video.mp4

# Export attendance
facestack --export --format csv --output attendance.csv
facestack --export --format json --date 2026-04-15

# Dashboard
facestack --dashboard

Web Dashboard

Launch with facestack --dashboard, facestack-dashboard, or streamlit run facestack/dashboard/app.py.

Page Description
Live Feed Real-time camera feed with face detection, recognition, and FPS
Enrollment Upload photos to register new people
Attendance View logs, daily summaries, hourly charts, export data
Benchmark Compare detector/recognizer combos on FPS and latency
Settings Configure backends, thresholds, device, anti-spoof

Architecture

facestack/
├── detection/          # 3 detector backends (SCRFD, YuNet, MediaPipe)
├── alignment/          # 3 aligner backends (Five-point, MediaPipe, InsightFace)
├── recognition/        # 3 recognizer backends (ArcFace, AdaFace, SFace)
├── tracking/           # Centroid tracker, cooldown, entry/exit zones
├── antispoof/          # Liveness detection
├── database/           # SQLAlchemy models, FAISS search, attendance, export
├── cloud/              # AWS, Azure, Google, Face++ backends + cost calculator
├── deploy/             # Raspberry Pi, Jetson Nano, laptop configs
├── utils/              # Video, drawing, benchmark, ONNX, TensorRT utilities
├── config.py           # Pydantic configuration
└── pipeline.py         # Main orchestrator: detect → align → recognize → track → log

Project Structure

facestack/
├── facestack/              # Core Python package (everything installable ships here)
│   ├── detection/          # Detector backends
│   ├── alignment/          # Aligner backends
│   ├── recognition/        # Recognizer backends
│   ├── tracking/
│   ├── antispoof/
│   ├── database/
│   ├── cloud/
│   ├── deploy/
│   ├── utils/
│   ├── dashboard/          # Streamlit dashboard (5 pages)
│   ├── scripts/            # CLI scripts (download_models, enroll, etc.)
│   ├── cli.py              # `facestack` console entry point
│   ├── config.py
│   └── pipeline.py
├── app.py                  # Thin shim → facestack.cli:main
├── scripts/                # Thin shims → facestack.scripts.*
├── dashboard/app.py        # Thin shim → facestack.dashboard.app (runpy)
├── notebooks/              # 31 educational Jupyter notebooks
├── tests/                  # Test suite
├── docker/                 # Dockerfile.laptop / .pi / .jetson + compose
├── models/                 # Model weights (gitignored, downloaded via script)
└── data/                   # Sample data

Pip-installed users get a self-contained package: the dashboard, scripts, and CLI all live inside facestack/ and are wired through console entry points. Repo users keep the familiar python app.py / python scripts/X.py UX via one-line shims.

Notebooks

31 notebooks covering the full journey from classical methods to production deployment:

# Topic Key Concepts
01-07 Detection Haar, HOG, SSD, MTCNN, RetinaFace, SCRFD, YuNet, benchmarks
08-10 Alignment Dlib landmarks, MediaPipe, alignment pipeline
11-13 Classical Recognition Eigenfaces, Fisherfaces, LBPH
14-19 Deep Recognition FaceNet, ArcFace, AdaFace, DeepFace, InsightFace, benchmarks
20-23 System Multi-camera tracking, anti-spoofing, attendance, entry/exit
24-27 Cloud APIs AWS Rekognition, Azure Face, Google Vision, Face++, cost analysis
28-30 Edge ONNX export, Raspberry Pi deployment, Jetson TensorRT
31 Integration Full app walkthrough, CLI, dashboard, packaging

Configuration

FaceStack uses Pydantic for validated configuration:

from facestack.config import FaceStackConfig

config = FaceStackConfig(
    detector="scrfd",
    recognizer="arcface",
    aligner="five_point",
    device="cpu",              # cpu, cuda, or tensorrt
    recognition_threshold=0.6,
    anti_spoof=True,
    cooldown_seconds=300,
    database_url="sqlite:///facestack.db",
)

Environment variables also work (prefix FACESTACK_):

export FACESTACK_DETECTOR=yunet
export FACESTACK_DEVICE=cuda

Docker Deployment

# Desktop / Laptop
docker build -f docker/Dockerfile.laptop -t facestack:laptop .
docker run --device /dev/video0 -p 8501:8501 facestack:laptop

# Raspberry Pi
docker build -f docker/Dockerfile.pi -t facestack:pi .

# Jetson (with TensorRT)
docker build -f docker/Dockerfile.jetson -t facestack:jetson .
docker run --runtime nvidia --device /dev/video0 facestack:jetson

# Full stack (app + db + dashboard)
docker compose -f docker/docker-compose.yml up

Cloud APIs

Provider Setup Cost (10K detect)
AWS Rekognition IAM user + AmazonRekognitionFullAccess ~$10
Azure Face Cognitive Services resource ~$10
Google Vision Vision API enabled + service account ~$15
Face++ API key from console.faceplusplus.com ~$0 (free tier)
# Cost analysis
facestack-cost-analysis            # or: python scripts/cost_analysis.py

Testing

# Run all tests
pytest tests/ -v

# Run specific test module
pytest tests/test_dashboard.py -v

# Run with coverage
pytest tests/ --cov=facestack --cov-report=term-missing

Requirements

  • Python 3.10+
  • OpenCV 4.8+
  • NumPy, Pydantic, SQLAlchemy
  • FAISS (for embedding search)
  • Streamlit (for dashboard)
  • Optional: ONNX Runtime, TensorRT, boto3, azure SDK, google-cloud-vision

License

MIT

Author

Vikas Gupta

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

facestack-0.0.6.tar.gz (118.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

facestack-0.0.6-py3-none-any.whl (131.4 kB view details)

Uploaded Python 3

File details

Details for the file facestack-0.0.6.tar.gz.

File metadata

  • Download URL: facestack-0.0.6.tar.gz
  • Upload date:
  • Size: 118.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for facestack-0.0.6.tar.gz
Algorithm Hash digest
SHA256 9fb9c9cf924e79a5fe07c31a86d5e7a6c161543796e7b3e731b3bcd86a9228d5
MD5 83f186b89ca2946f33e3b5d35771f4bb
BLAKE2b-256 c7acab08d71d2d3320b494d186e6e8ab5d78a88e875610a03a213209a450f544

See more details on using hashes here.

Provenance

The following attestation bundles were made for facestack-0.0.6.tar.gz:

Publisher: publish.yml on fullstackcv/facestack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file facestack-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: facestack-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 131.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for facestack-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 0d9c3053a9c3e70287225c4216deab6bd1823a64582437a10172f821cd2c92a6
MD5 2f138735168707d6b173beecd210d2ed
BLAKE2b-256 1823d874748201487a7986ce6ae6605678ad627c6630f7dbe7e234e67c27c549

See more details on using hashes here.

Provenance

The following attestation bundles were made for facestack-0.0.6-py3-none-any.whl:

Publisher: publish.yml on fullstackcv/facestack

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page