2011-03-29 21:48:36 +00:00
Camera Calibration and 3D Reconstruction
2011-02-22 20:43:26 +00:00
========================================
.. highlight :: cpp
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoBM_GPU
2011-02-22 20:43:26 +00:00
gpu::StereoBM_GPU
-----------------
2011-03-23 10:56:20 +00:00
.. cpp:class :: gpu::StereoBM_GPU
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
This class computes stereo correspondence (disparity map) using the block matching algorithm.
::
2011-02-22 20:43:26 +00:00
class StereoBM_GPU
{
public:
enum { BASIC_PRESET = 0, PREFILTER_XSOBEL = 1 };
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
enum { DEFAULT_NDISP = 64, DEFAULT_WINSZ = 19 };
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
StereoBM_GPU();
2011-02-26 11:05:10 +00:00
StereoBM_GPU(int preset, int ndisparities = DEFAULT_NDISP,
2011-02-22 20:43:26 +00:00
int winSize = DEFAULT_WINSZ);
2011-02-26 11:05:10 +00:00
void operator() (const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity);
2011-02-26 11:05:10 +00:00
void operator() (const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity, const Stream & stream);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
static bool checkIfGpuCallReasonable();
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int preset;
int ndisp;
int winSize;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
float avergeTexThreshold;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
...
};
2011-02-28 21:26:43 +00:00
2011-03-28 23:16:20 +00:00
2011-03-29 21:48:36 +00:00
The class also performs pre- and post-filtering steps: Sobel pre-filtering (if `` PREFILTER_XSOBEL `` flag is set) and low textureness filtering (if `` averageTexThreshols > 0 `` ). If `` avergeTexThreshold = 0 `` , low textureness filtering is disabled. Otherwise, the disparity is set to 0 in each point `` (x, y) `` , where for the left image
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
\sum HorizontalGradiensInWindow(x, y, winSize) < (winSize \cdot winSize) \cdot avergeTexThreshold
2011-03-23 10:56:20 +00:00
2011-03-29 21:48:36 +00:00
This means that the input left image is low textured.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoBM_GPU::StereoBM_GPU
2011-02-22 20:43:26 +00:00
2011-03-03 07:29:55 +00:00
gpu::StereoBM_GPU::StereoBM_GPU
2011-03-29 21:48:36 +00:00
-----------------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: gpu::StereoBM_GPU::StereoBM_GPU()
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. cpp:function :: gpu::StereoBM_GPU::StereoBM_GPU(int preset, int ndisparities = DEFAULT_NDISP, int winSize = DEFAULT_WINSZ)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables `` StereoBM_GPU `` constructors.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param preset: Preset:
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
* **BASIC_PRESET** Basic mode without pre-processing.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
* **PREFILTER_XSOBEL** Sobel pre-filtering mode.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param ndisparities: Number of disparities. It must be a multiple of 8 and less or equal to 256.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param winSize: Block size.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoBM_GPU::operator ()
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. _gpu :: StereoBM_GPU::operator ():
2011-03-03 07:29:55 +00:00
gpu::StereoBM_GPU::operator ()
2011-02-22 20:43:26 +00:00
----------------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::StereoBM_GPU::operator() (const GpuMat& left, const GpuMat& right, GpuMat& disparity)
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::StereoBM_GPU::operator() (const GpuMat& left, const GpuMat& right, GpuMat& disparity, const Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the stereo correspondence operator that finds the disparity for the specified rectified stereo pair.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param left: Left image. Only ``CV_8UC1`` type is supported.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param right: Right image with the same size and the same type as the left one.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disparity: Output disparity map. It is a ``CV_8UC1`` image with the same size as the input images.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoBM_GPU::checkIfGpuCallReasonable
2011-02-22 20:43:26 +00:00
2011-03-03 07:29:55 +00:00
gpu::StereoBM_GPU::checkIfGpuCallReasonable
2011-02-22 20:43:26 +00:00
-----------------------------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: bool gpu::StereoBM_GPU::checkIfGpuCallReasonable()
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Uses a heuristic method to estimate whether the current GPU is faster than the CPU in this algorithm. It queries the currently active device.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoBeliefPropagation
2011-02-22 20:43:26 +00:00
gpu::StereoBeliefPropagation
----------------------------
2011-03-23 10:56:20 +00:00
.. cpp:class :: gpu::StereoBeliefPropagation
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
This class computes stereo correspondence using the belief propagation algorithm. ::
2011-02-22 20:43:26 +00:00
class StereoBeliefPropagation
{
public:
enum { DEFAULT_NDISP = 64 };
enum { DEFAULT_ITERS = 5 };
enum { DEFAULT_LEVELS = 5 };
2011-02-26 11:05:10 +00:00
static void estimateRecommendedParams(int width, int height,
2011-02-22 20:43:26 +00:00
int& ndisp, int& iters, int& levels);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
explicit StereoBeliefPropagation(int ndisp = DEFAULT_NDISP,
int iters = DEFAULT_ITERS,
int levels = DEFAULT_LEVELS,
int msg_type = CV_32F);
StereoBeliefPropagation(int ndisp, int iters, int levels,
float max_data_term, float data_weight,
float max_disc_term, float disc_single_jump,
int msg_type = CV_32F);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity, Stream& stream);
void operator()(const GpuMat& data, GpuMat& disparity);
void operator()(const GpuMat& data, GpuMat& disparity, Stream& stream);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int ndisp;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int iters;
int levels;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
float max_data_term;
float data_weight;
float max_disc_term;
float disc_single_jump;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int msg_type;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
...
};
2011-02-28 21:26:43 +00:00
2011-03-29 21:48:36 +00:00
The class implements Pedro F. Felzenszwalb algorithm [Pedro F. Felzenszwalb and Daniel P. Huttenlocher. Efficient belief propagation for early vision. International Journal of Computer Vision, 70(1), October 2006]. It can compute own data cost (using a truncated linear model) or use a user-provided data cost.
2011-02-22 20:43:26 +00:00
2011-04-03 22:10:32 +00:00
**Note:**
`` StereoBeliefPropagation `` requires a lot of memory for message storage:
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
width \_ step \cdot height \cdot ndisp \cdot 4 \cdot (1 + 0.25)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
and for data cost storage:
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 10:34:44 +00:00
width\_step \cdot height \cdot ndisp \cdot (1 + 0.25 + 0.0625 + \dotsm + \frac{1}{4^{levels}})
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
`` width_step `` is the number of bytes in a line including padding.
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoBeliefPropagation::StereoBeliefPropagation
2011-03-03 07:29:55 +00:00
gpu::StereoBeliefPropagation::StereoBeliefPropagation
2011-02-22 20:43:26 +00:00
---------------------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: gpu::StereoBeliefPropagation::StereoBeliefPropagation( int ndisp = DEFAULT_NDISP, int iters = DEFAULT_ITERS, int levels = DEFAULT_LEVELS, int msg_type = CV_32F)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: gpu::StereoBeliefPropagation::StereoBeliefPropagation( int ndisp, int iters, int levels, float max_data_term, float data_weight, float max_disc_term, float disc_single_jump, int msg_type = CV_32F)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the `` StereoBeliefPropagation `` constructors.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ndisp: Number of disparities.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param iters: Number of BP iterations on each level.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param levels: Number of levels.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param max_data_term: Threshold for data cost truncation.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param data_weight: Data weight.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param max_disc_term: Threshold for discontinuity truncation.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param disc_single_jump: Discontinuity single jump.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param msg_type: Type for messages. ``CV_16SC1`` and ``CV_32FC1`` types are supported.
2011-03-03 07:29:55 +00:00
2011-03-29 21:48:36 +00:00
`` StereoBeliefPropagation `` uses a truncated linear model for the data cost and discontinuity terms:
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
.. math ::
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
DataCost = data \_ weight \cdot \min ( \lvert I_2-I_1 \rvert , max \_ data \_ term)
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
DiscTerm = \min (disc \_ single \_ jump \cdot \lvert f_1-f_2 \rvert , max \_ disc \_ term)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
For more details, see [Pedro F. Felzenszwalb and Daniel P. Huttenlocher. Efficient belief propagation for early vision. International Journal of Computer Vision, 70(1), October 2006].
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
By default, :cpp:class: `StereoBeliefPropagation` uses floating-point arithmetics and the `` CV_32FC1 `` type for messages. But it can also use fixed-point arithmetics and the `` CV_16SC1 `` message type for better performance. To avoid an overflow in this case, the parameters must satisfy the following requirement:
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
10 \cdot 2^{levels-1} \cdot max \_ data \_ term < SHRT \_ MAX
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoBeliefPropagation::estimateRecommendedParams
2011-03-03 07:29:55 +00:00
gpu::StereoBeliefPropagation::estimateRecommendedParams
-----------------------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoBeliefPropagation::estimateRecommendedParams( int width, int height, int& ndisp, int& iters, int& levels)
2011-03-23 10:56:20 +00:00
2011-03-29 21:48:36 +00:00
Uses a heuristic method to compute the recommended parameters (`` ndisp `` , `` iters `` and `` levels `` ) for the specified image size (`` width `` and `` height `` ).
2011-03-23 10:56:20 +00:00
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoBeliefPropagation::operator ()
2011-03-03 07:29:55 +00:00
gpu::StereoBeliefPropagation::operator ()
2011-02-22 20:43:26 +00:00
---------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoBeliefPropagation::operator()( const GpuMat& left, const GpuMat& right, GpuMat& disparity)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoBeliefPropagation::operator()( const GpuMat& left, const GpuMat& right, GpuMat& disparity, Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the stereo correspondence operator that finds the disparity for the specified rectified stereo pair or data cost.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param left: Left image. ``CV_8UC1`` , ``CV_8UC3`` and ``CV_8UC4`` types are supported.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param right: Right image with the same size and the same type as the left one.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disparity: Output disparity map. If ``disparity`` is empty, the output type is ``CV_16SC1`` . Otherwise, the output type is ``disparity.type()`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoBeliefPropagation::operator()( const GpuMat& data, GpuMat& disparity)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoBeliefPropagation::operator()( const GpuMat& data, GpuMat& disparity, Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param data: The user-specified data cost, a matrix of ``msg_type`` type and ``Size(<image columns>*ndisp, <image rows>)`` size.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disparity: Output disparity map. If the matrix is empty, it is created as the ``CV_16SC1`` matrix. Otherwise, the type is retained.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::StereoConstantSpaceBP
2011-02-22 20:43:26 +00:00
gpu::StereoConstantSpaceBP
--------------------------
2011-03-23 10:56:20 +00:00
.. cpp:class :: gpu::StereoConstantSpaceBP
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
This class computes stereo correspondence using the constant space belief propagation algorithm. ::
2011-02-22 20:43:26 +00:00
class StereoConstantSpaceBP
{
public:
enum { DEFAULT_NDISP = 128 };
enum { DEFAULT_ITERS = 8 };
enum { DEFAULT_LEVELS = 4 };
enum { DEFAULT_NR_PLANE = 4 };
2011-02-26 11:05:10 +00:00
static void estimateRecommendedParams(int width, int height,
2011-02-22 20:43:26 +00:00
int& ndisp, int& iters, int& levels, int& nr_plane);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
explicit StereoConstantSpaceBP(int ndisp = DEFAULT_NDISP,
int iters = DEFAULT_ITERS,
int levels = DEFAULT_LEVELS,
int nr_plane = DEFAULT_NR_PLANE,
int msg_type = CV_32F);
StereoConstantSpaceBP(int ndisp, int iters, int levels, int nr_plane,
2011-02-26 11:05:10 +00:00
float max_data_term, float data_weight,
2011-02-22 20:43:26 +00:00
float max_disc_term, float disc_single_jump,
int min_disp_th = 0,
int msg_type = CV_32F);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& left, const GpuMat& right,
2011-02-22 20:43:26 +00:00
GpuMat& disparity, Stream& stream);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int ndisp;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int iters;
int levels;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int nr_plane;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
float max_data_term;
float data_weight;
float max_disc_term;
float disc_single_jump;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int min_disp_th;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
int msg_type;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
bool use_local_init_data_cost;
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
...
};
2011-02-28 21:26:43 +00:00
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
The class implements Q. Yang algorithm [Q. Yang, L. Wang, and N. Ahuja. A constant-space belief propagation algorithm for stereo matching. In CVPR, 2010]. `` StereoConstantSpaceBP `` supports both local minimum and global minimum data cost initialization algortihms. For more details, see the paper. By default, a local algorithm is used. To enable a global algorithm, set `` use_local_init_data_cost `` to `` false `` .
2011-03-23 10:56:20 +00:00
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoConstantSpaceBP::StereoConstantSpaceBP
2011-03-03 07:29:55 +00:00
gpu::StereoConstantSpaceBP::StereoConstantSpaceBP
2011-02-22 20:43:26 +00:00
-----------------------------------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: gpu::StereoConstantSpaceBP::StereoConstantSpaceBP(int ndisp = DEFAULT_NDISP, int iters = DEFAULT_ITERS, int levels = DEFAULT_LEVELS, int nr_plane = DEFAULT_NR_PLANE, int msg_type = CV_32F)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: StereoConstantSpaceBP::StereoConstantSpaceBP(int ndisp, int iters, int levels, int nr_plane, float max_data_term, float data_weight, float max_disc_term, float disc_single_jump, int min_disp_th = 0, int msg_type = CV_32F)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the StereoConstantSpaceBP constructors.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ndisp: Number of disparities.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param iters: Number of BP iterations on each level.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param levels: Number of levels.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param nr_plane: Number of disparity levels on the first level.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param max_data_term: Truncation of data cost.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param data_weight: Data weight.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param max_disc_term: Truncation of discontinuity.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param disc_single_jump: Discontinuity single jump.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param min_disp_th: Minimal disparity threshold.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param msg_type: Type for messages. ``CV_16SC1`` and ``CV_32FC1`` types are supported.
2011-03-03 07:29:55 +00:00
2011-03-29 21:48:36 +00:00
`` StereoConstantSpaceBP `` uses a truncated linear model for the data cost and discontinuity terms:
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
DataCost = data \_ weight \cdot \min ( \lvert I_2-I_1 \rvert , max \_ data \_ term)
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
.. math ::
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
DiscTerm = \min (disc \_ single \_ jump \cdot \lvert f_1-f_2 \rvert , max \_ disc \_ term)
2011-02-26 11:05:10 +00:00
2011-03-30 12:27:31 +00:00
For more details, see [Q. Yang, L. Wang, and N. Ahuja. A constant-space belief propagation algorithm for stereo matching. In CVPR, 2010].
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
By default, `` StereoConstantSpaceBP `` uses floating-point arithmetics and the `` CV_32FC1 `` type for messages. But it can also use fixed-point arithmetics and the `` CV_16SC1 `` message type for better perfomance. To avoid an overflow in this case, the parameters must satisfy the following requirement:
2011-02-22 20:43:26 +00:00
.. math ::
2011-03-28 23:16:20 +00:00
10 \cdot 2^{levels-1} \cdot max \_ data \_ term < SHRT \_ MAX
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoConstantSpaceBP::estimateRecommendedParams
2011-03-03 07:29:55 +00:00
gpu::StereoConstantSpaceBP::estimateRecommendedParams
---------------------------------------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::StereoConstantSpaceBP::estimateRecommendedParams( int width, int height, int& ndisp, int& iters, int& levels, int& nr_plane)
2011-03-29 21:48:36 +00:00
Uses a heuristic method to compute parameters (ndisp, iters, levelsand nrplane) for the specified image size (widthand height).
2011-02-22 20:43:26 +00:00
.. index :: gpu::StereoConstantSpaceBP::operator ()
2011-03-03 07:29:55 +00:00
gpu::StereoConstantSpaceBP::operator ()
2011-02-22 20:43:26 +00:00
-------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoConstantSpaceBP::operator()( const GpuMat& left, const GpuMat& right, GpuMat& disparity)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::StereoConstantSpaceBP::operator()( const GpuMat& left, const GpuMat& right, GpuMat& disparity, Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the stereo correspondence operator that finds the disparity for the specified rectified stereo pair.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param left: Left image. ``CV_8UC1`` , ``CV_8UC3`` and ``CV_8UC4`` types are supported.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param right: Right image with the same size and the same type as the left one.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disparity: Output disparity map. If ``disparity`` is empty, the output type is ``CV_16SC1`` . Otherwise, the output type is ``disparity.type()`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. index :: gpu::DisparityBilateralFilter
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. _gpu :: DisparityBilateralFilter:
2011-02-22 20:43:26 +00:00
gpu::DisparityBilateralFilter
-----------------------------
2011-03-23 10:56:20 +00:00
.. cpp:class :: gpu::DisparityBilateralFilter
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
This class refines a disparity map using joint bilateral filtering. ::
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
class CV_EXPORTS DisparityBilateralFilter
2011-02-22 20:43:26 +00:00
{
public:
enum { DEFAULT_NDISP = 64 };
enum { DEFAULT_RADIUS = 3 };
enum { DEFAULT_ITERS = 1 };
2011-02-26 11:05:10 +00:00
explicit DisparityBilateralFilter(int ndisp = DEFAULT_NDISP,
2011-02-22 20:43:26 +00:00
int radius = DEFAULT_RADIUS, int iters = DEFAULT_ITERS);
2011-02-26 11:05:10 +00:00
DisparityBilateralFilter(int ndisp, int radius, int iters,
float edge_threshold, float max_disc_threshold,
2011-02-22 20:43:26 +00:00
float sigma_range);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& disparity, const GpuMat& image,
2011-02-22 20:43:26 +00:00
GpuMat& dst);
2011-02-26 11:05:10 +00:00
void operator()(const GpuMat& disparity, const GpuMat& image,
2011-02-22 20:43:26 +00:00
GpuMat& dst, Stream& stream);
2011-02-26 11:05:10 +00:00
2011-02-22 20:43:26 +00:00
...
};
2011-02-28 21:26:43 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
The class implements Q. Yang algorithm [Q. Yang, L. Wang, and N. Ahuja. A constant-space belief propagation algorithm for stereo matching. In CVPR, 2010].
2011-02-22 20:43:26 +00:00
.. index :: gpu::DisparityBilateralFilter::DisparityBilateralFilter
2011-03-03 07:29:55 +00:00
gpu::DisparityBilateralFilter::DisparityBilateralFilter
2011-02-22 20:43:26 +00:00
-----------------------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: gpu::DisparityBilateralFilter::DisparityBilateralFilter( int ndisp = DEFAULT_NDISP, int radius = DEFAULT_RADIUS, int iters = DEFAULT_ITERS)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: gpu::DisparityBilateralFilter::DisparityBilateralFilter( int ndisp, int radius, int iters, float edge_threshold, float max_disc_threshold, float sigma_range)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Enables the `` DisparityBilateralFilter `` constructors.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ndisp: Number of disparities.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param radius: Filter radius.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param iters: Number of iterations.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param edge_threshold: Threshold for edges.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param max_disc_threshold: Constant to reject outliers.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sigma_range: Filter range.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
.. index :: gpu::DisparityBilateralFilter::operator ()
2011-02-22 20:43:26 +00:00
2011-03-03 07:29:55 +00:00
gpu::DisparityBilateralFilter::operator ()
2011-02-22 20:43:26 +00:00
----------------------------------------------
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::DisparityBilateralFilter::operator()( const GpuMat& disparity, const GpuMat& image, GpuMat& dst)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
.. cpp:function :: void gpu::DisparityBilateralFilter::operator()( const GpuMat& disparity, const GpuMat& image, GpuMat& dst, Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Refines a disparity map using joint bilateral filtering.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disparity: Input disparity map. ``CV_8UC1`` and ``CV_16SC1`` types are supported.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param image: Input image. ``CV_8UC1`` and ``CV_8UC3`` types are supported.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst: Destination disparity map. It has the same size and type as ``disparity`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
.. index :: gpu::drawColorDisp
2011-03-03 07:29:55 +00:00
gpu::drawColorDisp
2011-02-22 20:43:26 +00:00
----------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::drawColorDisp(const GpuMat& src_disp, GpuMat& dst_disp, int ndisp)
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::drawColorDisp(const GpuMat& src_disp, GpuMat& dst_disp, int ndisp, const Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Colors a disparity image.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param src_disp: Source disparity image. ``CV_8UC1`` and ``CV_16SC1`` types are supported.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst_disp: Output disparity image. It has the same size as ``src_disp`` . The type is ``CV_8UC4`` in ``BGRA`` format (alpha = 255).
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ndisp: Number of disparities.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
This function draws a colored disparity map by converting disparity values from `` [0..ndisp) `` interval first to `` HSV `` color space (where different disparity values correspond to different hues) and then converting the pixels to `` RGB `` for visualization.
2011-02-22 20:43:26 +00:00
.. index :: gpu::reprojectImageTo3D
2011-03-03 07:29:55 +00:00
gpu::reprojectImageTo3D
2011-02-22 20:43:26 +00:00
---------------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::reprojectImageTo3D(const GpuMat& disp, GpuMat& xyzw, const Mat& Q)
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::reprojectImageTo3D(const GpuMat& disp, GpuMat& xyzw, const Mat& Q, const Stream& stream)
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
Reprojects a disparity image to 3D space.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param disp: Input disparity image. ``CV_8U`` and ``CV_16S`` types are supported.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param xyzw: Output 4-channel floating-point image of the same size as ``disp`` . Each element of ``xyzw(x,y)`` contains 3D coordinates ``(x,y,z,1)`` of the point ``(x,y)`` , computed from the disparity map.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param Q: :math:`4 \times 4` perspective transformation matrix that can be obtained via :ref:`StereoRectify` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-06-09 01:16:45 +00:00
See Also: :cpp:func: `reprojectImageTo3D` .
2011-02-22 20:43:26 +00:00
2011-03-09 08:48:39 +00:00
.. index :: gpu::solvePnPRansac
gpu::solvePnPRansac
-------------------
2011-03-23 10:56:20 +00:00
.. cpp:function :: void gpu::solvePnPRansac(const Mat& object, const Mat& image, const Mat& camera_mat, const Mat& dist_coef, Mat& rvec, Mat& tvec, bool use_extrinsic_guess=false, int num_iters=100, float max_dist=8.0, int min_inlier_count=100, vector<int>* inliers=NULL)
2011-03-09 08:48:39 +00:00
2011-03-29 21:48:36 +00:00
Finds the object pose from 3D-2D point correspondences.
2011-03-09 08:48:39 +00:00
:param object: Single-row matrix of object points.
:param image: Single-row matrix of image points.
:param camera_mat: 3x3 matrix of intrinsic camera parameters.
2011-06-09 01:16:45 +00:00
:param dist_coef: Distortion coefficients. See :cpp:func:`undistortPoints` for details.
2011-03-09 08:48:39 +00:00
:param rvec: Output 3D rotation vector.
:param tvec: Output 3D translation vector.
2011-03-29 21:48:36 +00:00
:param use_extrinsic_guess: Flag to indicate that the function must use ``rvec`` and ``tvec`` as an initial transformation guess. It is not supported for now.
2011-03-09 08:48:39 +00:00
:param num_iters: Maximum number of RANSAC iterations.
:param max_dist: Euclidean distance threshold to detect whether point is inlier or not.
2011-03-29 21:48:36 +00:00
:param min_inlier_count: Flag to indicate that the function must stop if greater or equal number of inliers is achieved. It is not supported for now.
2011-03-09 08:48:39 +00:00
:param inliers: Output vector of inlier indices.
2011-06-09 01:16:45 +00:00
See Also :cpp:func: `solvePnPRansac` .
2011-03-28 23:16:20 +00:00