Motion Detection¶
Class: MotionDetectionBlockV1
Source: inference.core.workflows.core_steps.classical_cv.motion_detection.v1.MotionDetectionBlockV1
Detect motion in video streams using OpenCV's background subtraction algorithm.
How This Block Works¶
This block uses background subtraction (specifically the MOG2 algorithm) to detect motion in video frames. The block maintains state across frames to build a background model and track motion patterns:
- Initializes background model - on the first frame, creates a background subtractor using the specified history and threshold parameters
- Processes each frame - applies background subtraction to identify pixels that differ from the learned background model
- Filters noise - applies morphological operations to remove noise and combine nearby motion regions into coherent contours
- Extracts motion regions - finds contours representing motion areas, filters them by minimum size, and optionally clips them to a detection zone
- Simplifies contours - reduces contour complexity to keep detection data manageable
- Generates outputs - creates object detection predictions with bounding boxes, determines motion status, triggers alarms when motion starts, and provides motion zone polygons
The block tracks motion state across frames - the alarm output becomes true only when motion transitions from not detected to detected, making it useful for triggering actions when motion first appears.
Common Use Cases¶
- Security Monitoring: Detect motion in surveillance cameras to trigger alerts, recordings, or notifications when activity is detected
- Resource Optimization: Conditionally run expensive inference operations (e.g., object detection, classification) only when motion is detected to save computational resources
- Activity Detection: Monitor areas for movement to track occupancy, identify entry/exit events, or detect unauthorized access
- Video Analytics: Analyze video streams to identify motion patterns, track activity levels, or detect anomalies in monitored areas
- Smart Recording: Trigger video recording or snapshot capture when motion is detected, reducing storage requirements compared to continuous recording
- Zone Monitoring: Monitor specific areas within a frame using detection zones to focus motion detection on relevant regions while ignoring busy but irrelevant areas
Connecting to Other Blocks¶
The motion detection outputs from this block can be connected to:
- Conditional logic blocks (e.g., Continue If) to execute workflow steps only when motion is detected or when alarms trigger
- Object detection blocks to run detection models only on frames with motion, saving computational resources
- Notification blocks (e.g., Email Notification, Slack Notification) to send alerts when motion is detected or alarms trigger
- Data storage blocks (e.g., Roboflow Dataset Upload, CSV Formatter) to log motion events, timestamps, and detection data for analytics
- Visualization blocks to draw motion zones, bounding boxes, or annotations on frames showing detected motion
- Filter blocks to filter images or data based on motion status before passing to downstream processing
Type identifier¶
Use the following identifier in step "type" field: roboflow_core/motion_detection@v1to add the block as
as step in your workflow.
Properties¶
| Name | Type | Description | Refs |
|---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
minimum_contour_area |
int |
Minimum area in square pixels for a motion region to be detected. Contours smaller than this threshold are filtered out to ignore noise, small shadows, or minor pixel variations. Lower values increase sensitivity but may detect more false positives (e.g., 100 for very sensitive detection, 500 for only large objects). Default is 200 square pixels.. | ✅ |
morphological_kernel_size |
int |
Size of the morphological kernel in pixels used to combine nearby motion regions and filter noise. Larger values merge more distant motion regions into single contours but may also merge separate objects. Smaller values preserve more detail but may leave fragmented detections. The kernel uses an elliptical shape. Default is 3 pixels.. | ✅ |
threshold |
int |
Threshold value for the squared Mahalanobis distance used by the MOG2 background subtraction algorithm. Controls sensitivity to motion - smaller values increase sensitivity (detect smaller changes) but may produce more false positives, larger values decrease sensitivity (only detect significant changes) but may miss subtle motion. Recommended range is 8-32. Default is 16.. | ✅ |
history |
int |
Number of previous frames used to build the background model. Controls how quickly the background adapts to changes - larger values (e.g., 50-100) create a more stable background model that's less sensitive to temporary changes but adapts slowly to permanent background changes. Smaller values (e.g., 10-20) allow faster adaptation but may treat moving objects as background if they stop moving. Default is 30 frames.. | ✅ |
detection_zone |
Union[List[Any], str] |
Optional polygon zone to limit motion detection to a specific area of the frame. Motion is only detected within this zone, ignoring activity outside. Format: [[x1, y1], [x2, y2], [x3, y3], ...] where coordinates are in pixels. The polygon must have more than 3 points. Can be provided as a list, JSON string, or selector referencing zone outputs from other blocks. Useful for focusing on specific regions (e.g., doorways, windows, restricted areas) while ignoring busy but irrelevant areas. If not provided, motion is detected across the entire frame.. | ✅ |
suppress_first_detections |
bool |
If true, suppresses motion detections until the background model has been initialized with enough frames (specified by the history parameter). This prevents false positives from early frames where the background model hasn't learned the scene yet. When false, the block attempts to detect motion immediately, which may produce unreliable results during initialization. Default is true (recommended for most use cases).. | ✅ |
The Refs column marks possibility to parametrise the property with dynamic values available
in workflow runtime. See Bindings for more info.
Runtime compatibility¶
-
soft— runtimehosted_serverless,dedicated_deployment; executionremote; inputvideo - Block keeps per-video state in process memory (keyed by video_metadata.video_identifier). With remote step execution on stateless or multi-replica HTTP runtimes, successive requests may be served by different worker processes, so the state resets between calls and the output is meaningless for tracking / counting / aggregation. Use local step execution in an InferencePipeline for stable cross-frame results.
-
soft— inputimage - Block depends on temporal context from video or repeated-frame workflows. With a still image/photo, there is no meaningful history to track, compare, aggregate, or visualize, so the block provides little or no benefit.
Available Connections¶
Compatible Blocks
Check what blocks you can connect to Motion Detection in version v1.
- inputs:
Size Measurement,Circle Visualization,MoonshotAI Kimi,Roboflow Asset Library Attributes,Twilio SMS Notification,Image Blur,S3 Sink,Email Notification,Reference Path Visualization,Camera Focus,SIFT Comparison,PTZ Tracking (ONVIF),Event Writer,Identify Changes,Slack Notification,Halo Visualization,VLM As Classifier,Image Stack,Clip Comparison,Google Gemma,Qwen 3.6 API,Dot Visualization,Image Slicer,Label Visualization,Background Color Visualization,Llama 3.2 Vision,Email Notification,Pixelate Visualization,Heatmap Visualization,Google Gemini,JSON Parser,Anthropic Claude,Google Gemma API,Stitch Images,Identify Outliers,Morphological Transformation,OpenAI,Blur Visualization,Trace Visualization,Detection Event Log,Llama 3.2 Vision,Clip Comparison,Camera Focus,Detections List Roll-Up,Florence-2 Model,Google Gemini,OpenAI,Corner Visualization,OpenRouter,PLC ModbusTCP,Pixel Color Count,Model Comparison Visualization,Buffer,MQTT Writer,SIFT Comparison,Webhook Sink,Model Monitoring Inference Aggregator,Image Threshold,Image Contours,Motion Detection,Local File Sink,Google Gemini,MoonshotAI Kimi,Polygon Visualization,Polygon Visualization,SIFT,Dimension Collapse,Stability AI Image Generation,Classification Label Visualization,Line Counter Visualization,Line Counter,Relative Static Crop,Grid Visualization,Image Preprocessing,Keypoint Visualization,Template Matching,Anthropic Claude,OPC UA Writer Sink,Icon Visualization,Color Visualization,Dynamic Zone,Triangle Visualization,QR Code Generator,Contrast Enhancement,Qwen 3.5 API,Absolute Static Crop,Dynamic Crop,Stability AI Inpainting,Background Subtraction,Roboflow Dataset Upload,Bounding Box Visualization,Polygon Zone Visualization,Stability AI Outpainting,Crop Visualization,Image Convert Grayscale,OpenAI,Mask Visualization,Halo Visualization,Image Slicer,Distance Measurement,Qwen-VL,Florence-2 Model,Perspective Correction,PLC EthernetIP,Twilio SMS/MMS Notification,Text Display,Morphological Transformation,Anthropic Claude,Roboflow Vision Events,Microsoft SQL Server Sink,VLM As Classifier,Roboflow Dataset Upload,VLM As Detector,Depth Estimation,Detections Consensus,Roboflow Custom Metadata,Contrast Equalization,Camera Calibration,Ellipse Visualization,VLM As Detector,Line Counter - outputs:
Cache Set,Roboflow Asset Library Attributes,MoonshotAI Kimi,Path Deviation,Overlap Filter,Reference Path Visualization,PTZ Tracking (ONVIF),Event Writer,Slack Notification,SAM2 Video Tracker,Halo Visualization,VLM As Classifier,Image Stack,Clip Comparison,Qwen 3.6 API,Google Gemma,Object Detection Model,Dot Visualization,Label Visualization,Background Color Visualization,Llama 3.2 Vision,Email Notification,SAM 3 Interactive,Velocity,Pixelate Visualization,Google Gemini,Track Class Lock,Anthropic Claude,OpenAI,Trace Visualization,Llama 3.2 Vision,Detection Event Log,ByteTrack Tracker,Clip Comparison,Camera Focus,OpenAI,Buffer,MQTT Writer,Webhook Sink,SIFT Comparison,Motion Detection,Google Gemini,MoonshotAI Kimi,Polygon Visualization,Classification Label Visualization,Multi-Label Classification Model,Instance Segmentation Model,Keypoint Detection Model,Keypoint Visualization,Template Matching,Instance Segmentation Model,Icon Visualization,Seg Preview,Dynamic Crop,Stability AI Inpainting,BoT-SORT Tracker,Bounding Box Visualization,Multi-Label Classification Model,Polygon Zone Visualization,Crop Visualization,Detections Transformation,Byte Tracker,Mask Visualization,Halo Visualization,Detections Stitch,Distance Measurement,Detection Offset,SORT Tracker,PLC EthernetIP,Text Display,Anthropic Claude,Line Counter,VLM As Classifier,Overlap Analysis,Roboflow Dataset Upload,VLM As Detector,Detections Consensus,Object Detection Model,Detections Filter,Ellipse Visualization,Detections Merge,Keypoint Detection Model,SAM3 Video Tracker,Time in Zone,SAM 3,Size Measurement,Circle Visualization,Twilio SMS Notification,Path Deviation,Email Notification,Single-Label Classification Model,Byte Tracker,SAM 3,LMM For Classification,Mask Area Measurement,Heatmap Visualization,Google Gemma API,Time in Zone,Single-Label Classification Model,YOLO-World Model,Blur Visualization,Stitch OCR Detections,Detections List Roll-Up,Florence-2 Model,Google Gemini,Corner Visualization,OpenRouter,Detections Stabilizer,Model Comparison Visualization,SAM 3,Model Monitoring Inference Aggregator,Byte Tracker,Instance Segmentation Model,Single-Label Classification Model,Polygon Visualization,Segment Anything 2 Model,Time in Zone,Line Counter Visualization,Line Counter,Per-Class Confidence Filter,Grid Visualization,Gaze Detection,Stitch OCR Detections,Anthropic Claude,OPC UA Writer Sink,Color Visualization,Dynamic Zone,Detections Combine,Triangle Visualization,Roboflow Dataset Upload,Qwen 3.5 API,Multi-Label Classification Model,OC-SORT Tracker,OpenAI,Qwen-VL,Florence-2 Model,Perspective Correction,Roboflow Vision Events,Twilio SMS/MMS Notification,Microsoft SQL Server Sink,Instance Segmentation Model,Roboflow Custom Metadata,Camera Calibration,Detections Classes Replacement,VLM As Detector,Keypoint Detection Model,Object Detection Model
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
Motion Detection in version v1 has.
Bindings
-
input
image(image): The input image or video frame to analyze for motion. The block processes frames sequentially to build a background model - each frame updates the background model and detects motion relative to learned background patterns. Can be connected from workflow inputs or previous steps..minimum_contour_area(integer): Minimum area in square pixels for a motion region to be detected. Contours smaller than this threshold are filtered out to ignore noise, small shadows, or minor pixel variations. Lower values increase sensitivity but may detect more false positives (e.g., 100 for very sensitive detection, 500 for only large objects). Default is 200 square pixels..morphological_kernel_size(integer): Size of the morphological kernel in pixels used to combine nearby motion regions and filter noise. Larger values merge more distant motion regions into single contours but may also merge separate objects. Smaller values preserve more detail but may leave fragmented detections. The kernel uses an elliptical shape. Default is 3 pixels..threshold(integer): Threshold value for the squared Mahalanobis distance used by the MOG2 background subtraction algorithm. Controls sensitivity to motion - smaller values increase sensitivity (detect smaller changes) but may produce more false positives, larger values decrease sensitivity (only detect significant changes) but may miss subtle motion. Recommended range is 8-32. Default is 16..history(integer): Number of previous frames used to build the background model. Controls how quickly the background adapts to changes - larger values (e.g., 50-100) create a more stable background model that's less sensitive to temporary changes but adapts slowly to permanent background changes. Smaller values (e.g., 10-20) allow faster adaptation but may treat moving objects as background if they stop moving. Default is 30 frames..detection_zone(Union[zone,list_of_values]): Optional polygon zone to limit motion detection to a specific area of the frame. Motion is only detected within this zone, ignoring activity outside. Format: [[x1, y1], [x2, y2], [x3, y3], ...] where coordinates are in pixels. The polygon must have more than 3 points. Can be provided as a list, JSON string, or selector referencing zone outputs from other blocks. Useful for focusing on specific regions (e.g., doorways, windows, restricted areas) while ignoring busy but irrelevant areas. If not provided, motion is detected across the entire frame..suppress_first_detections(boolean): If true, suppresses motion detections until the background model has been initialized with enough frames (specified by the history parameter). This prevents false positives from early frames where the background model hasn't learned the scene yet. When false, the block attempts to detect motion immediately, which may produce unreliable results during initialization. Default is true (recommended for most use cases)..
-
output
motion(boolean): Boolean flag.alarm(boolean): Boolean flag.detections(object_detection_prediction): Prediction with detected bounding boxes in form of sv.Detections(...) object.motion_zones(list_of_values): List of values of any type.
Example JSON definition of step Motion Detection in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/motion_detection@v1",
"image": "$inputs.image",
"minimum_contour_area": 200,
"morphological_kernel_size": 3,
"threshold": 16,
"history": 30,
"detection_zone": "<block_does_not_provide_example>",
"suppress_first_detections": true
}