| Screener (Live View) | Discord Notification (WebHook) | 
|   |   | 
Python Cat Detector ()
is a tool to detect the presence of my cat "Cookie" near her litterbox and alerts me to clean it.
Basically, the application grabs video frames from an IP camera RTSP stream, uses a neural network to identify a cat object, and play a message in a speaker.
All hardware and software used by pycatdetector (i.e. Camera, Linux Server and Speaker) can reach each other via my local WiFi network.
The software architecture is pretty simple as follows:
sequenceDiagram
    participant Camera
    participant Recorder
    participant Detector
    participant Encoder
    participant Screener
    participant Notifier
    participant Channel
    loop Read (RSTP)
      Camera->>Recorder: Image
    end
    loop Read (Queue)
      Recorder->>Detector: Image
    end
    loop Read (Queue)
      Detector->>Screener: Image
    end
    Detector->>Encoder: write(Video, Image)
    loop Read (Queue)
      Detector->>Notifier: Label/Score
    end
    Notifier->>Channel: notify(Label)
    This Python package has been tested and designed for:
- 
Hardware: - Depending on what you are doing 1-2 GB of RAM and a CPU with AVX2 support.
- An RTSP streaming device like the TP-Link Tapo C210 Camera
- (Optional) A discord webhook to be used as notification channel.
- (Optional) A compatible IoT device like Google Nest with HomeAssistant (see below).
 
- 
Software: - Ubuntu Linux 24.04 LTS
- Python 3.12 and several python libraries.
- PyCatDetector uses PyTorch with optionally NVIDIA CUDA GPU
- (Recommended) Docker and/or Docker Compose for headless run (no graphical features).
- (Optional) HomeAssistant endpoint for Text-To-Speach (TTS) service.
 
NOTICE: If your Linux is a Virtual Machine running on a Windows host you
need to disable Windows Security > Core Isolation > Memory Protection.
Check if your CPU (or vCPU) is supporting the AVX instruction set:
cat /proc/cpuinfo | grep -i avxSee more information on: 
https://pytorch.org/get-started/locally/#windows-verification
sudo apt install make
git clone "https://github.com/olafrv/pycatdetector.git"
cd pycatdetector
mv config.example.yaml config.yaml # edit manually afterwardsmake install         # install end user requirements
make check-config    # checks for YAML parsing errors
make run             # with python3 interpreter# If you don't have it (latest docker official version)
# https://github.com/docker/docker-install
curl -fsSL https://get.docker.com -o get-docker.sh; sh get-docker.sh
make docker.build    # build docker image with python requirements
make docker.run      # A) without compose, and removed after stopped
make docker.start    # B.1) with compose running in background as service
make docker.stop     # B.2) stop the composed container service
make docker.restart  # B.3) restart the composed container service
make docker.sh       # open bash in the container service
make docker.clean    # delete local docker images to save spacemake uninstall       # remove python requirements and disposable folders# Metadata and Requirements
make metadata             # show release METADATA file content
make install.dev          # install development requirements
make package.outdated     # check outdated python packages
# Binary build with Nuitka3
make build                # build binary with nuitka3
make clean                # delete local disposable files
make run.bin              # run ./dist/main.bin dynamically linked binary
# Profiling and Testing
make profile              # run python3 profiling over main.py
make profile.view         # check profiling results with snake
make test                 # run ./pycatdetector/tests/*
make test.coverage        # check call coverage during runtime
make test.coverage.report # check test coverage after runtime
# GitHub Release
# See Makefile for required GITHUB_* required variables
# Adjust METADATA file before running the following commands
# make github.* perform code formatting, build, test, push and release
make github.release       # create a new github package release- https://pypi.org/project/opencv-python/
- https://docs.opencv.org/4.6.0/d6/d00/tutorial_py_root.html
- https://docs.opencv.org/3.0-beta/doc/py_tutorials/py_gui/py_video_display/py_video_display.html
- https://answers.opencv.org/question/24714/skipping-frames-in-videocapture/
- https://docs.opencv.org/4.x/dd/d9e/classcv_1_1VideoWriter.html