Streamlined, modular, multi-source YOLO training & detection pipeline for research.
Project description
YOLO4r
You Only Look Once For Research
An open-source, automated animal-behavior detection pipeline.
Overview
YOLO4r (1.1.17) is a research-oriented, Ultralytics-based pipeline designed to make custom deep-learning model training & behavioral detection accessible to field & laboratory researchers.
YOLO4r supports:
- Multi-source real-time inference (video & live camera feeds).
- Structured logging of detections, interactions, & per-frame aggregate statistics.
- Automatic metadata extraction for precise timestamping for video & camera sources.
- Full configurability & modular design for research reproducibility.
This project remains open-source & under active development as part of an undergraduate research initiative. Contributions & feedback are always welcome!
Features
Model Training
- Supports transfer learning or training from scratch of an existing model.
- Automatically exports training metrics to:
Weights & Biases(W&B)quick-summary.txt(local lightweight summary)
- Supports aggressive data augmentation & auto-detection of new data for retraining.
Detection Pipeline
- Multi-threaded inference across multiple sources (camera feeds & videos).
- Metadata-aware timestamping for accurate frame-aligned measurements.
- Centralized message handling using
Printerfor all info, warnings, errors, & save confirmations. - Robust exception handling for model initialization, frame errors, & I/O failures.
Classes & Configuration
- YOLO4r uses user-defined class configurations:
FOCUS_CLASSES: primary subjects (e.g., animal species)CONTEXT_CLASSES: contextual or environmental elements (e.g., feeders, water trays, etc)
- Class lists are stored in & managed through
classes_config.yamlwithin the config folder, allowing for easy modification without editing code.
Here is an example of the a classes config YAML file:
FOCUS_CLASSES:
- F
- M
- Feeder
- Main_Perch
- Nesting_Box
- Sky_Perch
- Wooden_Perch
CONTEXT_CLASSES: []
A model's class list is extracted straight from its model.pt file to prepare a class_config.yaml file, which will be located in the /configs/<model_name> path.
This allows for a class list to be divided between focus & context classes that simplifies output statistics & terminal logs.
This class setup is intended to set specific classes as objects for focus classes to interact with, giving context to those interactions primarily.
Please ensure that the [] are removed if defining context classes!
Measurement System
- Data collection centralized in single helper utility that handles:
- Frame-level counts
- Interval-level aggregation
- Session summaries
- Interaction tracking (focus vs. context classes)
- Exports structured
.csvsummaries:counts.csv,average_counts.csvinterval_results.csv,session_summary.csvinteractions.csvSupports automatic calculation of ratios (e.g., M:F) & normalized detection rates.
Directory and Output Structure
Integrates a clean, timestamped log structure for both camera feeds & videos:
Camera sources:
/YOLO4r/logs/(model_name)/measurements/camera-feed/(source_name)/(system_timestamp)/measurements/
├── recordings/
│ └── usb0.mp4
└── scores/
├── source_metadata.json
├── frame-data/
│ ├── interval_results.csv
│ └── session_summary.csv
├── counts/
│ ├── counts.csv
│ └── average_counts.csv
└── interactions/
└── interactions.csv
Video sources:
/YOLO4r/logs/(model_name)/measurements/video-in/(source_name)/(video_timestamp)/measurements/
├── recordings/
│ └── video.mp4
└── scores/
├── source_metadata.json
├── frame-data/
│ ├── interval_results.csv
│ └── session_summary.csv
├── counts/
│ ├── counts.csv
│ └── average_counts.csv
└── interactions/
└── interactions.csv
- Folder names are automatically sanitized to avoid filesystem errors.
- Each source has its own isolated measurement subdirectory.
Terminal UI
Note that YOLO4r is a headless detection pipeline, meaning that live display windows will not appear while running inference. Instead, the terminal logs & tracks initiation, FPS, & basic statistics.
Here is an example of what to expect from the terminal:
YOLO4r Detection
----------------
[MODEL] Model
[video1] Frames:-- | FPS:-- | Time:-- | ETA:--
class1:-
class2:-
OBJECTS:-
[usb0] Frames:-- | FPS:-- | Time:--
class1:-
class2:-
OBJECTS:-
------------------------------------------------------------------------------------------------
[MODEL] Model
[INFO] 3 models found in runs folder:
[INFO] Loaded 6 classes: ['class1', 'class2', 'class3', 'class4', 'class5', 'class6'
[INFO] Recording initialized at 11/26/2025 23:19:28
[INFO] Source 'video1' completed.
[INFO] Source 'usb0' completed.
------------------------------------------------------------------------------------------------
[MODEL] Model
[SAVE] Measurements for video1:
[SAVE] Measurements saved to: "measurements/video-in/video1/mm-dd-yyyy_hh-mm-ss/scores"
- video1.mp4
- video1_metadata.json
- counts.csv
- average_counts.csv
- interval_results.csv
- session_summary.csv
- interactions.csv
[SAVE] Measurements for usb0:
[SAVE] Measurements saved to: "measurements/camera-feeds/usb0/mm-dd-yyyy_hh-mm-ss/scores"
- usb0.mp4
- usb0_metadata.json
- counts.csv
- average_counts.csv
- interval_results.csv
- session_summary.csv
- interactions.csv
[EXIT] All detection threads safely terminated.
Default example model trained on 7 classes:
M(Male Passer domesticus)F(Female Passer domesticus)FeederMain_PerchWooden_PerchSky_PerchNesting_Box
The model was trained using this pipeline & has been used for primary testing purposes.
The purpose of this model in particular is use for tracking & logging basic behavioral attributes of captive Passer domesticus subjects influenced by various intestinal microbial communities over an individual's development.
To be clear, the model is still in development & included for users to demonstrate a custom model trained through the pipeline.
Installation
1. Install MiniConda or Conda:
https://www.anaconda.com/docs/getting-started/miniconda/main
https://www.anaconda.com/download
2. Create & activate environment using:
conda create -n YOLO4r python=3.10
conda activate YOLO4r
3. Install the package:
pip install yolo4r
Prerequisites
- Must use
Python 3.10or older. - Keep in mind, training & detection require entirely separate system requirements.
- A computer with a relatively powerful CPU or has a GPU with
CUDA enabledis required.
Execution
Initiate Training
- Transfer-learning by default:
yolo4r train
Option to specify weights from either OBB or standard YOLO model:
yolo4r train model=(yolo11n, yolo11l-obb, yolov8m, etc.)
This will default to using YOLO11n.pt if not specified.
Option to name the model:
yolo4r train name="my awesome run!!"
Option to specify dataset within data folder.
yolo4r train data="my awesome dataset!!
This will default to the most recent dataset within the /data folder.
- Train a model only from custom dataset:
Option to specify weights from either OBB or standard YOLO model.
yolo4r train architecture=(yolo11, yolo12, yolov8-obb, etc.)
This will default to YOLO11.yaml if not specified.
- Designed to allow users to debug training operation:
yolo4r train test
- Process Label-Studio export folders:
yolo4r train labelstudio="my awesome export!!"
NOTE: Many of these commands can be set together, so here are a few examples:
yolo4r train labelstudio=geckos model=yolo11m architecture=customgeckomodel
yolo4r train data=geckos model=yolo12 test
Initiate Detection
- Defaults to mostly recently trained model & initiates usb0:
yolo4r detect
- Initiate multiple sources in parallel:
yolo4r detect usb0 usb1 "video1.type" "video2.type"
- Run inference using an official YOLO model or custom model:
yolo4r detect model=(yolo11, yolo12, yolov8-obb, etc.)
- Designed to allow users to route to debug model:
yolo4r detect test
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file yolo4r-1.1.17.tar.gz.
File metadata
- Download URL: yolo4r-1.1.17.tar.gz
- Upload date:
- Size: 28.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2d227ef8340ff51f94ad879ffceda9d46c420a330dedbc5b1293813bc4ebc079
|
|
| MD5 |
24b4359c735d1f0a5a64028faf58c230
|
|
| BLAKE2b-256 |
90a08a55a01c2aa9921450a030a04fc3218afd852b67295b738e023f00a163e3
|
File details
Details for the file yolo4r-1.1.17-py3-none-any.whl.
File metadata
- Download URL: yolo4r-1.1.17-py3-none-any.whl
- Upload date:
- Size: 28.4 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
924315280d67945d54cfc96b0541d46b8c2b2a1690cfa912c15d2b295107aae3
|
|
| MD5 |
5d1e6fe58c8ef5a8f526b3bd2f2dba2e
|
|
| BLAKE2b-256 |
43950377cdc89118a3cc20bae82eb7e85c3ea3964e1a4c4b56db6bd6e970fd92
|