OrientationOptimizer.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 * @date 2021
18 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
19 * GNU General Public License
20 */
21
22#pragma once
23
24#include <optional>
25
27
29{
30
32 {
33 Any = 10,
36 };
37
54
56 {
57 public:
59
60 OrientationOptimizer(const core::GlobalTrajectory& trajectory, const Params& params);
61
63 {
64 std::optional<core::GlobalTrajectory> trajectory;
65
66 /* //COMMENT IN FOR TEST CASE PLOTTING
67 std::vector<double> initial;
68 std::vector<double> prior; */
69
70 operator bool() const noexcept
71 {
72 return trajectory.has_value();
73 }
74 };
75
76 OptimizationResult optimize();
77
78 protected:
79 private:
81
82 const Params params;
83 };
84} // namespace armarx::navigation::global_planning::optimization
85
86// FIXME remove
88{
90}
OrientationOptimizer(const core::GlobalTrajectory &trajectory, const Params &params)
This file is part of ArmarX.
Definition fwd.h:30