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@v1to 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:
Google Vision OCR,Detections Filter,Clip Comparison,SAM 3,Seg Preview,Byte Tracker,Overlap Filter,SAM 3,SIFT Comparison,Object Detection Model,Path Deviation,Qwen2.5-VL,Detections Combine,Email Notification,Anthropic Claude,Image Contours,Object Detection Model,Line Counter,Email Notification,Clip Comparison,Moondream2,VLM as Classifier,Model Monitoring Inference Aggregator,OCR Model,Path Deviation,LMM,Time in Zone,Roboflow Dataset Upload,Gaze Detection,Detections Consensus,OpenAI,SAM 3,VLM as Detector,Roboflow Custom Metadata,Florence-2 Model,CogVLM,Byte Tracker,Keypoint Detection Model,Buffer,Bounding Rectangle,Segment Anything 2 Model,Keypoint Detection Model,SIFT Comparison,Time in Zone,Line Counter,JSON Parser,YOLO-World Model,PTZ Tracking (ONVIF).md),Detection Offset,Detections Classes Replacement,Detections Transformation,Identify Changes,Template Matching,Roboflow Dataset Upload,Anthropic Claude,Florence-2 Model,Distance Measurement,Google Gemini,Google Gemini,EasyOCR,VLM as Detector,SmolVLM2,Size Measurement,Identify Outliers,Dynamic Zone,Time in Zone,Twilio SMS Notification,Detections Stitch,Llama 3.2 Vision,Dimension Collapse,Velocity,Slack Notification,Byte Tracker,Local File Sink,OpenAI,Instance Segmentation Model,OpenAI,Dynamic Crop,Pixel Color Count,Detections Stabilizer,Webhook Sink,Instance Segmentation Model,VLM as Classifier,Perspective Correction,Detections Merge,OpenAI - outputs:
Label Visualization,Blur Visualization,Background Color Visualization,Keypoint Visualization,Bounding Box Visualization,Detections Filter,Reference Path Visualization,Stability AI Outpainting,Image Slicer,Pixelate Visualization,Single-Label Classification Model,SAM 3,Byte Tracker,Overlap Filter,SAM 3,Color Visualization,SIFT Comparison,Object Detection Model,Path Deviation,Detections Combine,Email Notification,Stitch Images,Circle Visualization,Object Detection Model,Polygon Zone Visualization,Line Counter,Ellipse Visualization,Email Notification,Model Monitoring Inference Aggregator,Path Deviation,Time in Zone,Roboflow Dataset Upload,Gaze Detection,Detections Consensus,Crop Visualization,Florence-2 Model,Roboflow Custom Metadata,Multi-Label Classification Model,Classification Label Visualization,Byte Tracker,Stitch OCR Detections,Keypoint Detection Model,Bounding Rectangle,Segment Anything 2 Model,Keypoint Detection Model,Time in Zone,Line Counter,Polygon Visualization,YOLO-World Model,PTZ Tracking (ONVIF).md),Detection Offset,Detections Classes Replacement,Icon Visualization,Detections Transformation,Identify Changes,Triangle Visualization,Template Matching,Roboflow Dataset Upload,Model Comparison Visualization,Corner Visualization,Distance Measurement,Florence-2 Model,Line Counter Visualization,Halo Visualization,Size Measurement,Stability AI Image Generation,Identify Outliers,Dynamic Zone,Time in Zone,Twilio SMS Notification,Dot Visualization,Relative Static Crop,Detections Stitch,Velocity,Slack Notification,Byte Tracker,Instance Segmentation Model,Multi-Label Classification Model,Image Slicer,Stability AI Inpainting,Dynamic Crop,Single-Label Classification Model,Detections Stabilizer,Webhook Sink,Instance Segmentation Model,Detections Merge,Perspective Correction,Mask Visualization,Trace Visualization
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[instance_segmentation_prediction,object_detection_prediction,keypoint_detection_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_predictionor Prediction with detected bounding boxes and segmentation masks in form of sv.Detections(...) object ifinstance_segmentation_prediction.object_present(Union[boolean,dictionary]): Boolean flag ifbooleanor Dictionary ifdictionary.presence_confidence(Union[float_zero_to_one,dictionary]):floatvalue in range[0.0, 1.0]iffloat_zero_to_oneor 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"
}