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 
31 {
32 
33  namespace detail
34  {
36  {
37  float distanceTh; // [mm]
38 
39  int maxIterations{-1};
40  };
41 
43  {
45  {
46  Converged,
48  };
50 
52 
53  float reductionFactor{0.F};
54  };
55 
56  std::ostream& operator<<(std::ostream& str, const ApproximationResult& res);
57  } // namespace detail
58 
60  {
61  public:
62  using Point = Eigen::Vector2f;
63  using Points = std::vector<Point>;
64 
67 
68  ChainApproximation(const Points& points, const Params& params);
69 
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 &params)
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