boofcv.alg.feature.detect.template.TemplateMatchingIntensity Maven / Gradle / Ivy
/*
* Copyright (c) 2011-2019, Peter Abeles. All Rights Reserved.
*
* This file is part of BoofCV (http://boofcv.org).
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package boofcv.alg.feature.detect.template;
import boofcv.struct.image.GrayF32;
import boofcv.struct.image.ImageBase;
/**
*
* Moves an image template over the image and for each pixel computes a metric for how similar
* that region is to template. An intensity image is thus computed for the entire image. Better
* matches always have a more positive value. If a metric inheritally has a small value for
* better matches then its sign will be adjusted so that poor matches have a negative value.
*
*
* A pixel in the intensity image is the result of evaluating the template with its center over
* that pixel. Given pixel (x,y) in the intensity image the template's top left corner (x',y') can be
* found at: x' = x - getOffsetX() and y' = y - getOffsetY().
*
*
* IMAGE BORDER: If the image border is processed or not depends on the implementation. If the border
* is processed then partial templates are considered. If the border is not processed then the
* value of the intensity along the border is not defined and should not be processed.
*
*
* @author Peter Abeles
*/
public interface TemplateMatchingIntensity> {
/**
* Specifies the input image which the template is going ot be matched against
* @param image Input image. Not modified.
*/
void setInputImage( T image );
/**
* Matches the template to the image and computes an intensity image. Must call
* {@link #setInputImage(ImageBase)} first
*
* @param template Template image. Must be equal to or smaller than the input image. Not modified.
*/
void process(T template);
/**
* Matches the template with a mask to the image and computes an intensity image. Must call
* {@link #setInputImage(ImageBase)} first
*
* @param mask Mask that identifies how translucent pixels. 0 = 100% transparent and all values above
* increase its importance. Typical values are 0 to 255 for integer images and 0.0 to 1.0 for
* floating point.
* @param template Template image. Must be equal to or smaller than the input image. Not modified.
*/
void process( T template, T mask );
/**
* Contains results of template matching. Higher intensity values correspond to a better match.
* Local matches can be found using {@link boofcv.abst.feature.detect.extract.NonMaxSuppression}.
* See comment about processing the image border.
*
* @return Feature intensity
*/
GrayF32 getIntensity();
/**
* Does this algorithm process the image's border. If it does not process the border
*
* @return true if the border is processed and false otherwise.
*/
boolean isBorderProcessed();
/**
* Thickness of border along the image left side (lower extent)
*
* @return Border in pixels
*/
int getBorderX0();
/**
* Thickness of border along the image right side (upper extent)
*
* @return Border in pixels
*/
int getBorderX1();
/**
* Thickness of border along the image top (lower extent)
*
* @return Border in pixels
*/
int getBorderY0();
/**
* Thickness of border along the image bottom (upper extent)
*
* @return Border in pixels
*/
int getBorderY1();
/**
* If true then a better fit is a larger number, otherwise a smaller number is a better fit
*/
boolean isMaximize();
}