moveit2
The MoveIt Motion Planning Framework for ROS 2.
Loading...
Searching...
No Matches
chomp_utils.hpp
Go to the documentation of this file.
1/*********************************************************************
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2009, Willow Garage, Inc.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following
15 * disclaimer in the documentation and/or other materials provided
16 * with the distribution.
17 * * Neither the name of Willow Garage nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 * POSSIBILITY OF SUCH DAMAGE.
33 *********************************************************************/
34
35/* Author: Mrinal Kalakrishnan */
36
37#pragma once
38
40
41#include <Eigen/Core>
42#include <iostream>
43
44namespace chomp
45{
46static const int DIFF_RULE_LENGTH = 7;
47
48// the differentiation rules (centered at the center)
49static const double DIFF_RULES[3][DIFF_RULE_LENGTH] = {
50 { 0, 0, -2 / 6.0, -3 / 6.0, 6 / 6.0, -1 / 6.0, 0 }, // velocity
51 { 0, -1 / 12.0, 16 / 12.0, -30 / 12.0, 16 / 12.0, -1 / 12.0, 0 }, // acceleration
52 { 0, 1 / 12.0, -17 / 12.0, 46 / 12.0, -46 / 12.0, 17 / 12.0, -1 / 12.0 } // jerk
53};
54
55static inline void robotStateToArray(const moveit::core::RobotState& state, const std::string& planning_group_name,
56 Eigen::MatrixXd::RowXpr joint_array)
57{
58 const moveit::core::JointModelGroup* group = state.getJointModelGroup(planning_group_name);
59 size_t joint_index = 0;
60 for (const moveit::core::JointModel* jm : group->getActiveJointModels())
61 joint_array[joint_index++] = state.getVariablePosition(jm->getFirstVariableIndex());
62}
63
64// copied from geometry/angles/angles.h
65static inline double normalizeAnglePositive(double angle)
66{
67 return fmod(fmod(angle, 2.0 * M_PI) + 2.0 * M_PI, 2.0 * M_PI);
68}
69
70static inline double normalizeAngle(double angle)
71{
72 double a = normalizeAnglePositive(angle);
73 if (a > M_PI)
74 a -= 2.0 * M_PI;
75 return a;
76}
77
78static inline double shortestAngularDistance(double start, double end)
79{
80 double res = normalizeAnglePositive(normalizeAnglePositive(end) - normalizeAnglePositive(start));
81 if (res > M_PI)
82 {
83 res = -(2.0 * M_PI - res);
84 }
85 return normalizeAngle(res);
86}
87
88} // namespace chomp
A joint from the robot. Models the transform that this joint applies in the kinematic chain....
Representation of a robot's state. This includes position, velocity, acceleration and effort.
const JointModelGroup * getJointModelGroup(const std::string &group) const
Get the model of a particular joint group.