RobotPlacement.h
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * Copyright (C) 2012-2016, High Performance Humanoid Technologies (H2T),
5 * Karlsruhe Institute of Technology (KIT), all rights reserved.
6 *
7 * ArmarX is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 *
11 * ArmarX is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 *
19 * @author Simon Ottenhaus (simon dot ottenhaus at kit dot edu)
20 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
21 * GNU General Public License
22 */
23
24#pragma once
25
26#include <memory>
27
28#include "DiffIKProvider.h"
29#include "GraspTrajectory.h"
30
31namespace armarx
32{
33 typedef std::shared_ptr<class RobotPlacement> RobotPlacementPtr;
34
36 {
37 public:
38 struct Result
39 {
41 };
42
44 {
45 std::vector<Eigen::Matrix4f> prePoses;
47 };
48
49 public:
50 RobotPlacement(const DiffIKProviderPtr& ikProvider);
51
52 static std::vector<Eigen::Matrix4f> CreateGrid(float dx,
53 int minx,
54 int maxx,
55 float dy,
56 int miny,
57 int maxy,
58 float da,
59 int mina,
60 int maxa);
61
62 std::vector<Result> evaluatePlacements(const std::vector<Eigen::Matrix4f>& robotPlacements,
63 const PlacementParams& params);
64
65
66 private:
67 DiffIKProviderPtr ikProvider;
68 bool returnOnlyReachable = true;
69 };
70} // namespace armarx
RobotPlacement(const DiffIKProviderPtr &ikProvider)
std::vector< Result > evaluatePlacements(const std::vector< Eigen::Matrix4f > &robotPlacements, const PlacementParams &params)
static std::vector< Eigen::Matrix4f > CreateGrid(float dx, int minx, int maxx, float dy, int miny, int maxy, float da, int mina, int maxa)
This file offers overloads of toIce() and fromIce() functions for STL container types.
std::shared_ptr< class RobotPlacement > RobotPlacementPtr
std::shared_ptr< class DiffIKProvider > DiffIKProviderPtr
std::shared_ptr< class GraspTrajectory > GraspTrajectoryPtr
std::vector< Eigen::Matrix4f > prePoses