Point Cloud Library (PCL)
1.15.1
Toggle main menu visibility
Loading...
Searching...
No Matches
sample_consensus
include
pcl
cuda
sample_consensus
msac.h
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Copyright (c) 2009, Willow Garage, Inc.
5
* All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
9
* are met:
10
*
11
* * Redistributions of source code must retain the above copyright
12
* notice, this list of conditions and the following disclaimer.
13
* * Redistributions in binary form must reproduce the above
14
* copyright notice, this list of conditions and the following
15
* disclaimer in the documentation and/or other materials provided
16
* with the distribution.
17
* * Neither the name of Willow Garage, Inc. nor the names of its
18
* contributors may be used to endorse or promote products derived
19
* from this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32
* POSSIBILITY OF SUCH DAMAGE.
33
*
34
* $Id$
35
*
36
*/
37
38
#pragma once
39
40
#include <pcl_cuda/sample_consensus/sac.h>
41
#include <pcl_cuda/sample_consensus/sac_model.h>
42
43
namespace
pcl_cuda
44
{
45
46
template
<
template
<
typename
>
class
Storage>
47
class
MEstimatorSampleConsensus
:
public
SampleConsensus<Storage>
48
{
49
using
SampleConsensus<Storage>::max_iterations_;
50
using
SampleConsensus<Storage>::threshold_;
51
using
SampleConsensus<Storage>::iterations_;
52
using
SampleConsensus<Storage>::sac_model_;
53
using
SampleConsensus<Storage>::model_;
54
using
SampleConsensus<Storage>::model_coefficients_;
55
using
SampleConsensus<Storage>::inliers_;
56
using
SampleConsensus<Storage>::inliers_stencil_;
57
using
SampleConsensus<Storage>::probability_;
58
59
using
SampleConsensusModelPtr =
typename
SampleConsensusModel<Storage>::Ptr;
60
using
Coefficients =
typename
SampleConsensusModel<Storage>::Coefficients;
61
using
Indices =
typename
SampleConsensusModel<Storage>::Indices;
62
using
Hypotheses =
typename
SampleConsensusModel<Storage>::Hypotheses;
63
64
public
:
65
/** \brief MEstimatorSampleConsensus main constructor
66
* \param model a Sample Consensus model
67
*/
68
MEstimatorSampleConsensus
(
const
SampleConsensusModelPtr &model) :
69
SampleConsensus<Storage> (model)
70
{
71
// Maximum number of trials before we give up.
72
max_iterations_ = 10000;
73
}
74
75
/** \brief RANSAC (RAndom SAmple Consensus) main constructor
76
* \param model a Sample Consensus model
77
* \param threshold distance to model threshold
78
*/
79
MEstimatorSampleConsensus
(
const
SampleConsensusModelPtr &model,
float
threshold) :
80
SampleConsensus<Storage> (model, threshold)
81
{
82
// Maximum number of trials before we give up.
83
max_iterations_ = 10000;
84
}
85
86
/** \brief Compute the actual model and find the inliers
87
* \param debug_verbosity_level enable/disable on-screen debug
88
* information and set the verbosity level
89
*/
90
bool
91
computeModel
(
int
debug_verbosity_level = 0);
92
};
93
}
pcl_cuda::MEstimatorSampleConsensus::computeModel
bool computeModel(int debug_verbosity_level=0)
Compute the actual model and find the inliers.
pcl_cuda::MEstimatorSampleConsensus::MEstimatorSampleConsensus
MEstimatorSampleConsensus(const SampleConsensusModelPtr &model, float threshold)
RANSAC (RAndom SAmple Consensus) main constructor.
Definition
msac.h:79
pcl_cuda::MEstimatorSampleConsensus::MEstimatorSampleConsensus
MEstimatorSampleConsensus(const SampleConsensusModelPtr &model)
MEstimatorSampleConsensus main constructor.
Definition
msac.h:68
pcl_cuda
Definition
filter.h:42