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

boofcv.abst.feature.detect.extract.NonMaxSuppression Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2017, 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.abst.feature.detect.extract;

import boofcv.struct.QueueCorner;
import boofcv.struct.image.GrayF32;


/**
 * 

* Detects local minimums and/or maximums in an intensity image inside square regions. This is known as non-maximum * suppression. The detector can be configured to ignore pixels along the image border by a user specified distance. * Some implementations require candidate locations for the features. This allows for a sparse algorithm to be used, * resulting in a significant speed boost. Pixel values with a value of -Float.MAX_VALUE or Float.MAX_VALUE will * not be considered for local minimum/maximum, respectively. This is a good way to ignore previously detected * features. *

* *

* Not all implementations will search for both minimums or maximums. Be sure you are using the correct one. If * you don't intend on detecting a minimum or maximum pass in null for the candidate list and the output found list. *

* *

* An extractor which uses candidate features must always be provided them. However, an algorithm which does not * use candidate features will simply ignore that input and operate as usual. Can check capabilities at runtime * using the {@link #canDetectMinimums()} and {@link #canDetectMaximums()} functions. *

* *

* A border can be specified around the outside of the image in which extremes can't be detected. However, a pixel * outside this border can influence if a pixel is a maximum inside, if the local search radius extends that far. * This is specified by the border parameter and the valid region is defined as follows:
* border ≤ x < width-border AND border ≤ y < height-border

* * @author Peter Abeles */ public interface NonMaxSuppression { /** * Process a feature intensity image to extract the point features. If a pixel has an intensity * value == -Float.MAX_VALUE or Float.MAX_VALUE it will not be considered for a local min or max, respectively. * If an algorithm only detect local minimums or maximums and null can be passed in for unused lists. This is * the recommended procedure since it will force an exception to be thrown if a mistake was made. * * @param intensity (Input) Feature intensity image. Not modified. * @param candidateMin (Input) (Optional) List of candidate local minimum features. Can be null if not used. * @param candidateMax (Input) (Optional) List of candidate local maximum features Can be null if not used. * @param foundMin (Output) Storage for found minimums. Can be null if not used. * @param foundMax (Output) Storage for found maximums. Can be null if not used. */ public void process(GrayF32 intensity, QueueCorner candidateMin, QueueCorner candidateMax, QueueCorner foundMin, QueueCorner foundMax ); /** * Returns true if the algorithm requires a candidate list of corners. * * @return true if candidates are required. */ public boolean getUsesCandidates(); /** * Maximum value for detected minimums * * @return threshold for feature selection */ public float getThresholdMinimum(); /** * Minimum value for detected maximums * * @return threshold for feature selection */ public float getThresholdMaximum(); /** * Change the feature selection threshold for finding local minimums. * * @param threshold The new selection threshold. */ public void setThresholdMinimum(float threshold); /** * Change the feature selection threshold for finding local maximums. * * @param threshold The new selection threshold. */ public void setThresholdMaximum(float threshold); /** * Defines the region inside the image in which a pixel can be an extreme. * valid region is: border ≤ x < width-border AND border ≤ y < height-border * * @param border Border size in pixels. */ public void setIgnoreBorder(int border); /** * Returns the size of the image border. * * @return border size */ public int getIgnoreBorder(); /** * Species the search radius for the feature * * @param radius Radius in pixels */ public void setSearchRadius(int radius); /** * Describes how large the region is that is being searched. The radius is the number of * pixels away from the center. * * @return Search radius */ public int getSearchRadius(); /** * True if it can detect local maximums. */ public boolean canDetectMaximums(); /** * True if it can detect local minimums. */ public boolean canDetectMinimums(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy