All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy