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

boofcv.alg.disparity.block.select.SelectSparseErrorWithChecksWta_S32 Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2020, 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.disparity.block.select;

import boofcv.alg.disparity.block.SelectDisparityWithChecksWta;
import boofcv.alg.disparity.block.SelectSparseStandardWta;
import boofcv.alg.disparity.block.score.DisparitySparseRectifiedScoreBM;

/**
 * 

* Implementation of {@link SelectSparseStandardWta} for score arrays of type S32. *

* *

* DO NOT MODIFY. Generated by GenerateSelectSparseStandardWta. *

* * @author Peter Abeles */ public class SelectSparseErrorWithChecksWta_S32 extends SelectSparseStandardWta { // texture threshold, use an integer value for speed. protected int textureThreshold; protected static final int discretizer = SelectDisparityWithChecksWta.DISCRETIZER; public SelectSparseErrorWithChecksWta_S32( int maxError, double texture, int tolRightToLeft ) { super(maxError, texture, tolRightToLeft); } @Override protected void setTexture( double texture ) { this.textureThreshold = (int)(discretizer*texture); } @Override public boolean select( DisparitySparseRectifiedScoreBM scorer, int x, int y ) { // First compute the error in the normal left to right direction if (!scorer.processLeftToRight(x, y)) return false; int[] scores = scorer.getScoreLtoR(); int disparityRange = scorer.getLocalRangeLtoR(); // Select the disparity with the best error int bestDisparity = 0; int scoreBest = scores[0]; for (int i = 1; i < disparityRange; i++) { if (scores[i] < scoreBest) { scoreBest = scores[i]; bestDisparity = i; } } // See if the best match is within tolerance if (scoreBest > maxError) { return false; } // test to see if the region lacks sufficient texture if: // 1) not already eliminated 2) sufficient disparities to check, 3) it's activated if (textureThreshold > 0 && disparityRange >= 3) { // find the second best disparity value and exclude its neighbors int secondBest = Integer.MAX_VALUE; for (int i = 0; i < bestDisparity - 1; i++) { if (scores[i] < secondBest) secondBest = scores[i]; } for (int i = bestDisparity + 2; i < disparityRange; i++) { if (scores[i] < secondBest) secondBest = scores[i]; } // similar scores indicate lack of texture // C = (C2-C1)/C1 if (discretizer*(secondBest - scoreBest) <= textureThreshold*scoreBest) return false; } // if requested perform right to left validation. Ideally the two disparities will be identical if (tolRightToLeft >= 0) { if (!scorer.processRightToLeft(x - bestDisparity - scorer.getDisparityMin(), y)) return false; final int[] scoresRtoL = scorer.getScoreRtoL(); final int localRangeRtoL = scorer.getLocalRangeRtoL(); int bestDisparityRtoL = 0; int scoreBestRtoL = scoresRtoL[0]; for (int i = 1; i < localRangeRtoL; i++) { if (scoresRtoL[i] < scoreBestRtoL) { scoreBestRtoL = scoresRtoL[i]; bestDisparityRtoL = i; } } if (Math.abs(bestDisparityRtoL - bestDisparity) > tolRightToLeft) return false; } this.disparity = bestDisparity; return true; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy