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

boofcv.alg.feature.disparity.SelectRectStandard 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.alg.feature.disparity;

import boofcv.struct.image.ImageGray;

/**
 * 

* Selects the disparity with the smallest error, which is known as the winner takes all (WTA) strategy. * Optionally several different techniques can be used to filter out bad disparity values. This is a base class * for algorithms which implement this same "standard" algorithm on different data types. *

* *

* Validation Filters:
* MaxError is the largest error value the selected region can have.
* right To Left validates the disparity by seeing if the matched region on the right has the same region on * the left as its optimal solution, within tolerance.
* texture Tolerance for how similar the best region is to the second best. Lower values indicate greater * tolerance. Reject if textureTol ≤ (C2-C1)/C1, where C2 = second best region score and C1 = best region score *

* *

* This implementation is not based off of any individual paper but ideas commonly expressed in several different * sources. A good study and summary of similar algorithms can be found in:
* [1] Wannes van der Mark and Dariu M. Gavrila, "Real-Time Dense Stereo for Intelligent Vehicles" * IEEE TRANSACTIONS ON INTELLIGENT TRANSPORTATION SYSTEMS, VOL. 7, NO. 1, MARCH 2006 *

* * @author Peter Abeles */ public abstract class SelectRectStandard implements DisparitySelect { // output containing disparity protected T imageDisparity; // minimum and maximum disparity that will be checked protected int minDisparity; protected int maxDisparity; protected int rangeDisparity; // value that an invalid pixel will be assigned protected int invalidDisparity; // max allowed disparity at the current pixel protected int localMax; // radius and width of the region being compared protected int radiusX; protected int regionWidth; // maximum allowed error protected int maxError; // tolerance for right to left validation. if < 0 then it's disabled protected int rightToLeftTolerance; /** * Configures tolerances * * @param maxError The maximum allowed error. Note this is sum error and not per pixel error. * Try (region width*height)*30. * @param rightToLeftTolerance Tolerance for how difference the left to right associated values can be. Try 6 * @param texture Tolerance for how similar optimal region is to other region. Disable with a value ≤ 0. * Closer to zero is more tolerant. Try 0.1 */ public SelectRectStandard(int maxError, int rightToLeftTolerance, double texture) { this.maxError = maxError <= 0 ? Integer.MAX_VALUE : maxError; this.rightToLeftTolerance = rightToLeftTolerance; setTexture(texture); } public abstract void setTexture( double threshold ); @Override public void configure(T imageDisparity, int minDisparity , int maxDisparity , int radiusX ) { this.imageDisparity = imageDisparity; this.minDisparity = minDisparity; this.maxDisparity = maxDisparity; this.radiusX = radiusX; rangeDisparity = maxDisparity-minDisparity; regionWidth = radiusX*2+1; invalidDisparity = rangeDisparity+1; } /** * Sets the output to the specified disparity value. * * @param index Image pixel that is being set * @param disparityValue disparity value */ protected abstract void setDisparity( int index , int disparityValue ); /** * Returns the maximum allowed disparity for a particular column in left to right direction, * as limited by the image border. */ protected int maxDisparityAtColumnL2R( int col) { return 1+col-minDisparity-Math.max(0,col-maxDisparity+1); } /** * For debugging purposes only */ public void setLocalMax(int value) { localMax = value; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy