First Non Empty Or Default¶
Class: FirstNonEmptyOrDefaultBlockV1
Merge alternative execution branches by selecting the first non-empty value from multiple data inputs, or returning a default value if all inputs are empty, enabling conditional execution merging, empty value handling, and structured output construction workflows where data from different branches needs to be combined or fallback values need to be provided for missing data.
How This Block Works¶
This block merges data from multiple sources (typically from different conditional execution branches) by selecting the first available non-empty value, ensuring outputs are always present for downstream processing. The block:
- Receives a list of data references and an optional default value:
- Takes multiple data inputs as a list of selectors (minimum 1 required)
- Each selector can reference outputs from different workflow steps or branches
- Receives a default value to use when all inputs are empty
- Processes inputs in order:
- Iterates through the data inputs in the order they are provided
- Checks each input value to determine if it is non-empty (not None)
- Stops at the first non-empty value encountered
- Selects first non-empty value:
- Returns the first non-empty value from the list if found
- This allows prioritizing certain data sources over others
- Order matters: earlier inputs have priority over later ones
- Falls back to default if all empty:
- If all inputs in the list are empty (None), returns the configured default value
- Ensures the output is never None, making it safe for downstream blocks
- Default value can be any type (string, number, object, null, etc.)
- Handles empty values:
- This block accepts empty values (None) from conditional execution
- Unlike most blocks that skip processing when inputs are None, this block processes them
- Converts potentially empty inputs into a guaranteed non-empty output
- Returns merged output:
- Outputs the selected value (first non-empty or default)
- Output is always non-None, ensuring compatibility with blocks that don't accept empty values
- Enables structured output construction even when some execution branches produce no data
This block is essential for merging alternative execution branches in workflows with conditional logic. When different branches of a workflow can produce data (e.g., one branch processes data if condition A is true, another if condition B is true), this block allows you to combine those branches by selecting the first available result, ensuring your workflow always produces a valid output.
Common Use Cases¶
- Merging Conditional Branches: Merge outputs from alternative conditional execution branches into a single value (e.g., merge results from different if-else branches, combine alternative processing paths, unify conditional branch outputs), enabling conditional execution merging workflows
- Empty Value Handling: Handle potentially empty values from filtering or conditional execution by providing fallback defaults (e.g., handle filtered data with defaults, provide fallbacks for conditional branches, ensure non-empty outputs from optional steps), enabling robust empty value handling workflows
- Structured Output Construction: Ensure workflow outputs always have values even when some execution paths don't produce data (e.g., construct consistent output structures, guarantee output field presence, build structured responses with defaults), enabling structured output construction workflows
- Priority-Based Selection: Select data from multiple sources based on priority order (e.g., prefer primary source over fallback, select best available data source, prioritize certain processing results), enabling priority-based data selection workflows
- Fallback Values: Provide fallback values when primary data sources are unavailable (e.g., use default values when data missing, provide fallbacks for empty results, ensure downstream compatibility), enabling fallback value workflows
- Output Normalization: Normalize outputs to ensure they're always present and non-empty (e.g., normalize optional outputs, ensure consistent output format, guarantee output availability), enabling output normalization workflows
Connecting to Other Blocks¶
This block receives multiple data inputs and produces a single merged output:
- After conditional execution blocks (ContinueIf, DetectionsFilter, etc.) to merge alternative branch outputs (e.g., merge if-else branch results, combine conditional paths, unify branch outputs), enabling conditional-to-merge workflows
- Before blocks that don't accept empty values to ensure inputs are always present (e.g., ensure non-empty inputs, provide fallbacks for empty data, guarantee input availability), enabling merge-to-processing workflows
- In workflow outputs to construct structured outputs with guaranteed field presence (e.g., build consistent outputs, ensure output completeness, create structured responses), enabling merge-to-output workflows
- After filtering blocks to handle cases where filters remove all data (e.g., provide defaults for filtered data, handle empty filter results, ensure output availability), enabling filter-to-merge workflows
- Before data storage blocks to ensure stored data is always present (e.g., store with defaults, ensure data completeness, provide fallback storage values), enabling merge-to-storage workflows
- Between alternative processing paths to combine results from different processing strategies (e.g., merge alternative processing results, combine different model outputs, unify processing strategies), enabling alternative-to-merge workflows
Requirements¶
This block requires at least one data input reference (can accept multiple). The block accepts empty values (None), allowing it to process data from conditional execution branches. The default parameter is optional (defaults to None) and specifies the fallback value when all inputs are empty. Data inputs are processed in order, with the first non-empty value being selected. If all inputs are empty, the default value is returned. The output is always non-None, ensuring compatibility with blocks that don't accept empty values. This block is essential for merging alternative execution branches and ensuring structured outputs are always complete.
Type identifier¶
Use the following identifier in step "type" field: roboflow_core/first_non_empty_or_default@v1to add the block as
as step in your workflow.
Properties¶
| Name | Type | Description | Refs |
|---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
default |
Any |
Default value to return when all data inputs are empty (None). This ensures the output is always non-None, making it safe for downstream blocks that don't accept empty values. The default can be any type: string (e.g., 'empty', 'N/A'), number (e.g., 0, -1), object (e.g., {}, []), null, or any other value. If not specified, defaults to None. Use this to provide fallback values when conditional execution branches or filtering removes all data, or to ensure structured outputs always have values.. | ❌ |
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 First Non Empty Or Default in version v1.
- inputs:
VLM As Classifier,Line Counter,MoonshotAI Kimi,Stability AI Image Generation,Path Deviation,Trace Visualization,Qwen2.5-VL,Image Stack,Anthropic Claude,Per-Class Confidence Filter,Icon Visualization,SIFT Comparison,Morphological Transformation,Color Visualization,SmolVLM2,LMM For Classification,Single-Label Classification Model,Perspective Correction,Clip Comparison,Corner Visualization,Environment Secrets Store,Roboflow Custom Metadata,Detections Merge,Halo Visualization,Dynamic Zone,Keypoint Detection Model,Qwen-VL,JSON Parser,Email Notification,Halo Visualization,Object Detection Model,Data Aggregator,Google Gemma,Background Color Visualization,Ellipse Visualization,Email Notification,Twilio SMS/MMS Notification,Text Display,Polygon Visualization,Crop Visualization,Absolute Static Crop,Image Preprocessing,Template Matching,Model Monitoring Inference Aggregator,Relative Static Crop,OpenRouter,OpenAI,PLC ModbusTCP,Florence-2 Model,VLM As Detector,Motion Detection,Heatmap Visualization,OCR Model,OpenAI,Detections Filter,Perception Encoder Embedding Model,Blur Visualization,Dimension Collapse,Barcode Detection,Depth Estimation,Instance Segmentation Model,Stability AI Outpainting,Anthropic Claude,YOLO-World Model,Google Gemini,Clip Comparison,Google Gemini,PLC EthernetIP,Background Subtraction,Buffer,Keypoint Visualization,CSV Formatter,Webhook Sink,Byte Tracker,Stitch Images,Florence-2 Model,Current Time,Detections List Roll-Up,Contrast Equalization,Mask Edge Snap,OpenAI,Qwen3-VL,Moondream2,Line Counter,VLM As Detector,Google Gemini,Triangle Visualization,Slack Notification,Overlap Filter,Time in Zone,Inner Workflow,CLIP Embedding Model,First Non Empty Or Default,Detections Stabilizer,SIFT,Local File Sink,Multi-Label Classification Model,Cosine Similarity,Image Contours,Keypoint Detection Model,VLM As Classifier,Pixel Color Count,GLM-OCR,Roboflow Asset Library Attributes,Image Slicer,Polygon Zone Visualization,Time in Zone,Google Gemma API,Semantic Segmentation Model,Stitch OCR Detections,Image Threshold,Line Counter Visualization,Distance Measurement,Semantic Segmentation Model,Multi-Label Classification Model,Contrast Enhancement,Camera Calibration,QR Code Generator,Detection Offset,ByteTrack Tracker,Expression,Detection Event Log,Detections Transformation,S3 Sink,Microsoft SQL Server Sink,Mask Area Measurement,Google Vision OCR,Twilio SMS Notification,Image Blur,Detections Combine,Morphological Transformation,Property Definition,Camera Focus,Delta Filter,Size Measurement,Roboflow Vision Events,Stability AI Inpainting,PTZ Tracking (ONVIF),Classification Label Visualization,Bounding Rectangle,SAM2 Video Tracker,Stitch OCR Detections,Event Writer,Grid Visualization,Qwen3.5-VL,Byte Tracker,Switch Case,Dominant Color,Rate Limiter,Mask Visualization,Llama 3.2 Vision,Reference Path Visualization,Velocity,Label Visualization,Identify Outliers,Image Slicer,SIFT Comparison,Byte Tracker,OPC UA Writer Sink,Dot Visualization,Cache Set,Identify Changes,Dynamic Crop,Detections Stitch,Circle Visualization,Path Deviation,BoT-SORT Tracker,SAM3 Video Tracker,Camera Focus,Llama 3.2 Vision,Gaze Detection,Segment Anything 2 Model,OpenAI-Compatible LLM,MoonshotAI Kimi,Single-Label Classification Model,Overlap Analysis,QR Code Detection,Qwen3.5,CogVLM,Object Detection Model,SAM 3 Interactive,Qwen 3.6 API,Detections Consensus,Bounding Box Visualization,Multi-Label Classification Model,LMM,OpenAI,SAM 3,PLC Reader,Image Convert Grayscale,Instance Segmentation Model,Continue If,Roboflow Visual Search,EasyOCR,Roboflow Dataset Upload,SAM 3,Cache Get,Detections Classes Replacement,Instance Segmentation Model,Pixelate Visualization,Keypoint Detection Model,Roboflow Dataset Upload,SORT Tracker,Instance Segmentation Model,PLC Writer,Track Class Lock,Qwen 3.5 API,Anthropic Claude,Object Detection Model,Time in Zone,MQTT Writer,Polygon Visualization,OC-SORT Tracker,SAM 3,Model Comparison Visualization,Single-Label Classification Model,Seg Preview - outputs:
VLM As Classifier,Line Counter,MoonshotAI Kimi,Stability AI Image Generation,Trace Visualization,Path Deviation,Qwen2.5-VL,Image Stack,Anthropic Claude,Per-Class Confidence Filter,Icon Visualization,SIFT Comparison,Morphological Transformation,Color Visualization,SmolVLM2,LMM For Classification,Single-Label Classification Model,Perspective Correction,Corner Visualization,Clip Comparison,Roboflow Custom Metadata,Detections Merge,Halo Visualization,Dynamic Zone,Qwen-VL,Keypoint Detection Model,JSON Parser,Email Notification,Halo Visualization,Object Detection Model,Data Aggregator,Google Gemma,Background Color Visualization,Email Notification,Ellipse Visualization,Twilio SMS/MMS Notification,Text Display,Polygon Visualization,Crop Visualization,Absolute Static Crop,Image Preprocessing,Template Matching,Model Monitoring Inference Aggregator,Relative Static Crop,OpenRouter,OpenAI,PLC ModbusTCP,VLM As Detector,Florence-2 Model,OpenAI,Heatmap Visualization,Motion Detection,OCR Model,Detections Filter,Perception Encoder Embedding Model,Blur Visualization,Barcode Detection,Dimension Collapse,Depth Estimation,Instance Segmentation Model,Stability AI Outpainting,Anthropic Claude,YOLO-World Model,Google Gemini,Clip Comparison,Google Gemini,PLC EthernetIP,Background Subtraction,Keypoint Visualization,Buffer,CSV Formatter,Webhook Sink,Byte Tracker,Stitch Images,Florence-2 Model,Current Time,Detections List Roll-Up,Contrast Equalization,Mask Edge Snap,OpenAI,Qwen3-VL,Moondream2,Line Counter,VLM As Detector,Google Gemini,Triangle Visualization,Slack Notification,Overlap Filter,Time in Zone,Inner Workflow,CLIP Embedding Model,First Non Empty Or Default,Detections Stabilizer,SIFT,Local File Sink,Multi-Label Classification Model,Cosine Similarity,Image Contours,Keypoint Detection Model,VLM As Classifier,Pixel Color Count,GLM-OCR,Roboflow Asset Library Attributes,Image Slicer,Polygon Zone Visualization,Google Gemma API,Time in Zone,Contrast Enhancement,Stitch OCR Detections,Line Counter Visualization,Image Threshold,Semantic Segmentation Model,Distance Measurement,Multi-Label Classification Model,Semantic Segmentation Model,Camera Calibration,QR Code Generator,Detection Offset,ByteTrack Tracker,Expression,Detection Event Log,Detections Transformation,S3 Sink,Microsoft SQL Server Sink,Mask Area Measurement,Google Vision OCR,Twilio SMS Notification,Image Blur,Detections Combine,Morphological Transformation,Property Definition,Camera Focus,Roboflow Vision Events,Size Measurement,Delta Filter,PTZ Tracking (ONVIF),Stability AI Inpainting,Classification Label Visualization,SAM2 Video Tracker,Stitch OCR Detections,Bounding Rectangle,Event Writer,Grid Visualization,Qwen3.5-VL,Mask Visualization,Dominant Color,Byte Tracker,Rate Limiter,Llama 3.2 Vision,Switch Case,Image Slicer,Velocity,Label Visualization,Identify Outliers,Reference Path Visualization,Byte Tracker,SIFT Comparison,OPC UA Writer Sink,Dot Visualization,Identify Changes,Cache Set,Path Deviation,Detections Stitch,Circle Visualization,Llama 3.2 Vision,BoT-SORT Tracker,SAM3 Video Tracker,Dynamic Crop,Camera Focus,Gaze Detection,Segment Anything 2 Model,OpenAI-Compatible LLM,MoonshotAI Kimi,Single-Label Classification Model,Overlap Analysis,Qwen3.5,QR Code Detection,CogVLM,Object Detection Model,SAM 3 Interactive,Qwen 3.6 API,Detections Consensus,Bounding Box Visualization,Multi-Label Classification Model,LMM,SAM 3,OpenAI,PLC Reader,Image Convert Grayscale,Instance Segmentation Model,Continue If,Roboflow Visual Search,EasyOCR,Roboflow Dataset Upload,SAM 3,Cache Get,Instance Segmentation Model,Detections Classes Replacement,Pixelate Visualization,Keypoint Detection Model,Instance Segmentation Model,SORT Tracker,PLC Writer,Roboflow Dataset Upload,Track Class Lock,Qwen 3.5 API,Object Detection Model,Anthropic Claude,Time in Zone,MQTT Writer,Polygon Visualization,OC-SORT Tracker,SAM 3,Model Comparison Visualization,Single-Label Classification Model,Seg Preview
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
First Non Empty Or Default in version v1 has.
Bindings
-
input
data(*): List of data references (selectors) to check for non-empty values, in priority order. Each selector can reference outputs from different workflow steps or execution branches. The block iterates through this list and returns the first non-empty (non-None) value encountered. If all values in the list are empty/None, the default value is returned. Minimum 1 item required. Order matters: earlier items in the list have higher priority. Common use cases: merging outputs from conditional execution branches, providing fallback data sources, or combining results from alternative processing paths..
-
output
output(*): Equivalent of any element.
Example JSON definition of step First Non Empty Or Default in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/first_non_empty_or_default@v1",
"data": [
"$steps.my_step.predictions"
],
"default": "empty"
}