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
40 };
41
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) noexcept : 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
constexpr T c
std::string str(const T &t)
ChainApproximation(const Points &points, const Params &params)
std::ostream & operator<<(std::ostream &str, const ApproximationResult &res)
This file is part of ArmarX.