Track Class Lock¶
Class: TrackClassLockBlockV1
Source: inference.core.workflows.core_steps.transformations.track_class_lock.v1.TrackClassLockBlockV1
Lock the class label of each tracked object by majority voting, eliminating class flicker in video workflows where a model alternates between similar classes for the same physical object.
How This Block Works¶
This block maintains per-track voting state, keyed by the video_identifier embedded in the image's video metadata:
- Pre-lock, every qualifying frame (confidence >= vote_confidence) counts as a vote for the predicted class. A class becomes locked once it collects min_votes votes AND leads the runner-up class by at least lead_margin votes.
- Post-lock, the locked class is written into every subsequent detection of that track. Reported confidence is the running mean of counted votes (clamped to 1.0).
- A locked class can only change after switch_after CONSECUTIVE qualifying frames of the same challenger class. Challenger evidence is streak-scoped: both the streak counter and its confidence sum reset whenever the streak breaks, and on a successful switch the new class's tallies are seeded from the streak values only, so reported confidence never exceeds 1.0.
- When a NEW tracker id appears where a locked track recently disappeared (within reattach_window frames, bounding box IoU >= reattach_iou), the new track inherits the lost track's lock and voting state. This makes locks survive tracker id switches caused by short detection gaps or occlusions. Only locked tracks are inherited, and a track still present in the current frame is never inherited. Set reattach_window to 0 to disable re-attachment.
- State for tracks unseen for state_ttl frames is purged.
Each detection is annotated with a boolean class_locked flag in detections.data.
Requirements¶
Detections must carry tracker_id (wire this block after a tracking block such as Byte Tracker). The image's video_metadata is used to maintain separate state per video stream.
Type identifier¶
Use the following identifier in step "type" field: roboflow_core/track_class_lock@v1to add the block as
as step in your workflow.
Properties¶
| Name | Type | Description | Refs |
|---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
min_votes |
int |
Cumulative qualifying votes a class needs before the initial lock is acquired. Higher values delay locking but make the initial decision more reliable.. | ✅ |
vote_confidence |
float |
Minimum prediction confidence for a frame to count, both for pre-lock votes and post-lock challenger streaks. Frames below this threshold are ignored.. | ✅ |
lead_margin |
int |
Number of votes by which the top class must lead the runner-up before locking. Prevents premature locks when two classes are contested.. | ✅ |
switch_after |
int |
Number of CONSECUTIVE qualifying frames of the same challenger class required to change an existing lock. Any interruption resets the streak. Minimum 1 (a value of 1 switches on a single contrary frame; use >= 2 to enforce a multi-frame streak).. | ✅ |
state_ttl |
int |
Number of frames after which state of unseen tracks is purged.. | ✅ |
reattach_window |
int |
When a NEW tracker id appears where a locked track disappeared within this many frames, the new track inherits the lost track's lock and votes. Bridges tracker id switches caused by short detection gaps. Set to 0 to disable re-attachment.. | ✅ |
reattach_iou |
float |
Minimum IoU between a new detection's bounding box and a recently lost locked track's last known bounding box for the lock to be inherited. Higher values require the object to reappear closer to where it vanished.. | ✅ |
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 Track Class Lock in version v1.
- inputs:
Image Slicer,Polygon Zone Visualization,Line Counter,Contrast Enhancement,Time in Zone,Stability AI Image Generation,Image Threshold,Line Counter Visualization,Trace Visualization,Path Deviation,Distance Measurement,Image Stack,Camera Calibration,QR Code Generator,Detection Offset,ByteTrack Tracker,Detection Event Log,Per-Class Confidence Filter,Icon Visualization,SIFT Comparison,Detections Transformation,Morphological Transformation,Color Visualization,Perspective Correction,Corner Visualization,Mask Area Measurement,Google Vision OCR,Detections Merge,Halo Visualization,Image Blur,Dynamic Zone,Detections Combine,Morphological Transformation,Keypoint Detection Model,Camera Focus,Halo Visualization,Stability AI Inpainting,PTZ Tracking (ONVIF),Object Detection Model,Classification Label Visualization,Bounding Rectangle,SAM2 Video Tracker,Grid Visualization,Background Color Visualization,Mask Visualization,Byte Tracker,Ellipse Visualization,Reference Path Visualization,Image Slicer,Label Visualization,Velocity,Text Display,Byte Tracker,SIFT Comparison,Identify Outliers,Dot Visualization,Polygon Visualization,Identify Changes,Crop Visualization,Dynamic Crop,Absolute Static Crop,Circle Visualization,Image Preprocessing,Detections Stitch,Path Deviation,Relative Static Crop,Camera Focus,Template Matching,BoT-SORT Tracker,SAM3 Video Tracker,Gaze Detection,Segment Anything 2 Model,VLM As Detector,OCR Model,Heatmap Visualization,Motion Detection,Detections Filter,Blur Visualization,Object Detection Model,Depth Estimation,Instance Segmentation Model,Stability AI Outpainting,YOLO-World Model,SAM 3 Interactive,Clip Comparison,Background Subtraction,Keypoint Visualization,Detections Consensus,Byte Tracker,Bounding Box Visualization,SAM 3,Stitch Images,Image Convert Grayscale,Instance Segmentation Model,Detections List Roll-Up,Contrast Equalization,Mask Edge Snap,Moondream2,VLM As Detector,Line Counter,Roboflow Visual Search,Triangle Visualization,EasyOCR,Overlap Filter,SAM 3,Time in Zone,Detections Classes Replacement,Instance Segmentation Model,Pixelate Visualization,Keypoint Detection Model,Detections Stabilizer,SORT Tracker,Instance Segmentation Model,SIFT,Track Class Lock,Object Detection Model,Time in Zone,Image Contours,Polygon Visualization,Keypoint Detection Model,Pixel Color Count,OC-SORT Tracker,SAM 3,Model Comparison Visualization,Seg Preview - outputs:
Line Counter,Time in Zone,Stitch OCR Detections,Trace Visualization,Path Deviation,Distance Measurement,Detection Offset,ByteTrack Tracker,Detection Event Log,Per-Class Confidence Filter,Icon Visualization,Detections Transformation,Color Visualization,Perspective Correction,Corner Visualization,Mask Area Measurement,Roboflow Custom Metadata,Detections Merge,Halo Visualization,Dynamic Zone,Detections Combine,Size Measurement,Roboflow Vision Events,Halo Visualization,PTZ Tracking (ONVIF),Stability AI Inpainting,Stitch OCR Detections,SAM2 Video Tracker,Bounding Rectangle,Event Writer,Background Color Visualization,Byte Tracker,Mask Visualization,Ellipse Visualization,Velocity,Label Visualization,Byte Tracker,Dot Visualization,Polygon Visualization,Crop Visualization,Path Deviation,Detections Stitch,Dynamic Crop,Circle Visualization,BoT-SORT Tracker,Model Monitoring Inference Aggregator,Camera Focus,Segment Anything 2 Model,Florence-2 Model,Heatmap Visualization,Detections Filter,Overlap Analysis,Blur Visualization,SAM 3 Interactive,Detections Consensus,Keypoint Visualization,Byte Tracker,Bounding Box Visualization,Florence-2 Model,Detections List Roll-Up,Mask Edge Snap,Line Counter,Triangle Visualization,Overlap Filter,Roboflow Dataset Upload,Time in Zone,Detections Classes Replacement,Pixelate Visualization,Detections Stabilizer,SORT Tracker,Roboflow Dataset Upload,Track Class Lock,Time in Zone,Polygon Visualization,OC-SORT Tracker,Model Comparison Visualization
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
Track Class Lock in version v1 has.
Bindings
-
input
image(image): Image with embedded video metadata. The video_metadata contains video_identifier used to maintain separate voting state for different videos..detections(Union[keypoint_detection_prediction,object_detection_prediction,rle_instance_segmentation_prediction,instance_segmentation_prediction]): Tracked predictions (object detection, instance segmentation, keypoint detection or RLE instance segmentation). Must include tracker_id information from a tracking block..min_votes(integer): Cumulative qualifying votes a class needs before the initial lock is acquired. Higher values delay locking but make the initial decision more reliable..vote_confidence(float_zero_to_one): Minimum prediction confidence for a frame to count, both for pre-lock votes and post-lock challenger streaks. Frames below this threshold are ignored..lead_margin(integer): Number of votes by which the top class must lead the runner-up before locking. Prevents premature locks when two classes are contested..switch_after(integer): Number of CONSECUTIVE qualifying frames of the same challenger class required to change an existing lock. Any interruption resets the streak. Minimum 1 (a value of 1 switches on a single contrary frame; use >= 2 to enforce a multi-frame streak)..state_ttl(integer): Number of frames after which state of unseen tracks is purged..reattach_window(integer): When a NEW tracker id appears where a locked track disappeared within this many frames, the new track inherits the lost track's lock and votes. Bridges tracker id switches caused by short detection gaps. Set to 0 to disable re-attachment..reattach_iou(float_zero_to_one): Minimum IoU between a new detection's bounding box and a recently lost locked track's last known bounding box for the lock to be inherited. Higher values require the object to reappear closer to where it vanished..
-
output
tracked_detections(Union[object_detection_prediction,instance_segmentation_prediction,keypoint_detection_prediction,rle_instance_segmentation_prediction]): Prediction with detected bounding boxes in form of sv.Detections(...) object ifobject_detection_predictionor Prediction with detected bounding boxes and segmentation masks in form of sv.Detections(...) object ifinstance_segmentation_predictionor Prediction with detected bounding boxes and detected keypoints in form of sv.Detections(...) object ifkeypoint_detection_predictionor Prediction with detected bounding boxes and RLE-encoded segmentation masks in form of sv.Detections(...) object ifrle_instance_segmentation_prediction.
Example JSON definition of step Track Class Lock in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/track_class_lock@v1",
"image": "<block_does_not_provide_example>",
"detections": "$steps.byte_tracker.tracked_detections",
"min_votes": 10,
"vote_confidence": 0.8,
"lead_margin": 3,
"switch_after": 15,
"state_ttl": 300,
"reattach_window": 30,
"reattach_iou": 0.3
}