Detections Consensus¶
Class: DetectionsConsensusBlockV1
Source: inference.core.workflows.core_steps.fusion.detections_consensus.v1.DetectionsConsensusBlockV1
Combine detections from multiple detection-based models based on a majority vote strategy.
This block is useful if you have multiple specialized models that you want to consult to determine whether a certain object is present in an image.
See the table below to explore the values you can use to configure the consensus block.
Type identifier¶
Use the following identifier in step "type"
field: roboflow_core/detections_consensus@v1
to add the block as
as step in your workflow.
Properties¶
Name | Type | Description | Refs |
---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
required_votes |
int |
Required number of votes for single detection from different models to accept detection as output detection. | ✅ |
class_aware |
bool |
Flag to decide if merging detections is class-aware or only bounding boxes aware. | ✅ |
iou_threshold |
float |
IoU threshold to consider detections from different models as matching (increasing votes for region). | ✅ |
confidence |
float |
Confidence threshold for merged detections. | ✅ |
classes_to_consider |
List[str] |
Optional list of classes to consider in consensus procedure.. | ✅ |
required_objects |
Optional[Dict[str, int], int] |
If given, it holds the number of objects that must be present in merged results, to assume that object presence is reached. Can be selector to InferenceParameter , integer value or dictionary with mapping of class name into minimal number of merged detections of given class to assume consensus.. |
✅ |
presence_confidence_aggregation |
AggregationMode |
Mode dictating aggregation of confidence scores and classes both in case of object presence deduction procedure.. | ❌ |
detections_merge_confidence_aggregation |
AggregationMode |
Mode dictating aggregation of confidence scores and classes both in case of boxes consensus procedure. One of average , max , min . Default: average . While using for merging overlapping boxes, against classes - average equals to majority vote, max - for the class of detection with max confidence, min - for the class of detection with min confidence.. |
❌ |
detections_merge_coordinates_aggregation |
AggregationMode |
Mode dictating aggregation of bounding boxes. One of average , max , min . Default: average . average means taking mean from all boxes coordinates, min - taking smallest box, max - taking largest box. This mode is not used for masks aggregation.. |
❌ |
detections_merge_mask_aggregation |
MaskAggregationMode |
Mode dictating aggregation of masks. One of union , intersection , max , min . Default: union . union means taking union of all masks, intersection - taking intersection of all masks, max - taking largest mask, min - taking smallest mask.. |
❌ |
The Refs column marks possibility to parametrise the property with dynamic values available
in workflow
runtime. See Bindings for more info.
Available Connections¶
Compatible Blocks
Check what blocks you can connect to Detections Consensus
in version v1
.
- inputs:
Line Counter
,Keypoint Detection Model
,Gaze Detection
,OpenAI
,Distance Measurement
,Line Counter
,Roboflow Dataset Upload
,Template Matching
,Size Measurement
,SmolVLM2
,VLM as Classifier
,Detections Classes Replacement
,Instance Segmentation Model
,Instance Segmentation Model
,JSON Parser
,Email Notification
,Bounding Rectangle
,OpenAI
,Dynamic Zone
,Slack Notification
,VLM as Detector
,Twilio SMS Notification
,Byte Tracker
,Webhook Sink
,Qwen2.5-VL
,Google Vision OCR
,Buffer
,Velocity
,Identify Changes
,Model Monitoring Inference Aggregator
,Roboflow Custom Metadata
,Florence-2 Model
,VLM as Detector
,Anthropic Claude
,Detections Transformation
,Image Contours
,Dimension Collapse
,Florence-2 Model
,Clip Comparison
,Detections Merge
,Pixel Color Count
,Time in Zone
,Dynamic Crop
,Local File Sink
,Perspective Correction
,Byte Tracker
,Detections Filter
,SIFT Comparison
,CogVLM
,Path Deviation
,Object Detection Model
,Segment Anything 2 Model
,VLM as Classifier
,LMM
,OpenAI
,Byte Tracker
,Moondream2
,Detection Offset
,Detections Consensus
,Time in Zone
,Keypoint Detection Model
,Llama 3.2 Vision
,Detections Stabilizer
,Roboflow Dataset Upload
,Clip Comparison
,YOLO-World Model
,Overlap Filter
,Google Gemini
,PTZ Tracking (ONVIF)
.md),SIFT Comparison
,Detections Stitch
,Object Detection Model
,Path Deviation
,Identify Outliers
- outputs:
Line Counter
,Keypoint Detection Model
,Gaze Detection
,Halo Visualization
,Stability AI Image Generation
,Model Comparison Visualization
,Keypoint Visualization
,Crop Visualization
,Bounding Box Visualization
,Distance Measurement
,Line Counter
,Roboflow Dataset Upload
,Size Measurement
,Template Matching
,Mask Visualization
,Image Slicer
,Detections Classes Replacement
,Instance Segmentation Model
,Instance Segmentation Model
,Ellipse Visualization
,Email Notification
,Bounding Rectangle
,Dynamic Zone
,Slack Notification
,Twilio SMS Notification
,Byte Tracker
,Webhook Sink
,Label Visualization
,Stability AI Outpainting
,Single-Label Classification Model
,Polygon Visualization
,Velocity
,Identify Changes
,Model Monitoring Inference Aggregator
,Roboflow Custom Metadata
,Reference Path Visualization
,Florence-2 Model
,Detections Transformation
,Line Counter Visualization
,Florence-2 Model
,Single-Label Classification Model
,Corner Visualization
,Detections Merge
,Stitch Images
,Time in Zone
,Background Color Visualization
,Blur Visualization
,Image Slicer
,Dynamic Crop
,Perspective Correction
,Stitch OCR Detections
,Circle Visualization
,Triangle Visualization
,Byte Tracker
,Dot Visualization
,Detections Filter
,Path Deviation
,Multi-Label Classification Model
,Object Detection Model
,Segment Anything 2 Model
,Color Visualization
,Stability AI Inpainting
,Classification Label Visualization
,Byte Tracker
,Detection Offset
,Detections Consensus
,Time in Zone
,Keypoint Detection Model
,Pixelate Visualization
,Trace Visualization
,Detections Stabilizer
,Roboflow Dataset Upload
,YOLO-World Model
,Overlap Filter
,PTZ Tracking (ONVIF)
.md),SIFT Comparison
,Multi-Label Classification Model
,Relative Static Crop
,Detections Stitch
,Object Detection Model
,Path Deviation
,Polygon Zone Visualization
,Identify Outliers
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
Detections Consensus
in version v1
has.
Bindings
-
input
predictions_batches
(Union[object_detection_prediction
,keypoint_detection_prediction
,instance_segmentation_prediction
]): Reference to detection-like model predictions made against single image to agree on model consensus.required_votes
(integer
): Required number of votes for single detection from different models to accept detection as output detection.class_aware
(boolean
): Flag to decide if merging detections is class-aware or only bounding boxes aware.iou_threshold
(float_zero_to_one
): IoU threshold to consider detections from different models as matching (increasing votes for region).confidence
(float_zero_to_one
): Confidence threshold for merged detections.classes_to_consider
(list_of_values
): Optional list of classes to consider in consensus procedure..required_objects
(Union[dictionary
,integer
]): If given, it holds the number of objects that must be present in merged results, to assume that object presence is reached. Can be selector toInferenceParameter
, integer value or dictionary with mapping of class name into minimal number of merged detections of given class to assume consensus..
-
output
predictions
(Union[object_detection_prediction
,instance_segmentation_prediction
]): Prediction with detected bounding boxes in form of sv.Detections(...) object ifobject_detection_prediction
or Prediction with detected bounding boxes and segmentation masks in form of sv.Detections(...) object ifinstance_segmentation_prediction
.object_present
(Union[boolean
,dictionary
]): Boolean flag ifboolean
or Dictionary ifdictionary
.presence_confidence
(Union[float_zero_to_one
,dictionary
]):float
value in range[0.0, 1.0]
iffloat_zero_to_one
or Dictionary ifdictionary
.
Example JSON definition of step Detections Consensus
in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/detections_consensus@v1",
"predictions_batches": [
"$steps.a.predictions",
"$steps.b.predictions"
],
"required_votes": 2,
"class_aware": true,
"iou_threshold": 0.3,
"confidence": 0.1,
"classes_to_consider": [
"a",
"b"
],
"required_objects": 3,
"presence_confidence_aggregation": "max",
"detections_merge_confidence_aggregation": "min",
"detections_merge_coordinates_aggregation": "min",
"detections_merge_mask_aggregation": "union"
}