moveit2
The MoveIt Motion Planning Framework for ROS 2.
link_model.cpp
Go to the documentation of this file.
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2008, 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 the 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: Ioan Sucan */
36 
39 #include <geometric_shapes/check_isometry.h>
40 #include <geometric_shapes/shape_operations.h>
42 
43 namespace moveit
44 {
45 namespace core
46 {
47 LinkModel::LinkModel(const std::string& name, size_t link_index)
48  : name_(name)
49  , link_index_(link_index)
50  , parent_joint_model_(nullptr)
51  , parent_link_model_(nullptr)
52  , is_parent_joint_fixed_(false)
53  , joint_origin_transform_is_identity_(true)
54  , first_collision_body_transform_index_(-1)
55 {
56  joint_origin_transform_.setIdentity();
57 }
58 
59 LinkModel::~LinkModel() = default;
60 
61 void LinkModel::setJointOriginTransform(const Eigen::Isometry3d& transform)
62 {
63  ASSERT_ISOMETRY(transform) // unsanitized input, could contain a non-isometry
64  joint_origin_transform_ = transform;
65  joint_origin_transform_is_identity_ =
66  joint_origin_transform_.linear().isIdentity() &&
67  joint_origin_transform_.translation().norm() < std::numeric_limits<double>::epsilon();
68 }
69 
71 {
72  parent_joint_model_ = joint;
73  is_parent_joint_fixed_ = joint->getType() == JointModel::FIXED;
74 }
75 
76 void LinkModel::setGeometry(const std::vector<shapes::ShapeConstPtr>& shapes, const EigenSTL::vector_Isometry3d& origins)
77 {
78  shapes_ = shapes;
79  collision_origin_transform_ = origins;
80  collision_origin_transform_is_identity_.resize(collision_origin_transform_.size());
81 
82  core::AABB aabb;
83 
84  for (std::size_t i = 0; i < shapes_.size(); ++i)
85  {
86  ASSERT_ISOMETRY(collision_origin_transform_[i]) // unsanitized input, could contain a non-isometry
87  collision_origin_transform_is_identity_[i] =
88  (collision_origin_transform_[i].linear().isIdentity() &&
89  collision_origin_transform_[i].translation().norm() < std::numeric_limits<double>::epsilon()) ?
90  1 :
91  0;
92  Eigen::Isometry3d transform = collision_origin_transform_[i];
93 
94  if (shapes_[i]->type != shapes::MESH)
95  {
96  Eigen::Vector3d extents = shapes::computeShapeExtents(shapes_[i].get());
97  aabb.extendWithTransformedBox(transform, extents);
98  }
99  else
100  {
101  // we cannot use shapes::computeShapeExtents() for meshes, since that method does not provide information about
102  // the offset of the mesh origin
103  const shapes::Mesh* mesh = dynamic_cast<const shapes::Mesh*>(shapes_[i].get());
104  for (unsigned int j = 0; j < mesh->vertex_count; ++j)
105  {
106  aabb.extend(transform * Eigen::Map<Eigen::Vector3d>(&mesh->vertices[3 * j]));
107  }
108  }
109  }
110 
111  centered_bounding_box_offset_ = aabb.center();
112  if (shapes_.empty())
113  {
114  shape_extents_.setZero();
115  }
116  else
117  {
118  shape_extents_ = aabb.sizes();
119  }
120 }
121 
122 void LinkModel::setVisualMesh(const std::string& visual_mesh, const Eigen::Isometry3d& origin,
123  const Eigen::Vector3d& scale)
124 {
125  visual_mesh_filename_ = visual_mesh;
126  visual_mesh_origin_ = origin;
127  visual_mesh_scale_ = scale;
128 }
129 
130 } // end of namespace core
131 } // end of namespace moveit
Represents an axis-aligned bounding box.
Definition: aabb.hpp:47
void extendWithTransformedBox(const Eigen::Isometry3d &transform, const Eigen::Vector3d &box)
Extend with a box transformed by the given transform.
Definition: aabb.cpp:40
A joint from the robot. Models the transform that this joint applies in the kinematic chain....
JointType getType() const
Get the type of joint.
void setGeometry(const std::vector< shapes::ShapeConstPtr > &shapes, const EigenSTL::vector_Isometry3d &origins)
Definition: link_model.cpp:76
EIGEN_MAKE_ALIGNED_OPERATOR_NEW LinkModel(const std::string &name, size_t link_index)
Construct a link model named name.
Definition: link_model.cpp:47
void setParentJointModel(const JointModel *joint)
Definition: link_model.cpp:70
void setVisualMesh(const std::string &visual_mesh, const Eigen::Isometry3d &origin, const Eigen::Vector3d &scale)
Definition: link_model.cpp:122
void setJointOriginTransform(const Eigen::Isometry3d &transform)
Definition: link_model.cpp:61
Vec3fX< details::Vec3Data< double > > Vector3d
Definition: fcl_compat.hpp:89
Main namespace for MoveIt.
Definition: exceptions.hpp:43
name
Definition: setup.py:7
Definition: world.hpp:49