NVR with realtime local object detection for IP cameras
Go to file
Vinnie Esposito 6a277620ca fix(face_recognition): feed BGR (not RGB) to FaceDetectorYN in manual detection branch
Frigate's `requires_face_detection` branch in `FaceRealTimeProcessor.process_frame`
converts the YUV camera frame to RGB and passes it to `cv2.FaceDetectorYN`.
YuNet is trained on BGR — feeding it RGB silently degrades detection
confidence by ~10× on typical person crops, causing face_recognition to
emit no `sub_label` and produce no `train/` entries. There is no log signal
because the detector simply returns 0 faces; from outside the box it looks
like nobody is walking past any camera.

The same file already does the YUV→BGR conversion correctly in the
else-branch (was line 271, now line 285) — only the manual-detection
branch was missed.

## Reproduction

Verified in-pod against the running Frigate's models on identical
person crops (snapshot pulled from a real person event):

    BGR (correct):  cv2.FaceDetectorYN ←  confidence 0.744 ✓
    RGB (current):  cv2.FaceDetectorYN ←  confidence 0.047 ✗

The `score_threshold=0.5` set on `FaceDetectorYN.create()` filters anything
under 0.5 at the detector layer, so the RGB-degraded crops never reach
the user-configurable `detection_threshold`. Result: silent outage.

## Fix

Three changes in `frigate/data_processing/real_time/face.py`:

1. `cv2.COLOR_YUV2RGB_I420` → `cv2.COLOR_YUV2BGR_I420`
2. Variable rename `rgb` → `bgr` to match
3. Remove the now-redundant `cv2.cvtColor(face_frame, cv2.COLOR_RGB2BGR)`
   block — `face_frame` is already BGR after the upstream conversion change

Net diff: +6 / -7. Pure Python, no new dependencies.

## How a deployment confirms the fix

After this change, walking past a camera produces:
- `data.attributes` with a `face` entry on the person event (currently empty)
- New entries in `/api/faces` `train/` array (currently frozen)
- `sub_label` populated on subsequent person events for trained faces

Signed-off-by: Vinnie Esposito <vespo21@gmail.com>
2026-05-05 18:39:49 -05:00
.cspell Full UI configuration (#22151) 2026-02-27 08:55:36 -07:00
.cursor/rules Implement Wizard for Creating Classification Models (#20622) 2025-10-23 13:27:28 -06:00
.devcontainer Initial implementation of D-FINE model via ONNX (#16772) 2025-02-24 08:56:01 -07:00
.github Miscellaneous fixes (#23053) 2026-04-30 17:19:53 -06:00
.vscode Settings UI tweaks (#22547) 2026-03-20 07:24:34 -06:00
config Improve the devcontainer experience (#3492) 2022-11-20 07:34:12 -06:00
docker ROCm Optimizations (#23118) 2026-05-05 16:33:43 -05:00
docs ROCm Optimizations (#23118) 2026-05-05 16:33:43 -05:00
frigate fix(face_recognition): feed BGR (not RGB) to FaceDetectorYN in manual detection branch 2026-05-05 18:39:49 -05:00
migrations Improve motion review and add motion search (#22253) 2026-03-05 17:53:48 -06:00
notebooks fix yolonas colab notebook (#22936) 2026-04-21 11:08:10 -06:00
testing-scripts add analyze keyframes testing script (#22994) 2026-04-24 11:42:30 -05:00
web Miscellaneous fixes (#23111) 2026-05-05 09:03:49 -06:00
.dockerignore Improve the devcontainer experience (#3492) 2022-11-20 07:34:12 -06:00
.gitignore docs: add docker compose generator (#22956) 2026-05-03 13:56:51 -05:00
.pylintrc use fstr log style 2021-02-25 07:01:59 -06:00
audio-labelmap.txt Audio events (#6848) 2023-07-01 08:18:33 -05:00
CODEOWNERS Initial support for Hailo-8L (#12431) 2024-08-29 20:19:50 -06:00
CONTRIBUTING.md Miscellaneous fixes (#23082) 2026-05-01 11:25:26 -06:00
cspell.json Work through most of the cspell warnings in python (#13794) 2024-09-17 10:41:46 -05:00
docker-compose.yml Use Frigate amd64 cache image for devcontainer build (#22888) 2026-04-15 08:37:23 -06:00
generate_config_translations.py Settings i18n improvements (#22571) 2026-03-22 13:03:24 -05:00
labelmap.txt Cleanup Detector labelmap (#4932) 2023-01-06 07:03:16 -06:00
LICENSE llc to inc and 2025 to 2026 (#21484) 2026-01-01 09:56:09 -06:00
Makefile Birdseye fixes (#22166) 2026-02-27 20:02:46 -07:00
netlify.toml Docs improvements (#8641) 2023-11-18 08:04:43 -06:00
package-lock.json Implement support for notifications (#12523) 2024-08-29 20:19:50 -06:00
pyproject.toml Fix various typing issues (#18187) 2025-05-13 08:27:20 -06:00
README_CN.md llc to inc and 2025 to 2026 (#21484) 2026-01-01 09:56:09 -06:00
README.md docs: fix alt text and capitalization in documentation (#21551) 2026-01-07 07:22:05 -07:00
TRADEMARK.md llc to inc and 2025 to 2026 (#21484) 2026-01-01 09:56:09 -06:00

logo

Frigate NVR™ - Realtime Object Detection for IP Cameras

License: MIT

Translation status
English

A complete and local NVR designed for Home Assistant with AI object detection. Uses OpenCV and Tensorflow to perform realtime object detection locally for IP cameras.

Use of a GPU or AI accelerator is highly recommended. AI accelerators will outperform even the best CPUs with very little overhead. See Frigate's supported object detectors.

  • Tight integration with Home Assistant via a custom component
  • Designed to minimize resource use and maximize performance by only looking for objects when and where it is necessary
  • Leverages multiprocessing heavily with an emphasis on realtime over processing every frame
  • Uses a very low overhead motion detection to determine where to run object detection
  • Object detection with TensorFlow runs in separate processes for maximum FPS
  • Communicates over MQTT for easy integration into other systems
  • Records video with retention settings based on detected objects
  • 24/7 recording
  • Re-streaming via RTSP to reduce the number of connections to your camera
  • WebRTC & MSE support for low-latency live view

Documentation

View the documentation at https://docs.frigate.video

Donations

If you would like to make a donation to support development, please use Github Sponsors.

License

This project is licensed under the MIT License.

  • Code: The source code, configuration files, and documentation in this repository are available under the MIT License. You are free to use, modify, and distribute the code as long as you include the original copyright notice.
  • Trademarks: The "Frigate" name, the "Frigate NVR" brand, and the Frigate logo are trademarks of Frigate, Inc. and are not covered by the MIT License.

Please see our Trademark Policy for details on acceptable use of our brand assets.

Screenshots

Live dashboard

Live dashboard

Streamlined review workflow

Streamlined review workflow

Multi-camera scrubbing

Multi-camera scrubbing

Built-in mask and zone editor

Built-in mask and zone editor

Translations

We use Weblate to support language translations. Contributions are always welcome.

Translation status

Copyright © 2026 Frigate, Inc.