moveit2
The MoveIt Motion Planning Framework for ROS 2.
Loading...
Searching...
No Matches
test_collision_common_pr2.h
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 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: E. Gil Jones */
36
43#include <urdf_parser/urdf_parser.h>
44#include <geometric_shapes/shape_operations.h>
45
46#include <gtest/gtest.h>
47#include <sstream>
48#include <algorithm>
49#include <ctype.h>
50#include <fstream>
51
52template <class CollisionAllocatorType>
53class CollisionDetectorTest : public ::testing::Test
54{
55public:
56 std::shared_ptr<CollisionAllocatorType> value_;
57
58protected:
62
63 void SetUp() override
64 {
65 value_ = std::make_shared<CollisionAllocatorType>();
67 robot_model_ok_ = static_cast<bool>(robot_model_);
68 kinect_dae_resource_ = "package://moveit_resources_pr2_description/urdf/meshes/sensors/kinect_v0/kinect.dae";
69
70 acm_ = std::make_shared<collision_detection::AllowedCollisionMatrix>(robot_model_->getLinkModelNames(), true);
71
72 cenv_ = value_->allocateEnv(robot_model_);
73 }
74
75 void TearDown() override
76 {
77 }
78
80
81 moveit::core::RobotModelPtr robot_model_;
82
83 collision_detection::CollisionEnvPtr cenv_;
84
85 collision_detection::AllowedCollisionMatrixPtr acm_;
86
88};
89
90#ifdef NDEBUG
91#define EXPECT_TIME_LT(EXPR, VAL) EXPECT_LT(EXPR, VAL)
92#else // Don't perform timing checks in Debug mode (but evaluate expression)
93#define EXPECT_TIME_LT(EXPR, VAL) static_cast<void>(EXPR)
94#endif
95
97
99{
100 ASSERT_TRUE(this->robot_model_ok_);
101}
102
103TYPED_TEST_P(CollisionDetectorTest, DefaultNotInCollision)
104{
105 moveit::core::RobotState robot_state(this->robot_model_);
106 robot_state.setToDefaultValues();
107 robot_state.update();
108
111 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
112 ASSERT_FALSE(res.collision);
113}
114
116{
121 // req.contacts = true;
122 // req.max_contacts = 100;
123
124 moveit::core::RobotState robot_state(this->robot_model_);
125 robot_state.setToDefaultValues();
126 robot_state.update();
127
128 Eigen::Isometry3d offset = Eigen::Isometry3d::Identity();
129 offset.translation().x() = .01;
130
131 // robot_state.getLinkState("base_link")->updateGivenGlobalLinkTransform(Eigen::Isometry3d::Identity());
132 // robot_state.getLinkState("base_bellow_link")->updateGivenGlobalLinkTransform(offset);
133 robot_state.updateStateWithLinkAt("base_link", Eigen::Isometry3d::Identity());
134 robot_state.updateStateWithLinkAt("base_bellow_link", offset);
135 robot_state.update();
136
137 this->acm_->setEntry("base_link", "base_bellow_link", false);
138 this->cenv_->checkSelfCollision(req, res1, robot_state, *this->acm_);
139 ASSERT_TRUE(res1.collision);
140
141 this->acm_->setEntry("base_link", "base_bellow_link", true);
142 this->cenv_->checkSelfCollision(req, res2, robot_state, *this->acm_);
143 ASSERT_FALSE(res2.collision);
144
145 // req.verbose = true;
146 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(Eigen::Isometry3d::Identity());
147 // robot_state.getLinkState("l_gripper_palm_link")->updateGivenGlobalLinkTransform(offset);
148 robot_state.updateStateWithLinkAt("r_gripper_palm_link", Eigen::Isometry3d::Identity());
149 robot_state.updateStateWithLinkAt("l_gripper_palm_link", offset);
150 robot_state.update();
151
152 this->acm_->setEntry("r_gripper_palm_link", "l_gripper_palm_link", false);
153 this->cenv_->checkSelfCollision(req, res3, robot_state, *this->acm_);
154 ASSERT_TRUE(res3.collision);
155}
156
158{
160 req.contacts = true;
161 req.max_contacts = 1;
162
163 moveit::core::RobotState robot_state(this->robot_model_);
164 robot_state.setToDefaultValues();
165 robot_state.update();
166
167 Eigen::Isometry3d offset = Eigen::Isometry3d::Identity();
168 offset.translation().x() = .01;
169
170 // robot_state.getLinkState("base_link")->updateGivenGlobalLinkTransform(Eigen::Isometry3d::Identity());
171 // robot_state.getLinkState("base_bellow_link")->updateGivenGlobalLinkTransform(offset);
172 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(Eigen::Isometry3d::Identity());
173 // robot_state.getLinkState("l_gripper_palm_link")->updateGivenGlobalLinkTransform(offset);
174
175 robot_state.updateStateWithLinkAt("base_link", Eigen::Isometry3d::Identity());
176 robot_state.updateStateWithLinkAt("base_bellow_link", offset);
177 robot_state.updateStateWithLinkAt("r_gripper_palm_link", Eigen::Isometry3d::Identity());
178 robot_state.updateStateWithLinkAt("l_gripper_palm_link", offset);
179 robot_state.update();
180
181 this->acm_->setEntry("base_link", "base_bellow_link", false);
182 this->acm_->setEntry("r_gripper_palm_link", "l_gripper_palm_link", false);
183
185 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
186 ASSERT_TRUE(res.collision);
187 EXPECT_EQ(res.contacts.size(), 1u);
188 EXPECT_EQ(res.contacts.begin()->second.size(), 1u);
189
190 res.clear();
191 req.max_contacts = 2;
192 req.max_contacts_per_pair = 1;
193 // req.verbose = true;
194 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
195 ASSERT_TRUE(res.collision);
196 EXPECT_EQ(res.contacts.size(), 2u);
197 EXPECT_EQ(res.contacts.begin()->second.size(), 1u);
198
199 res.contacts.clear();
200 res.contact_count = 0;
201
202 req.max_contacts = 10;
203 req.max_contacts_per_pair = 2;
204 this->acm_ =
205 std::make_shared<collision_detection::AllowedCollisionMatrix>(this->robot_model_->getLinkModelNames(), false);
206 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
207 ASSERT_TRUE(res.collision);
208 EXPECT_LE(res.contacts.size(), 10u);
209 EXPECT_LE(res.contact_count, 10u);
210}
211
213{
215 req.contacts = true;
216 req.max_contacts = 1;
217
218 moveit::core::RobotState robot_state(this->robot_model_);
219 robot_state.setToDefaultValues();
220 robot_state.update();
221
222 Eigen::Isometry3d pos1 = Eigen::Isometry3d::Identity();
223 Eigen::Isometry3d pos2 = Eigen::Isometry3d::Identity();
224
225 pos1.translation().x() = 5.0;
226 pos2.translation().x() = 5.01;
227
228 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(pos1);
229 // robot_state.getLinkState("l_gripper_palm_link")->updateGivenGlobalLinkTransform(pos2);
230 robot_state.updateStateWithLinkAt("r_gripper_palm_link", pos1);
231 robot_state.updateStateWithLinkAt("l_gripper_palm_link", pos2);
232 robot_state.update();
233
234 this->acm_->setEntry("r_gripper_palm_link", "l_gripper_palm_link", false);
235
237 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
238 ASSERT_TRUE(res.collision);
239 ASSERT_EQ(res.contacts.size(), 1u);
240 ASSERT_EQ(res.contacts.begin()->second.size(), 1u);
241
242 for (collision_detection::CollisionResult::ContactMap::const_iterator it = res.contacts.begin();
243 it != res.contacts.end(); ++it)
244 {
245 EXPECT_NEAR(it->second[0].pos.x(), 5.0, .33);
246 }
247
248 pos1 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond::Identity());
249 pos2 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) *
250 Eigen::Quaterniond(sqrt(1 - pow(0.258, 2)), 0.0, 0.258, 0.0));
251 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(pos1);
252 // robot_state.getLinkState("l_gripper_palm_link")->updateGivenGlobalLinkTransform(pos2);
253 robot_state.updateStateWithLinkAt("r_gripper_palm_link", pos1);
254 robot_state.updateStateWithLinkAt("l_gripper_palm_link", pos2);
255 robot_state.update();
256
258 this->cenv_->checkSelfCollision(req, res2, robot_state, *this->acm_);
259 ASSERT_TRUE(res2.collision);
260 ASSERT_EQ(res2.contacts.size(), 1u);
261 ASSERT_EQ(res2.contacts.begin()->second.size(), 1u);
262
263 for (collision_detection::CollisionResult::ContactMap::const_iterator it = res2.contacts.begin();
264 it != res2.contacts.end(); ++it)
265 {
266 EXPECT_NEAR(it->second[0].pos.x(), 3.0, 0.33);
267 }
268
269 pos1 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) * Eigen::Quaterniond::Identity());
270 pos2 = Eigen::Isometry3d(Eigen::Translation3d(3.0, 0.0, 0.0) *
271 Eigen::Quaterniond(M_PI / 4.0, 0.0, M_PI / 4.0, 0.0).normalized());
272 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(pos1);
273 // robot_state.getLinkState("l_gripper_palm_link")->updateGivenGlobalLinkTransform(pos2);
274 robot_state.updateStateWithLinkAt("r_gripper_palm_link", pos1);
275 robot_state.updateStateWithLinkAt("l_gripper_palm_link", pos2);
276 robot_state.update();
277
279 this->cenv_->checkSelfCollision(req, res2, robot_state, *this->acm_);
280 ASSERT_FALSE(res3.collision);
281}
282
284{
287
288 this->acm_ =
289 std::make_shared<collision_detection::AllowedCollisionMatrix>(this->robot_model_->getLinkModelNames(), true);
290
291 moveit::core::RobotState robot_state(this->robot_model_);
292 robot_state.setToDefaultValues();
293 robot_state.update();
294
295 Eigen::Isometry3d pos1 = Eigen::Isometry3d::Identity();
296 pos1.translation().x() = 5.0;
297
298 // robot_state.getLinkState("r_gripper_palm_link")->updateGivenGlobalLinkTransform(pos1);
299 robot_state.updateStateWithLinkAt("r_gripper_palm_link", pos1);
300 robot_state.update();
301 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
302 ASSERT_FALSE(res.collision);
303
304 shapes::Shape* shape = new shapes::Box(.1, .1, .1);
305 this->cenv_->getWorld()->addToObject("box", pos1, shapes::ShapeConstPtr(shape), Eigen::Isometry3d::Identity());
306
308 this->cenv_->checkRobotCollision(req, res, robot_state, *this->acm_);
309 ASSERT_TRUE(res.collision);
310
311 // deletes shape
312 this->cenv_->getWorld()->removeObject("box");
313
314 shape = new shapes::Box(.1, .1, .1);
315 std::vector<shapes::ShapeConstPtr> shapes;
316 EigenSTL::vector_Isometry3d poses;
317 shapes.push_back(shapes::ShapeConstPtr(shape));
318 poses.push_back(Eigen::Isometry3d::Identity());
319 std::vector<std::string> touch_links;
320 robot_state.attachBody("box", poses[0], shapes, poses, touch_links, "r_gripper_palm_link");
321
323 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
324 ASSERT_TRUE(res.collision);
325
326 // deletes shape
327 robot_state.clearAttachedBody("box");
328
329 touch_links.push_back("r_gripper_palm_link");
330 touch_links.push_back("r_gripper_motor_accelerometer_link");
331 shapes[0] = std::make_shared<shapes::Box>(.1, .1, .1);
332 robot_state.attachBody("box", poses[0], shapes, poses, touch_links, "r_gripper_palm_link");
333 robot_state.update();
334
336 this->cenv_->checkSelfCollision(req, res, robot_state, *this->acm_);
337 ASSERT_FALSE(res.collision);
338
339 pos1.translation().x() = 5.01;
340 shapes::Shape* coll = new shapes::Box(.1, .1, .1);
341 this->cenv_->getWorld()->addToObject("coll", pos1, shapes::ShapeConstPtr(coll), Eigen::Isometry3d::Identity());
343 this->cenv_->checkRobotCollision(req, res, robot_state, *this->acm_);
344 ASSERT_TRUE(res.collision);
345
346 this->acm_->setEntry("coll", "r_gripper_palm_link", true);
348 this->cenv_->checkRobotCollision(req, res, robot_state, *this->acm_);
349 ASSERT_TRUE(res.collision);
350}
351
353{
354 moveit::core::RobotState robot_state(this->robot_model_);
355 robot_state.setToDefaultValues();
356 robot_state.update();
357
360
361 collision_detection::CollisionEnvPtr new_cenv = this->value_->allocateEnv(this->cenv_, this->cenv_->getWorld());
362
363 auto before = std::chrono::system_clock::now();
364 new_cenv->checkSelfCollision(req, res, robot_state);
365 double first_check =
366 std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
367 before = std::chrono::system_clock::now();
368 new_cenv->checkSelfCollision(req, res, robot_state);
369 double second_check =
370 std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
371
372 EXPECT_TIME_LT(fabs(first_check - second_check), .05);
373
374 std::vector<shapes::ShapeConstPtr> shapes;
375 shapes.resize(1);
376
377 shapes[0].reset(shapes::createMeshFromResource(this->kinect_dae_resource_));
378
379 EigenSTL::vector_Isometry3d poses;
380 poses.push_back(Eigen::Isometry3d::Identity());
381
382 std::vector<std::string> touch_links;
383 robot_state.attachBody("kinect", poses[0], shapes, poses, touch_links, "r_gripper_palm_link");
384
385 before = std::chrono::system_clock::now();
386 new_cenv->checkSelfCollision(req, res, robot_state);
387 first_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
388 before = std::chrono::system_clock::now();
389 new_cenv->checkSelfCollision(req, res, robot_state);
390 second_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
391
392 // the first check is going to take a while, as data must be constructed
393 EXPECT_TIME_LT(second_check, .1);
394
395 collision_detection::CollisionEnvPtr other_new_cenv = this->value_->allocateEnv(this->cenv_, this->cenv_->getWorld());
396 before = std::chrono::system_clock::now();
397 new_cenv->checkSelfCollision(req, res, robot_state);
398 first_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
399 before = std::chrono::system_clock::now();
400 new_cenv->checkSelfCollision(req, res, robot_state);
401 second_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
402
403 EXPECT_TIME_LT(fabs(first_check - second_check), .05);
404}
405
406TYPED_TEST_P(CollisionDetectorTest, ConvertObjectToAttached)
407{
410
411 shapes::ShapeConstPtr shape(shapes::createMeshFromResource(this->kinect_dae_resource_));
412 Eigen::Isometry3d pos1 = Eigen::Isometry3d::Identity();
413 Eigen::Isometry3d pos2 = Eigen::Isometry3d::Identity();
414 pos2.translation().x() = 10.0;
415
416 this->cenv_->getWorld()->addToObject("kinect", pos1, shape, Eigen::Isometry3d::Identity());
417
418 moveit::core::RobotState robot_state(this->robot_model_);
419 robot_state.setToDefaultValues();
420 robot_state.update();
421
422 auto before = std::chrono::system_clock::now();
423 this->cenv_->checkRobotCollision(req, res, robot_state);
424 double first_check =
425 std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
426 before = std::chrono::system_clock::now();
427 this->cenv_->checkRobotCollision(req, res, robot_state);
428 double second_check =
429 std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
430
431 EXPECT_TIME_LT(second_check, .05);
432
433 collision_detection::CollisionEnv::ObjectConstPtr object = this->cenv_->getWorld()->getObject("kinect");
434 this->cenv_->getWorld()->removeObject("kinect");
435
436 moveit::core::RobotState robot_state1(this->robot_model_);
437 moveit::core::RobotState robot_state2(this->robot_model_);
438 robot_state1.setToDefaultValues();
439 robot_state2.setToDefaultValues();
440 robot_state1.update();
441 robot_state2.update();
442
443 std::vector<std::string> touch_links;
444 Eigen::Isometry3d identity_transform{ Eigen::Isometry3d::Identity() };
445 robot_state1.attachBody("kinect", identity_transform, object->shapes_, object->shape_poses_, touch_links,
446 "r_gripper_palm_link");
447
448 EigenSTL::vector_Isometry3d other_poses;
449 other_poses.push_back(pos2);
450
451 // This creates a new set of constant properties for the attached body, which happens to be the same as the one above;
452 robot_state2.attachBody("kinect", identity_transform, object->shapes_, object->shape_poses_, touch_links,
453 "r_gripper_palm_link");
454
455 // going to take a while, but that's fine
457 this->cenv_->checkSelfCollision(req, res, robot_state1);
458
459 EXPECT_TRUE(res.collision);
460
461 before = std::chrono::system_clock::now();
462 this->cenv_->checkSelfCollision(req, res, robot_state1, *this->acm_);
463 first_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
464 before = std::chrono::system_clock::now();
465 req.verbose = true;
467 this->cenv_->checkSelfCollision(req, res, robot_state2, *this->acm_);
468 second_check = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - before).count();
469
470 EXPECT_TIME_LT(first_check, .05);
471 EXPECT_TIME_LT(fabs(first_check - second_check), .1);
472}
473
474TYPED_TEST_P(CollisionDetectorTest, TestCollisionMapAdditionSpeed)
475{
476 EigenSTL::vector_Isometry3d poses;
477 std::vector<shapes::ShapeConstPtr> shapes;
478 for (unsigned int i = 0; i < 10000; ++i)
479 {
480 poses.push_back(Eigen::Isometry3d::Identity());
481 shapes.push_back(std::make_shared<shapes::Box>(.01, .01, .01));
482 }
483 auto start = std::chrono::system_clock::now();
484 this->cenv_->getWorld()->addToObject("map", shapes, poses);
485 double t = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - start).count();
486 // TODO (j-petit): investigate why bullet collision checking is considerably slower here
487 EXPECT_TIME_LT(t, 5.0);
488 // this is not really a failure; it is just that slow;
489 // looking into doing collision checking with a voxel grid.
490 RCLCPP_INFO(rclcpp::get_logger("moveit.core.collision_detection.bullet"), "Adding boxes took %g", t);
491}
492
494{
495 moveit::core::RobotState robot_state1(this->robot_model_);
496 robot_state1.setToDefaultValues();
497 robot_state1.update();
498
499 Eigen::Isometry3d kinect_pose;
500 kinect_pose.setIdentity();
501 shapes::ShapePtr kinect_shape;
502 kinect_shape.reset(shapes::createMeshFromResource(this->kinect_dae_resource_));
503
504 this->cenv_->getWorld()->addToObject("kinect", kinect_shape, kinect_pose);
505
506 Eigen::Isometry3d np;
507 for (unsigned int i = 0; i < 5; ++i)
508 {
509 np = Eigen::Translation3d(i * .001, i * .001, i * .001) * Eigen::Quaterniond::Identity();
510 this->cenv_->getWorld()->moveShapeInObject("kinect", kinect_shape, np);
513 this->cenv_->checkCollision(req, res, robot_state1, *this->acm_);
514 }
515}
516
517TYPED_TEST_P(CollisionDetectorTest, TestChangingShapeSize)
518{
519 moveit::core::RobotState robot_state1(this->robot_model_);
520 robot_state1.setToDefaultValues();
521 robot_state1.update();
522
525
526 ASSERT_FALSE(res1.collision);
527
528 EigenSTL::vector_Isometry3d poses;
529 std::vector<shapes::ShapeConstPtr> shapes;
530 for (unsigned int i = 0; i < 5; ++i)
531 {
532 this->cenv_->getWorld()->removeObject("shape");
533 shapes.clear();
534 poses.clear();
535 shapes.push_back(std::make_shared<const shapes::Box>(1 + i * .0001, 1 + i * .0001, 1 + i * .0001));
536 poses.push_back(Eigen::Isometry3d::Identity());
537 this->cenv_->getWorld()->addToObject("shape", shapes, poses);
540 this->cenv_->checkCollision(req, res, robot_state1, *this->acm_);
541 ASSERT_TRUE(res.collision);
542 }
543
544 Eigen::Isometry3d kinect_pose = Eigen::Isometry3d::Identity();
545 shapes::ShapePtr kinect_shape;
546 kinect_shape.reset(shapes::createMeshFromResource(this->kinect_dae_resource_));
547 this->cenv_->getWorld()->addToObject("kinect", kinect_shape, kinect_pose);
550 this->cenv_->checkCollision(req2, res2, robot_state1, *this->acm_);
551 ASSERT_TRUE(res2.collision);
552 for (unsigned int i = 0; i < 5; ++i)
553 {
554 this->cenv_->getWorld()->removeObject("shape");
555 shapes.clear();
556 poses.clear();
557 shapes.push_back(std::make_shared<shapes::Box>(1 + i * .0001, 1 + i * .0001, 1 + i * .0001));
558 poses.push_back(Eigen::Isometry3d::Identity());
559 this->cenv_->getWorld()->addToObject("shape", shapes, poses);
562 this->cenv_->checkCollision(req, res, robot_state1, *this->acm_);
563 ASSERT_TRUE(res.collision);
564 }
565}
566
567REGISTER_TYPED_TEST_SUITE_P(CollisionDetectorTest, InitOK, DefaultNotInCollision, LinksInCollision, ContactReporting,
568 ContactPositions, AttachedBodyTester, DiffSceneTester, ConvertObjectToAttached,
569 TestCollisionMapAdditionSpeed, MoveMesh, TestChangingShapeSize);
collision_detection::CollisionEnvPtr cenv_
moveit::core::RobotModelPtr robot_model_
std::shared_ptr< CollisionAllocatorType > value_
collision_detection::AllowedCollisionMatrixPtr acm_
World::ObjectConstPtr ObjectConstPtr
Representation of a robot's state. This includes position, velocity, acceleration and effort.
Definition robot_state.h:90
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.
Definition world.h:49
Representation of a collision checking request.
bool verbose
Flag indicating whether information about detected collisions should be reported.
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.
TYPED_TEST_P(CollisionDetectorTest, InitOK)
TYPED_TEST_CASE_P(CollisionDetectorTest)
REGISTER_TYPED_TEST_SUITE_P(CollisionDetectorTest, InitOK, DefaultNotInCollision, LinksInCollision, ContactReporting, ContactPositions, AttachedBodyTester, DiffSceneTester, ConvertObjectToAttached, TestCollisionMapAdditionSpeed, MoveMesh, TestChangingShapeSize)
#define EXPECT_TIME_LT(EXPR, VAL)