Skip to content
forked from PsyChip/machina

OpenCV+YOLO+LLAVA+FAISS powered video surveillance system

Notifications You must be signed in to change notification settings

sorokinvld/machina

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MACHINA

CCTV viewer with realtime object tagger [WIP]

partial screenshot

Uses

How it works

Simply it connects to a high-resolution RTSP stream in a separate thread, queues the frames into memory as it is and resamples it for processing.

YOLO takes this frame, application gives a specific id based on it's coordinates, size and timestamp then tries to match the same object on every iteration.

Another thread runs in background, iterates that object array continuously and makes LLM requests to Ollama server for object tagging

Object matching

It calculates the center of every detection box, pinpoint on screen and gives 16px tolerance on all directions. Script tries to find closest object as fallback and creates a new object in memory in last resort. You can observe persistent objects in /elements folder

Test Environment

Every input frame resampled to 640x480 for processing, got avg 20ms interference time with yolo 11 small model (yolo11s.pt) on Geforce GTX 1060 which is almost 7 years old graphics card. Other models available in "models" directory

Stream delays by 1-2 seconds on every 10~ minutes due to network conditions, script also have a frame skip mechanism on 3 seconds of detection idle.

Prerequisites

  • Install Python 3.12.x
  • Clone the repository
  • Install ollama server
  • Pull the LLAVA model by running ollama run llava
  • Pick a pytorch version that compatible with your hardware and install
  • Install the dependencies by running pip install -r requirements.txt
  • Open app.py and set your rtmp stream address at line 18
  • Run the script py app.py
git clone https://github.com/PsyChip/machina
cd machina
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
pip install -r requirements.txt
py app.py

Usage

  • S : snapshot, actual image from input stream
  • R : start/stop recording. it records what you see.
  • Q : quit app
  • left mouse: select
  • middle mouse: zoom
  • right mouse: pan

Project direction

This is a living project, trying to create a complete headless security system by taking advantage of open source object detection models on my spare time.

TODO

  • Additional UI Layer
  • RTS style object selection box and detailed information about selected object(s)
  • People crowd, car crash, police, ambulance, running human detection [request]
  • Webhook callbacks on new object/disappeared object/movement after long stay

Feel free to contribute with code, ideas or even maybe a little bit support via ko-fi or bitcoin. I'll prioritize the feature requests for every $10 donation

Created by PsyChip [email protected]

.eof

About

OpenCV+YOLO+LLAVA+FAISS powered video surveillance system

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%