Template Matching¶
Class: TemplateMatchingBlockV1
Source: inference.core.workflows.core_steps.classical_cv.template_matching.v1.TemplateMatchingBlockV1
Locate instances of a template image within a larger image using template matching with normalized cross-correlation, finding exact or near-exact matches of the template pattern at any location in the image, outputting bounding box detections with optional NMS filtering for object detection, logo detection, pattern recognition, and template-based object localization workflows.
How This Block Works¶
This block searches for occurrences of a template image within a larger input image using normalized cross-correlation template matching. The block:
- Receives an input image and a template image (smaller pattern to search for)
- Converts both images to grayscale for template matching (template matching typically works on grayscale images for efficiency and robustness)
- Performs template matching using OpenCV's matchTemplate with TM_CCOEFF_NORMED method:
- Slides the template across the input image at every possible position
- Computes normalized cross-correlation coefficient at each position (measures similarity between template and image region)
- Generates a similarity map showing how well the template matches at each location
- Identifies match locations where similarity exceeds the matching_threshold:
- Finds all positions where the correlation coefficient is greater than or equal to the threshold
- Threshold values range from 0.0 to 1.0, with higher values requiring closer matches
- Lower thresholds find more potential matches (including partial matches), higher thresholds find only very similar matches
- Creates bounding boxes for each match:
- Each match location becomes a detection with a bounding box matching the template's dimensions
- All detections have confidence of 1.0 (they met the threshold requirement)
- All detections are assigned class "template_match" and class_id 0
- Each detection gets a unique detection ID for tracking
- Optionally applies Non-Maximum Suppression (NMS) to filter overlapping detections:
- Template matching often produces many overlapping detections at the same location (duplicate matches)
- NMS removes overlapping detections, keeping only the best match in each area
- NMS threshold controls how much overlap is allowed before removing detections
- Can be disabled (apply_nms=False) if NMS becomes computationally intractable with very large numbers of matches
- Attaches metadata to detections:
- Sets parent_id to reference the input image
- Sets prediction_type to "object-detection"
- Stores image dimensions for coordinate reference
- Attaches parent coordinate information for workflow tracking
- Returns detection predictions in sv.Detections format along with the total number of matches found
The block uses normalized cross-correlation which is effective for finding exact or near-exact template matches. It works best when the template appears in the image at the same scale, rotation, and lighting conditions. The method tends to produce many overlapping detections for the same match location, which is why NMS filtering is important. However, in cases with extremely large numbers of matches (e.g., repeating patterns), NMS may become computationally expensive and can be disabled if needed.
Common Use Cases¶
- Logo and Brand Detection: Find specific logos or brand elements within images (e.g., detect company logos in photos, find brand markers in images, locate specific logo patterns in scenes), enabling logo detection workflows
- Exact Pattern Matching: Locate specific patterns or objects that appear identically in images (e.g., find specific UI elements in screenshots, detect exact patterns in images, locate specific visual elements), enabling exact pattern detection workflows
- Quality Control and Inspection: Find reference patterns or features for quality inspection (e.g., detect specific features in manufacturing images, find reference markers for alignment, locate inspection targets), enabling quality control workflows
- Object Localization: Locate specific objects or regions when exact appearance is known (e.g., find specific objects with known appearance, locate reference objects in images, detect specific visual elements), enabling template-based object localization
- Document Processing: Find specific elements or regions in documents (e.g., locate form fields in documents, detect specific document elements, find reference markers in scanned documents), enabling document processing workflows
- UI Element Detection: Detect specific UI components or elements in interface images (e.g., find buttons in UI screenshots, locate specific UI elements, detect interface components), enabling UI analysis workflows
Connecting to Other Blocks¶
This block receives an image and template, and produces detection predictions:
- After image input blocks to find template patterns in input images (e.g., search for templates in input images, locate patterns in camera feeds, find templates in image streams), enabling template matching workflows
- After preprocessing blocks to find templates in preprocessed images (e.g., match templates after image enhancement, find patterns in filtered images, locate templates in normalized images), enabling preprocessed template matching
- Before visualization blocks to visualize template match locations (e.g., visualize detected template matches, display bounding boxes for matches, show template match results), enabling template match visualization workflows
- Before filtering blocks to filter template matches by criteria (e.g., filter matches by location, select specific match regions, refine template match results), enabling filtered template matching workflows
- Before crop blocks to extract regions around template matches (e.g., crop areas around matches, extract match regions for analysis, crop template match locations), enabling template-based region extraction
- In quality control workflows where template matching is used for inspection or alignment (e.g., find reference markers for alignment, detect inspection targets, locate quality control features), enabling quality control template matching workflows
Type identifier¶
Use the following identifier in step "type" field: roboflow_core/template_matching@v1to add the block as
as step in your workflow.
Properties¶
| Name | Type | Description | Refs |
|---|---|---|---|
name |
str |
Enter a unique identifier for this step.. | ❌ |
matching_threshold |
float |
Minimum similarity threshold (0.0 to 1.0) required for a template match. Higher values (closer to 1.0) require very close matches and find fewer but more precise matches. Lower values (closer to 0.0) allow more lenient matches and find more potential matches including partial matches. Default is 0.8, which requires fairly close matches. Use lower thresholds (0.6-0.7) to find more matches or handle slight variations. Use higher thresholds (0.85-0.95) for exact matches only. The threshold compares normalized cross-correlation coefficients from template matching.. | ✅ |
apply_nms |
bool |
Whether to apply Non-Maximum Suppression (NMS) to filter overlapping detections. Template matching often produces many overlapping detections at the same location. NMS removes overlapping detections, keeping only the best match in each area. Default is True (recommended for most cases). Set to False if: (1) the number of matches is extremely large (NMS may become computationally expensive), (2) you want to see all raw matches without filtering, or (3) matches are intentionally close together and should all be kept. When disabled, you may see many duplicate detections for the same match location.. | ✅ |
nms_threshold |
float |
Intersection over Union (IoU) threshold for Non-Maximum Suppression. Only relevant when apply_nms is True. Detections with IoU overlap greater than this threshold are considered duplicates, and only the detection with highest confidence is kept. Lower values (0.3-0.4) are more aggressive at removing overlaps, removing detections that are only slightly overlapping. Higher values (0.6-0.7) are more lenient, only removing heavily overlapping detections. Default is 0.5, which provides balanced overlap filtering. Adjust based on how much overlap you expect between template matches and how close together valid matches can be.. | ✅ |
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 Template Matching in version v1.
- inputs:
Dynamic Crop,Motion Detection,Email Notification,Image Blur,Background Subtraction,SIFT Comparison,Image Preprocessing,Local File Sink,Bounding Box Visualization,Model Monitoring Inference Aggregator,Email Notification,Slack Notification,Camera Focus,Identify Outliers,Twilio SMS/MMS Notification,VLM As Detector,Dot Visualization,Gaze Detection,Roboflow Dataset Upload,Camera Focus,Depth Estimation,Polygon Visualization,Perspective Correction,PTZ Tracking (ONVIF),Camera Calibration,Corner Visualization,Icon Visualization,Image Slicer,Line Counter Visualization,Heatmap Visualization,Morphological Transformation,Stability AI Image Generation,Keypoint Visualization,VLM As Detector,Halo Visualization,Background Color Visualization,Label Visualization,JSON Parser,Polygon Visualization,Pixelate Visualization,Contrast Equalization,Triangle Visualization,Stability AI Outpainting,Mask Visualization,VLM As Classifier,Color Visualization,Text Display,Relative Static Crop,Reference Path Visualization,Image Threshold,Clip Comparison,Classification Label Visualization,Webhook Sink,Circle Visualization,Polygon Zone Visualization,Image Contours,Image Convert Grayscale,Grid Visualization,VLM As Classifier,Roboflow Custom Metadata,Dynamic Zone,SIFT,Halo Visualization,Detections Consensus,Model Comparison Visualization,Blur Visualization,QR Code Generator,Absolute Static Crop,Image Slicer,S3 Sink,Cosine Similarity,Stability AI Inpainting,Ellipse Visualization,Identify Changes,Crop Visualization,SIFT Comparison,Trace Visualization,Twilio SMS Notification,Stitch Images,Roboflow Dataset Upload - outputs:
Dynamic Crop,Time in Zone,Motion Detection,Email Notification,Image Blur,Background Subtraction,SIFT Comparison,Time in Zone,Image Preprocessing,Instance Segmentation Model,Object Detection Model,Model Monitoring Inference Aggregator,Bounding Box Visualization,Anthropic Claude,Keypoint Detection Model,Detections Stitch,Email Notification,Twilio SMS/MMS Notification,Identify Outliers,Slack Notification,Dot Visualization,Florence-2 Model,Roboflow Dataset Upload,Camera Focus,Stitch OCR Detections,Polygon Visualization,Perspective Correction,PTZ Tracking (ONVIF),Line Counter,Icon Visualization,Corner Visualization,Overlap Filter,Detections List Roll-Up,Image Slicer,Line Counter Visualization,Heatmap Visualization,Morphological Transformation,Distance Measurement,Byte Tracker,Keypoint Visualization,Keypoint Detection Model,Halo Visualization,Background Color Visualization,Label Visualization,Detection Event Log,Polygon Visualization,Pixelate Visualization,Time in Zone,Triangle Visualization,Stability AI Outpainting,Mask Visualization,Color Visualization,Instance Segmentation Model,Detections Combine,Detections Classes Replacement,Dominant Color,Text Display,Line Counter,Stitch OCR Detections,Reference Path Visualization,Image Threshold,Classification Label Visualization,Webhook Sink,Circle Visualization,Image Contours,Mask Area Measurement,Byte Tracker,Grid Visualization,Florence-2 Model,Roboflow Custom Metadata,Dynamic Zone,Velocity,Halo Visualization,Object Detection Model,Byte Tracker,Detections Consensus,Anthropic Claude,Model Comparison Visualization,Blur Visualization,Detection Offset,QR Code Generator,Path Deviation,Absolute Static Crop,Image Slicer,Anthropic Claude,Detections Transformation,Ellipse Visualization,Stability AI Inpainting,Path Deviation,Crop Visualization,Identify Changes,SIFT Comparison,Trace Visualization,Segment Anything 2 Model,Twilio SMS Notification,Size Measurement,Detections Stabilizer,Detections Filter,Stitch Images,Pixel Color Count,Detections Merge,Roboflow Dataset Upload
Input and Output Bindings¶
The available connections depend on its binding kinds. Check what binding kinds
Template Matching in version v1 has.
Bindings
-
input
image(image): Large image in which to search for the template pattern. The template will be searched across this entire image at all possible positions. The image is converted to grayscale internally for template matching. Template matching works best when the image and template have similar lighting conditions and the template appears at similar scale and orientation in the image..template(image): Small template image pattern to search for within the input image. The template should be smaller than the input image. The template is converted to grayscale internally for matching. Template matching finds exact or near-exact matches of this template at any location in the input image. Works best when the template appears in the image at the same scale, rotation, and lighting conditions. The template's dimensions determine the size of the detection bounding boxes..matching_threshold(float): Minimum similarity threshold (0.0 to 1.0) required for a template match. Higher values (closer to 1.0) require very close matches and find fewer but more precise matches. Lower values (closer to 0.0) allow more lenient matches and find more potential matches including partial matches. Default is 0.8, which requires fairly close matches. Use lower thresholds (0.6-0.7) to find more matches or handle slight variations. Use higher thresholds (0.85-0.95) for exact matches only. The threshold compares normalized cross-correlation coefficients from template matching..apply_nms(boolean): Whether to apply Non-Maximum Suppression (NMS) to filter overlapping detections. Template matching often produces many overlapping detections at the same location. NMS removes overlapping detections, keeping only the best match in each area. Default is True (recommended for most cases). Set to False if: (1) the number of matches is extremely large (NMS may become computationally expensive), (2) you want to see all raw matches without filtering, or (3) matches are intentionally close together and should all be kept. When disabled, you may see many duplicate detections for the same match location..nms_threshold(float_zero_to_one): Intersection over Union (IoU) threshold for Non-Maximum Suppression. Only relevant when apply_nms is True. Detections with IoU overlap greater than this threshold are considered duplicates, and only the detection with highest confidence is kept. Lower values (0.3-0.4) are more aggressive at removing overlaps, removing detections that are only slightly overlapping. Higher values (0.6-0.7) are more lenient, only removing heavily overlapping detections. Default is 0.5, which provides balanced overlap filtering. Adjust based on how much overlap you expect between template matches and how close together valid matches can be..
-
output
predictions(object_detection_prediction): Prediction with detected bounding boxes in form of sv.Detections(...) object.number_of_matches(integer): Integer value.
Example JSON definition of step Template Matching in version v1
{
"name": "<your_step_name_here>",
"type": "roboflow_core/template_matching@v1",
"image": "$inputs.image",
"template": "$inputs.template",
"matching_threshold": 0.8,
"apply_nms": "$inputs.apply_nms",
"nms_threshold": "$inputs.nms_threshold"
}