Data Aggregator¶
Class: DataAggregatorBlockV1
Source: inference.core.workflows.core_steps.analytics.data_aggregator.v1.DataAggregatorBlockV1
Collect and process data from workflow steps over configurable time-based or run-based intervals to generate statistical summaries and analytics reports, supporting multiple aggregation operations (sum, average, max, min, count, distinct values, value counts) with optional UQL-based data transformations for comprehensive data stream analytics.
How This Block Works¶
This block collects and aggregates data from workflow steps over specified intervals to produce statistical summaries. Unlike most blocks that output data for every input, this block maintains internal state and outputs aggregated results only when the configured interval is reached. The block:
- Receives data inputs from other workflow steps (via
datafield mapping variable names to workflow step outputs) - Optionally applies UQL (Query Language) operations to transform the data before aggregation (e.g., extract class names from detections, calculate sequence lengths, filter or transform values) using
data_operationsfor each input variable - Accumulates data into internal aggregation states based on the specified
aggregation_modefor each variable - Tracks time elapsed or number of runs based on
interval_unit(seconds, minutes, hours, or runs) - Most of the time, returns empty outputs (terminating downstream processing) while collecting data internally
- When the interval threshold is reached (based on time elapsed or run count), computes and outputs aggregated statistics
- Flushes internal state after outputting aggregated results and starts collecting data for the next interval
- Produces output fields dynamically named as
{variable_name}_{aggregation_mode}(e.g.,predictions_avg,classes_distinct,count_values_counts)
The block supports multiple aggregation modes for numeric data (sum, avg, max, min, values_difference), counting operations (count, count_distinct), and value analysis (distinct, values_counts). For list-like data, operations automatically process each element (e.g., count adds list length, distinct adds each element to the distinct set). The interval can be time-based (useful for video streams where wall-clock time matters) or run-based (useful for video file processing where frame count matters more than elapsed time).
Common Use Cases¶
- Video Stream Analytics: Aggregate detection results over time intervals from live video streams (e.g., calculate average object counts per minute, track distinct classes seen per hour, compute min/max detection counts over 30-second windows), enabling real-time analytics and monitoring for continuous video processing workflows
- Batch Video Processing: Aggregate statistics across video frames using run-based intervals (e.g., calculate average detections per 100 frames, count distinct objects across 500-frame windows, sum total detections per batch), enabling meaningful analytics for pre-recorded video files where frame count matters more than elapsed time
- Time-Series Metrics Collection: Collect and summarize workflow metrics over time (e.g., aggregate detection counts, calculate average confidence scores, track distinct class occurrences, compute value distributions), enabling statistical analysis and reporting for production workflows
- Model Performance Analysis: Analyze model predictions across multiple inputs (e.g., calculate average prediction counts, track distinct predicted classes, compute min/max confidence scores, count occurrences of each class), enabling comprehensive model performance evaluation and insights
- Data Stream Summarization: Summarize high-frequency data streams into periodic reports (e.g., aggregate every 60 seconds of detections into summary statistics, compute hourly averages, generate per-run summaries), enabling efficient data reduction and analysis for high-volume workflows
- Multi-Model Comparison: Aggregate results from multiple models for comparison (e.g., compare average detection counts across models, track distinct classes per model, compute aggregate statistics for model ensembles), enabling comparative analytics across different inference pipelines
Connecting to Other Blocks¶
This block receives data from workflow steps and outputs aggregated statistics periodically:
- After detection or analysis blocks (e.g., Object Detection, Instance Segmentation, Classification) to aggregate prediction results over time or across frames, enabling statistical analysis of model outputs and detection patterns
- After data processing blocks (e.g., Expression, Property Definition, Detections Filter) that produce numeric or list outputs to aggregate computed values, metrics, or transformed data over intervals
- Before sink blocks (e.g., CSV Formatter, Local File Sink, Webhook Sink) to save periodic aggregated reports, enabling efficient storage and export of summarized analytics data instead of individual data points
- In video processing workflows to generate time-based or frame-based analytics reports, enabling comprehensive video analysis with periodic statistical summaries rather than per-frame outputs
- Before visualization or reporting blocks that need aggregated data to create dashboards, charts, or summaries from time-series data, enabling visualization of trends and statistics
- In analytics pipelines where high-frequency data needs to be reduced to periodic summaries, enabling efficient downstream processing and storage of statistical insights rather than raw high-volume data streams
Type identifier¶
Use the following identifier in step "type" field: roboflow_core/data_aggregator@v1to add the block as
as step in your workflow.
Properties¶
| Name | Type | Description | Refs |
|---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
data_operations |
Dict[str, List[Union[ClassificationPropertyExtract, ConvertDictionaryToJSON, ConvertImageToBase64, ConvertImageToJPEG, DetectionsFilter, DetectionsOffset, DetectionsPropertyExtract, DetectionsRename, DetectionsSelection, DetectionsShift, DetectionsToDictionary, Divide, ExtractDetectionProperty, ExtractFrameMetadata, ExtractImageProperty, LookupTable, Multiply, NumberRound, NumericSequenceAggregate, PickDetectionsByParentClass, RandomNumber, SequenceAggregate, SequenceApply, SequenceElementsCount, SequenceLength, SequenceMap, SortDetections, StringMatches, StringSubSequence, StringToLowerCase, StringToUpperCase, TimestampToISOFormat, ToBoolean, ToNumber, ToString]]] |
Optional dictionary mapping variable names (from data) to UQL (Query Language) operation chains that transform data before aggregation. Operations are applied in sequence to extract, filter, or transform values (e.g., extract class names from detections using DetectionsPropertyExtract, calculate sequence length using SequenceLength, filter values, perform calculations). Keys must match variable names in data. Leave empty or omit variables that don't need transformation. Example: {'predictions': [{'type': 'DetectionsPropertyExtract', 'property_name': 'class_name'}]}.. | ❌ |
aggregation_mode |
Dict[str, List[str]] |
Dictionary mapping variable names (from data) to lists of aggregation operations to compute. Each aggregation produces an output field named '{variable_name}_{aggregation_mode}'. Supported operations: 'sum' (sum of numeric values), 'avg' (average of numeric values), 'max'/'min' (maximum/minimum numeric values), 'count' (count values, adds list length for lists), 'distinct' (list of unique values), 'count_distinct' (number of unique values), 'values_counts' (dictionary of value occurrence counts), 'values_difference' (difference between max and min numeric values). For lists, operations process each element. Multiple aggregations per variable are supported. Example: {'predictions': ['distinct', 'count_distinct', 'avg']}.. | ❌ |
interval_unit |
str |
Unit for measuring the aggregation interval: 'seconds', 'minutes', 'hours' (time-based, uses wall-clock time elapsed since last output - useful for video streams), or 'runs' (run-based, counts number of workflow executions - useful for video file processing where frame count matters more than time). Time-based intervals track elapsed time between aggregated outputs. Run-based intervals count the number of times the block receives data. The block outputs aggregated results and flushes state when the interval threshold is reached.. | ❌ |
interval |
int |
Length of the aggregation interval in the units specified by interval_unit. Must be greater than 0. The block accumulates data internally and outputs aggregated results when this interval threshold is reached. For time-based units (seconds, minutes, hours), this is the duration elapsed since the last output. For 'runs', this is the number of workflow executions (e.g., frames processed) since the last output. After outputting results, the block resets its internal state and starts a new aggregation window. Most of the time, the block returns empty outputs while collecting data.. | ❌ |
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 Data Aggregator in version v1.
- inputs:
Detections Classes Replacement,Morphological Transformation,Image Preprocessing,Email Notification,VLM As Classifier,Halo Visualization,Morphological Transformation,Detections Transformation,Pixel Color Count,Object Detection Model,Time in Zone,Template Matching,Image Threshold,Text Display,BoT-SORT Tracker,Model Monitoring Inference Aggregator,Pixelate Visualization,Keypoint Detection Model,Time in Zone,Qwen-VL,OpenAI,CogVLM,Crop Visualization,Cosine Similarity,SAM 3,Dot Visualization,Detections Merge,Google Vision OCR,Detections List Roll-Up,PLC EthernetIP,Florence-2 Model,Dimension Collapse,Roboflow Dataset Upload,Qwen3.5-VL,Mask Edge Snap,Roboflow Vision Events,Polygon Zone Visualization,Qwen2.5-VL,Polygon Visualization,SIFT Comparison,Absolute Static Crop,S3 Sink,Twilio SMS/MMS Notification,QR Code Generator,SIFT Comparison,Contrast Enhancement,Per-Class Confidence Filter,Single-Label Classification Model,Cache Get,Stitch OCR Detections,Dynamic Zone,Detections Filter,OCR Model,Byte Tracker,Color Visualization,Roboflow Dataset Upload,Gaze Detection,Bounding Rectangle,Roboflow Custom Metadata,Environment Secrets Store,LMM For Classification,Detections Stabilizer,Line Counter Visualization,Image Blur,Stability AI Inpainting,Object Detection Model,Blur Visualization,OpenAI-Compatible LLM,Path Deviation,Current Time,SAM 3,Perspective Correction,Keypoint Visualization,Byte Tracker,Detection Offset,Anthropic Claude,MQTT Writer,MoonshotAI Kimi,Google Gemini,Identify Changes,Image Slicer,SAM 3,Depth Estimation,Detections Consensus,Detections Stitch,Ellipse Visualization,Google Gemma API,Object Detection Model,PLC ModbusTCP,Slack Notification,Overlap Analysis,Rate Limiter,Identify Outliers,Inner Workflow,Time in Zone,Image Stack,Delta Filter,Google Gemini,Cache Set,Bounding Box Visualization,Label Visualization,Keypoint Detection Model,Size Measurement,Camera Focus,Stitch OCR Detections,CSV Formatter,Keypoint Detection Model,Multi-Label Classification Model,OpenAI,SIFT,Perception Encoder Embedding Model,Anthropic Claude,Image Convert Grayscale,Roboflow Asset Library Attributes,OC-SORT Tracker,Moondream2,CLIP Embedding Model,Florence-2 Model,Seg Preview,Overlap Filter,EasyOCR,YOLO-World Model,Buffer,Segment Anything 2 Model,Multi-Label Classification Model,Twilio SMS Notification,Local File Sink,Single-Label Classification Model,Icon Visualization,Triangle Visualization,VLM As Classifier,Qwen 3.5 API,Mask Area Measurement,Path Deviation,JSON Parser,OpenRouter,Dominant Color,Instance Segmentation Model,Distance Measurement,Qwen3-VL,Instance Segmentation Model,OpenAI,Background Color Visualization,MoonshotAI Kimi,Continue If,Byte Tracker,Google Gemini,Grid Visualization,Clip Comparison,Semantic Segmentation Model,Corner Visualization,Image Slicer,Single-Label Classification Model,Reference Path Visualization,SmolVLM2,Line Counter,First Non Empty Or Default,Halo Visualization,Dynamic Crop,Webhook Sink,Instance Segmentation Model,Stability AI Outpainting,Detection Event Log,VLM As Detector,Relative Static Crop,Anthropic Claude,Expression,Clip Comparison,Multi-Label Classification Model,SORT Tracker,OpenAI,Llama 3.2 Vision,Barcode Detection,ByteTrack Tracker,Velocity,Motion Detection,Detections Combine,Camera Calibration,Model Comparison Visualization,Data Aggregator,Trace Visualization,Google Gemma,PTZ Tracking (ONVIF),Line Counter,OPC UA Writer Sink,QR Code Detection,Circle Visualization,Email Notification,LMM,Event Writer,Instance Segmentation Model,Camera Focus,Contrast Equalization,Heatmap Visualization,Background Subtraction,Image Contours,SAM2 Video Tracker,Qwen 3.6 API,GLM-OCR,Qwen3.5,VLM As Detector,Classification Label Visualization,Llama 3.2 Vision,Property Definition,Stitch Images,Mask Visualization,Microsoft SQL Server Sink,Stability AI Image Generation,Semantic Segmentation Model,Polygon Visualization - outputs:
Detections Classes Replacement,Morphological Transformation,Image Preprocessing,Email Notification,VLM As Classifier,Morphological Transformation,Halo Visualization,Detections Transformation,Pixel Color Count,Object Detection Model,BoT-SORT Tracker,Text Display,Template Matching,Time in Zone,Image Threshold,Model Monitoring Inference Aggregator,Pixelate Visualization,Keypoint Detection Model,Time in Zone,Qwen-VL,OpenAI,CogVLM,Crop Visualization,SAM 3,Cosine Similarity,Dot Visualization,Google Vision OCR,PLC EthernetIP,Detections List Roll-Up,Detections Merge,Florence-2 Model,Dimension Collapse,Roboflow Dataset Upload,Mask Edge Snap,Qwen3.5-VL,Roboflow Vision Events,Polygon Zone Visualization,Qwen2.5-VL,Polygon Visualization,SIFT Comparison,S3 Sink,Absolute Static Crop,Twilio SMS/MMS Notification,QR Code Generator,SIFT Comparison,Contrast Enhancement,Per-Class Confidence Filter,Single-Label Classification Model,Cache Get,Stitch OCR Detections,Dynamic Zone,Detections Filter,OCR Model,Byte Tracker,Color Visualization,Roboflow Dataset Upload,Gaze Detection,Roboflow Custom Metadata,Bounding Rectangle,LMM For Classification,OpenAI-Compatible LLM,Line Counter Visualization,Stability AI Inpainting,Image Blur,Object Detection Model,Blur Visualization,Detections Stabilizer,Path Deviation,Current Time,SAM 3,Perspective Correction,Keypoint Visualization,Byte Tracker,Detection Offset,Anthropic Claude,MQTT Writer,MoonshotAI Kimi,Google Gemini,Image Slicer,Identify Changes,SAM 3,Depth Estimation,Detections Consensus,Ellipse Visualization,Google Gemma API,Detections Stitch,Object Detection Model,PLC ModbusTCP,Slack Notification,Overlap Analysis,Rate Limiter,Identify Outliers,Time in Zone,Inner Workflow,Image Stack,Delta Filter,Google Gemini,Cache Set,Label Visualization,Bounding Box Visualization,Keypoint Detection Model,Stitch OCR Detections,Camera Focus,CSV Formatter,Size Measurement,Keypoint Detection Model,Multi-Label Classification Model,OpenAI,SIFT,Perception Encoder Embedding Model,Anthropic Claude,Image Convert Grayscale,OC-SORT Tracker,Roboflow Asset Library Attributes,Moondream2,CLIP Embedding Model,Florence-2 Model,Seg Preview,Overlap Filter,EasyOCR,YOLO-World Model,Multi-Label Classification Model,Segment Anything 2 Model,Twilio SMS Notification,Buffer,Local File Sink,Single-Label Classification Model,Triangle Visualization,VLM As Classifier,Qwen 3.5 API,Mask Area Measurement,Icon Visualization,Path Deviation,JSON Parser,OpenRouter,Dominant Color,Instance Segmentation Model,Distance Measurement,Qwen3-VL,Instance Segmentation Model,OpenAI,Background Color Visualization,MoonshotAI Kimi,Continue If,Byte Tracker,Google Gemini,Grid Visualization,Clip Comparison,Semantic Segmentation Model,Corner Visualization,Reference Path Visualization,Image Slicer,SmolVLM2,Single-Label Classification Model,Line Counter,Halo Visualization,First Non Empty Or Default,Webhook Sink,Dynamic Crop,Instance Segmentation Model,Stability AI Outpainting,Detection Event Log,VLM As Detector,Relative Static Crop,Anthropic Claude,SORT Tracker,Expression,Clip Comparison,Multi-Label Classification Model,OpenAI,Llama 3.2 Vision,Barcode Detection,ByteTrack Tracker,Velocity,Motion Detection,Detections Combine,Camera Calibration,PTZ Tracking (ONVIF),Trace Visualization,Model Comparison Visualization,Data Aggregator,Google Gemma,OPC UA Writer Sink,Line Counter,QR Code Detection,Circle Visualization,Email Notification,LMM,Event Writer,Instance Segmentation Model,Heatmap Visualization,Background Subtraction,Contrast Equalization,GLM-OCR,Qwen 3.6 API,Image Contours,SAM2 Video Tracker,Camera Focus,Qwen3.5,VLM As Detector,Classification Label Visualization,Llama 3.2 Vision,Property Definition,Stitch Images,Mask Visualization,Microsoft SQL Server Sink,Stability AI Image Generation,Semantic Segmentation Model,Polygon Visualization
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
Data Aggregator in version v1 has.
Bindings
-
input
data(*): Dictionary mapping variable names to data sources from workflow steps. Each key becomes a variable name for aggregation, and each value is a selector referencing workflow step outputs (e.g., predictions, metrics, computed values). These variables are used in aggregation_mode to specify which aggregations to compute. Example: {'predictions': '$steps.model.predictions', 'count': '$steps.counter.total'}..
-
output
*(*): Equivalent of any element.
Example JSON definition of step Data Aggregator in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/data_aggregator@v1",
"data": {
"predictions": "$steps.model.predictions",
"reference": "$inputs.reference_class_names"
},
"data_operations": {
"predictions": [
{
"property_name": "class_name",
"type": "DetectionsPropertyExtract"
}
]
},
"aggregation_mode": {
"predictions": [
"distinct",
"count_distinct"
]
},
"interval_unit": "seconds",
"interval": 10
}