boofcv.alg.feature.disparity.DisparityBlockMatchRowFormat 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.feature.disparity;
import boofcv.alg.InputSanityCheck;
import boofcv.alg.border.GrowBorder;
import boofcv.alg.feature.disparity.block.DisparitySelect;
import boofcv.core.image.border.FactoryImageBorder;
import boofcv.struct.border.ImageBorder;
import boofcv.struct.image.ImageBase;
import boofcv.struct.image.ImageGray;
import boofcv.struct.image.ImageType;
import lombok.Getter;
/**
*
* Base class for all dense stereo disparity score algorithms whose score's can be processed by
* {@link DisparitySelect}. The scores for all possible disparities at each pixel is computed for
* an entire row at once. Then {@link DisparitySelect} is called to process this score.
*
*
*
* Score Format: The index of the score for column i ≥ radiusX + minDisparity at disparity d is:
* index = imgWidth*(d-minDisparity-radiusX) + i - minDisparity-radiusX
* Format Comment:
* This ordering is a bit unnatural when searching for the best disparity, but reduces cache misses
* when writing. Performance boost is about 20%-30% depending on max disparity and image size.
*
*
* @author Peter Abeles
*/
public abstract class DisparityBlockMatchRowFormat
, Disparity extends ImageGray>
{
// the minimum disparity value (inclusive)
protected @Getter int disparityMin;
// maximum allowed image disparity (exclusive)
protected @Getter int disparityMax;
// difference between max and min
protected @Getter int disparityRange;
// number of score elements: image_width*rangeDisparity
protected int widthDisparityBlock;
// radius of the region along x and y axis
protected @Getter int radiusX,radiusY;
// size of the region: radius*2 + 1
protected @Getter int regionWidth,regionHeight;
// Used to extract a row with the border added to it
protected @Getter GrowBorder growBorderL;
protected @Getter GrowBorder growBorderR;
/**
* Configures disparity calculation.
*
* @param regionRadiusX Radius of the rectangular region along x-axis.
* @param regionRadiusY Radius of the rectangular region along y-axis.
*/
public DisparityBlockMatchRowFormat(int regionRadiusX, int regionRadiusY , ImageType imageType ) {
this.radiusX = regionRadiusX;
this.radiusY = regionRadiusY;
this.regionWidth = regionRadiusX*2+1;
this.regionHeight = regionRadiusY*2+1;
growBorderL = (GrowBorder)FactoryImageBorder.createGrowBorder(imageType);
growBorderR = (GrowBorder)FactoryImageBorder.createGrowBorder(imageType);
}
public void setBorder( ImageBorder border ) {
growBorderL.setBorder(border.copy());
growBorderR.setBorder(border.copy());
}
/**
* Configures the disparity search
*
* @param disparityMin Minimum disparity that it will check. Must be ≥ 0 and < maxDisparity
* @param disparityRange Number of possible disparity values estimated. The max possible disparity is min+range-1.
*/
public void configure( int disparityMin , int disparityRange ) {
if( disparityMin < 0 )
throw new IllegalArgumentException("Min disparity must be greater than or equal to zero. max="+disparityMin);
if( disparityRange <= 0 )
throw new IllegalArgumentException("Disparity range must be more than 0");
this.disparityMin = disparityMin;
this.disparityRange = disparityRange;
this.disparityMax = disparityMin+disparityRange-1;
}
/**
* Computes disparity between two stereo images
*
* @param left Left rectified stereo image. Input
* @param right Right rectified stereo image. Input
* @param disparity Disparity between the two images. Output
*/
public void process( Input left , Input right , Disparity disparity ) {
// initialize data structures
InputSanityCheck.checkSameShape(left, right);
if( disparityMax > left.width )
throw new RuntimeException(
"The maximum disparity is too large for this image size: max size "+left.width);
// Stores error for all x-coordinates and disparity values along a single row
widthDisparityBlock = left.width* disparityRange;
_process(left,right,disparity);
}
/**
* Inner function that computes the disparity.
*/
public abstract void _process( Input left , Input right , Disparity disparity );
public abstract ImageType getInputType();
public abstract Class getDisparityType();
public int getBorderX() {
return 0;
}
public int getBorderY() {
return radiusY;
}
/**
* The maximum possible error for the region
*/
public int getMaxRegionError() {
return regionWidth*regionHeight*getMaxPerPixelError();
}
protected abstract int getMaxPerPixelError();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy