44 #include <geometric_shapes/shape_operations.h>
45 #include <urdf_parser/urdf_parser.h>
48 #include <gtest/gtest.h>
62 acm_ = std::make_shared<collision_detection::AllowedCollisionMatrix>(
robot_model_->getLinkModelNames(),
true);
64 std::map<std::string, std::vector<collision_detection::CollisionSphere>> link_body_decompositions;
65 cenv_ = std::make_shared<DefaultCEnvType>(
robot_model_, link_body_decompositions);
75 moveit::core::TransformsPtr
ftf_;
78 collision_detection::CollisionEnvPtr
cenv_;
80 collision_detection::AllowedCollisionMatrixPtr
acm_;
92 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
107 cenv_->checkSelfCollision(req, res1, robot_state, *acm_);
108 std::map<std::string, double> torso_val;
109 torso_val[
"torso_lift_joint"] = .15;
112 cenv_->checkSelfCollision(req, res1, robot_state, *acm_);
113 cenv_->checkSelfCollision(req, res1, robot_state, *acm_);
129 Eigen::Isometry3d offset = Eigen::Isometry3d::Identity();
130 offset.translation().x() = .01;
135 acm_->setEntry(
"base_link",
"base_bellow_link",
false);
136 cenv_->checkSelfCollision(req, res1, robot_state, *acm_);
139 acm_->setEntry(
"base_link",
"base_bellow_link",
true);
140 cenv_->checkSelfCollision(req, res2, robot_state, *acm_);
146 acm_->setEntry(
"r_gripper_palm_link",
"l_gripper_palm_link",
false);
147 cenv_->checkSelfCollision(req, res3, robot_state, *acm_);
161 Eigen::Isometry3d offset = Eigen::Isometry3d::Identity();
162 offset.translation().x() = .01;
170 acm_->setEntry(
"base_link",
"base_bellow_link",
false);
171 acm_->setEntry(
"r_gripper_palm_link",
"l_gripper_palm_link",
false);
174 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
177 EXPECT_EQ(res.
contacts.begin()->second.size(), 1u);
183 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
186 EXPECT_EQ(res.
contacts.begin()->second.size(), 1u);
193 acm_ = std::make_shared<collision_detection::AllowedCollisionMatrix>(robot_model_->getLinkModelNames(),
false);
194 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
196 EXPECT_LE(res.
contacts.size(), 10u);
210 Eigen::Isometry3d pos1 = Eigen::Isometry3d::Identity();
211 Eigen::Isometry3d pos2 = Eigen::Isometry3d::Identity();
213 pos1.translation().x() = 5.0;
214 pos2.translation().x() = 5.01;
219 acm_->setEntry(
"r_gripper_palm_link",
"l_gripper_palm_link",
false);
222 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
225 ASSERT_EQ(res.
contacts.begin()->second.size(), 1u);
227 for (collision_detection::CollisionResult::ContactMap::const_iterator it = res.
contacts.begin();
230 EXPECT_NEAR(it->second[0].pos.x(), 5.0, .33);
233 pos1 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond::Identity());
234 pos2 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond(0.965, 0.0, 0.258, 0.0));
240 cenv_->checkSelfCollision(req, res2, robot_state, *acm_);
242 ASSERT_EQ(res2.
contacts.size(), 1u);
243 ASSERT_EQ(res2.
contacts.begin()->second.size(), 1u);
245 for (collision_detection::CollisionResult::ContactMap::const_iterator it = res2.
contacts.begin();
248 EXPECT_NEAR(it->second[0].pos.x(), 3.0, 0.33);
251 pos1 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond::Identity());
252 pos2 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond(M_PI / 4.0, 0.0, M_PI / 4.0, 0.0));
258 cenv_->checkSelfCollision(req, res2, robot_state, *acm_);
269 acm_ = std::make_shared<collision_detection::AllowedCollisionMatrix>(robot_model_->getLinkModelNames(),
true);
275 Eigen::Isometry3d pos1 = Eigen::Isometry3d::Identity();
276 pos1.translation().x() = 1.0;
279 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
282 shapes::Shape* shape =
new shapes::Box(.25, .25, .25);
283 cenv_->getWorld()->addToObject(
"box", shapes::ShapeConstPtr(shape), pos1);
286 cenv_->checkRobotCollision(req, res, robot_state, *acm_);
290 cenv_->getWorld()->removeObject(
"box");
292 const auto identity = Eigen::Isometry3d::Identity();
293 std::vector<shapes::ShapeConstPtr>
shapes;
294 EigenSTL::vector_Isometry3d poses;
295 shapes.push_back(std::make_shared<const shapes::Box>(.25, .25, .25));
296 poses.push_back(identity);
297 std::set<std::string> touch_links;
298 trajectory_msgs::msg::JointTrajectory empty_state;
300 robot_state.
attachBody(std::make_unique<moveit::core::AttachedBody>(
301 robot_state.
getLinkModel(
"r_gripper_palm_link"),
"box", identity,
shapes, poses, touch_links, empty_state));
304 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
310 touch_links.insert(
"r_gripper_palm_link");
311 shapes[0] = std::make_shared<shapes::Box>(.1, .1, .1);
313 robot_state.
attachBody(std::make_unique<moveit::core::AttachedBody>(
314 robot_state.
getLinkModel(
"r_gripper_palm_link"),
"box", identity,
shapes, poses, touch_links, empty_state));
317 cenv_->checkSelfCollision(req, res, robot_state, *acm_);
320 pos1.translation().x() = 1.01;
321 shapes::Shape* coll =
new shapes::Box(.1, .1, .1);
322 cenv_->getWorld()->addToObject(
"coll", shapes::ShapeConstPtr(coll), pos1);
324 cenv_->checkRobotCollision(req, res, robot_state, *acm_);
327 acm_->setEntry(
"coll",
"r_gripper_palm_link",
true);
329 cenv_->checkRobotCollision(req, res, robot_state, *acm_);
333 int main(
int argc,
char** argv)
335 testing::InitGoogleTest(&argc, argv);
336 return RUN_ALL_TESTS();
moveit::core::RobotModelPtr robot_model_
collision_detection::AllowedCollisionMatrixPtr acm_
moveit::core::TransformsConstPtr ftf_const_
moveit::core::TransformsPtr ftf_
collision_detection::CollisionEnvPtr cenv_
Representation of a robot's state. This includes position, velocity, acceleration and effort.
void setVariablePositions(const double *position)
It is assumed positions is an array containing the new positions for all variables in this state....
const LinkModel * getLinkModel(const std::string &link) const
Get the model of a particular link.
void attachBody(std::unique_ptr< AttachedBody > attached_body)
Add an attached body to this state.
void updateStateWithLinkAt(const std::string &link_name, const Eigen::Isometry3d &transform, bool backward=false)
Update the state after setting a particular link to the input global transform pose.
bool clearAttachedBody(const std::string &id)
Remove the attached body named id. Return false if the object was not found (and thus not removed)....
void update(bool force=false)
Update all transforms.
void setToDefaultValues()
Set all joints to their default positions. The default position is 0, or if that is not within bounds...
moveit::core::RobotModelPtr loadTestingRobotModel(const std::string &package_name, const std::string &urdf_relative_path, const std::string &srdf_relative_path)
Loads a robot model given a URDF and SRDF file in a package.
Representation of a collision checking request.
std::string group_name
The group name to check collisions for (optional; if empty, assume the complete robot)....
bool contacts
If true, compute contacts. Otherwise only a binary collision yes/no is reported.
std::size_t max_contacts
Overall maximum number of contacts to compute.
std::size_t max_contacts_per_pair
Maximum number of contacts to compute per pair of bodies (multiple bodies may be in contact at differ...
Representation of a collision checking result.
EIGEN_MAKE_ALIGNED_OPERATOR_NEW void clear()
Clear a previously stored result.
bool collision
True if collision was found, false otherwise.
std::size_t contact_count
Number of contacts returned.
int main(int argc, char **argv)
TEST_F(DistanceFieldCollisionDetectionTester, DefaultNotInCollision)
collision_detection::CollisionEnvDistanceField DefaultCEnvType