ChainApproximation.h
Go to the documentation of this file.
1
/**
2
* This file is part of ArmarX.
3
*
4
* ArmarX is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License version 2 as
6
* published by the Free Software Foundation.
7
*
8
* ArmarX is distributed in the hope that it will be useful, but
9
* WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU General Public License for more details.
12
*
13
* You should have received a copy of the GNU General Public License
14
* along with this program. If not, see <http://www.gnu.org/licenses/>.
15
*
16
* @author Fabian Reister ( fabian dot reister at kit dot edu )
17
* @author Christian R. G. Dreher ( c dot dreher at kit dot edu )
18
* @date 2021
19
* @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20
* GNU General Public License
21
*/
22
23
#pragma once
24
25
#include <iosfwd>
26
#include <vector>
27
28
#include <Eigen/Core>
29
30
namespace
armarx::navigation::algorithm
31
{
32
33
namespace
detail
34
{
35
struct
ChainApproximationParams
36
{
37
float
distanceTh
;
// [mm]
38
39
int
maxIterations
{-1};
40
};
41
42
struct
ApproximationResult
43
{
44
enum class
TerminationCondition
45
{
46
Converged
,
47
IterationLimit
48
};
49
TerminationCondition
condition
;
50
51
int
iterations
;
52
53
float
reductionFactor
{0.F};
54
};
55
56
std::ostream&
operator<<
(std::ostream&
str
,
const
ApproximationResult& res);
57
}
// namespace detail
58
59
class
ChainApproximation
60
{
61
public
:
62
using
Point
= Eigen::Vector2f;
63
using
Points
= std::vector<Point>;
64
65
using
Params
=
detail::ChainApproximationParams
;
66
using
ApproximationResult
=
detail::ApproximationResult
;
67
68
ChainApproximation
(
const
Points
& points,
const
Params
& params);
69
70
ApproximationResult
approximate
();
71
72
[[nodiscard]]
Points
approximatedChain
()
const
;
73
74
private
:
75
struct
Triplet
76
{
77
Triplet(
const
int
&
a
,
const
int
& b,
const
int
&
c
) :
a
(
a
), b(b),
c
(
c
)
78
{
79
}
80
81
int
a
;
82
int
b;
83
int
c
;
84
};
85
86
using
Triplets = std::vector<Triplet>;
87
88
Triplets getTriplets()
const
;
89
90
std::vector<float> computeDistances(
const
Triplets& triplets);
91
float
computeDistance(
const
Triplet& triplet)
const
;
92
93
bool
approximateStep();
94
95
Points
points;
96
97
std::vector<int> indices;
98
99
const
Params
params;
100
};
101
102
}
// namespace armarx::navigation::algorithm
str
std::string str(const T &t)
Definition:
UserAssistedSegmenterGuiWidgetController.cpp:43
armarx::navigation::algorithm::detail::ChainApproximationParams::maxIterations
int maxIterations
Definition:
ChainApproximation.h:39
armarx::navigation::algorithm::detail::ChainApproximationParams
Definition:
ChainApproximation.h:35
armarx::navigation::algorithm::ChainApproximation::approximate
ApproximationResult approximate()
Definition:
ChainApproximation.cpp:31
armarx::navigation::algorithm::detail::ApproximationResult::condition
TerminationCondition condition
Definition:
ChainApproximation.h:49
detail
Definition:
OpenCVUtil.cpp:128
c
constexpr T c
Definition:
UnscentedKalmanFilterTest.cpp:46
armarx::navigation::algorithm::ChainApproximation::approximatedChain
Points approximatedChain() const
Definition:
ChainApproximation.cpp:178
armarx::navigation::algorithm::detail::ApproximationResult::TerminationCondition::IterationLimit
@ IterationLimit
armarx::ctrlutil::a
double a(double t, double a0, double j)
Definition:
CtrlUtil.h:45
armarx::navigation::algorithm::detail::ApproximationResult::iterations
int iterations
Definition:
ChainApproximation.h:51
armarx::navigation::algorithm::ChainApproximation::Points
std::vector< Point > Points
Definition:
ChainApproximation.h:63
Point
Definition:
PointCloud.h:21
armarx::navigation::algorithm
This file is part of ArmarX.
Definition:
AStarPlanner.cpp:32
armarx::navigation::algorithm::ChainApproximation
Definition:
ChainApproximation.h:59
armarx::navigation::algorithm::detail::operator<<
std::ostream & operator<<(std::ostream &str, const ApproximationResult &res)
Definition:
ChainApproximation.cpp:184
armarx::navigation::algorithm::ChainApproximation::ChainApproximation
ChainApproximation(const Points &points, const Params ¶ms)
Definition:
ChainApproximation.cpp:22
armarx::navigation::algorithm::detail::ChainApproximationParams::distanceTh
float distanceTh
Definition:
ChainApproximation.h:37
armarx::navigation::algorithm::detail::ApproximationResult::TerminationCondition::Converged
@ Converged
armarx::navigation::algorithm::detail::ApproximationResult::reductionFactor
float reductionFactor
Definition:
ChainApproximation.h:53
armarx::navigation::algorithm::detail::ApproximationResult::TerminationCondition
TerminationCondition
Definition:
ChainApproximation.h:44
armarx::navigation::algorithm::detail::ApproximationResult
Definition:
ChainApproximation.h:42
armarx::navigation::algorithm::ChainApproximation::Params
detail::ChainApproximationParams Params
Definition:
ChainApproximation.h:65
armarx
navigation
algorithms
smoothing
ChainApproximation.h
Generated on Sat Mar 29 2025 09:17:35 for armarx_documentation by
1.8.17