Skip to content

Commit

Permalink
Merge branch 'main' into pr-cost_function_interface
Browse files Browse the repository at this point in the history
  • Loading branch information
sjahr authored Oct 27, 2023
2 parents 954dc76 + 7fba8c6 commit d95e6e2
Show file tree
Hide file tree
Showing 33 changed files with 585 additions and 184 deletions.
8 changes: 4 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ The [MoveIt Motion Planning Framework for ROS 2](http://moveit.ros.org). For the

## Getting Started

See our extensive [Tutorials and Documentation](https://moveit.picknik.ai/)
See our extensive [Tutorials and Documentation](https://moveit.picknik.ai/).

## Install

Expand All @@ -36,15 +36,15 @@ This open source project is maintained by supporters from around the world — s
</a>

[PickNik Inc](https://picknik.ai/) is leading the development of MoveIt.
If you would like to support this project, please contact [email protected]
If you would like to support this project, please contact [email protected].

<a href="http://rosin-project.eu">
<img src="http://rosin-project.eu/wp-content/uploads/rosin_ack_logo_wide.png"
alt="rosin_logo" height="60" >
</a>

The port to ROS 2 was supported by ROSIN - ROS-Industrial Quality-Assured Robot Software Components.
More information: <a href="http://rosin-project.eu">rosin-project.eu</a>
More information: <a href="http://rosin-project.eu">rosin-project.eu</a>.

<img src="http://rosin-project.eu/wp-content/uploads/rosin_eu_flag.jpg"
alt="eu_flag" height="45" align="left" >
Expand All @@ -53,7 +53,7 @@ This project has received funding from the European Union’s Horizon 2020
research and innovation programme under grant agreement no. 732287.

## Generate API Doxygen Documentation
See [How To Generate API Doxygen Reference Locally](https://moveit.picknik.ai/main/doc/how_to_guides/how_to_generate_api_doxygen_locally.html)
See [How To Generate API Doxygen Reference Locally](https://moveit.picknik.ai/main/doc/how_to_guides/how_to_generate_api_doxygen_locally.html).

# Buildfarm
| Package | Humble Binary | Iron Binary | Rolling Binary |
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ struct Contact
Eigen::Vector3d normal;

/** \brief depth (penetration between bodies) */
double depth;
double depth = 0.0;

/** \brief The id of the first body involved in the contact */
std::string body_name_1;
Expand All @@ -99,7 +99,7 @@ struct Contact
*
* If the value is 0, then the collision occurred in the start pose. If the value is 1, then the collision occurred
* in the end pose. */
double percent_interpolation;
double percent_interpolation = 0.0;

/** \brief The two nearest points connecting the two bodies */
Eigen::Vector3d nearest_points[2];
Expand All @@ -116,7 +116,7 @@ struct CostSource
std::array<double, 3> aabb_max;

/// The partial cost (the probability of existence for the object there is a collision with)
double cost;
double cost = 0.0;

/// Get the volume of the AABB around the cost source
double getVolume() const
Expand Down Expand Up @@ -144,9 +144,6 @@ struct CostSource
/** \brief Representation of a collision checking result */
struct CollisionResult
{
CollisionResult() : collision(false), distance(std::numeric_limits<double>::max()), contact_count(0)
{
}
using ContactMap = std::map<std::pair<std::string, std::string>, std::vector<Contact> >;

EIGEN_MAKE_ALIGNED_OPERATOR_NEW
Expand All @@ -165,13 +162,13 @@ struct CollisionResult
void print() const;

/** \brief True if collision was found, false otherwise */
bool collision;
bool collision = false;

/** \brief Closest distance between two bodies */
double distance;
double distance = std::numeric_limits<double>::max();

/** \brief Number of contacts returned */
std::size_t contact_count;
std::size_t contact_count = 0;

/** \brief A map returning the pairs of body ids in contact, plus their contact details */
ContactMap contacts;
Expand All @@ -183,47 +180,34 @@ struct CollisionResult
/** \brief Representation of a collision checking request */
struct CollisionRequest
{
CollisionRequest()
: distance(false)
, cost(false)
, contacts(false)
, max_contacts(1)
, max_contacts_per_pair(1)
, max_cost_sources(1)
, verbose(false)
{
}
virtual ~CollisionRequest()
{
}

/** \brief The group name to check collisions for (optional; if empty, assume the complete robot). Descendent links are included. */
std::string group_name;
/** \brief The group name to check collisions for (optional; if empty, assume the complete robot). Descendent links
* are included. */
std::string group_name = "";

/** \brief If true, compute proximity distance */
bool distance;
bool distance = false;

/** \brief If true, a collision cost is computed */
bool cost;
bool cost = false;

/** \brief If true, compute contacts. Otherwise only a binary collision yes/no is reported. */
bool contacts;
bool contacts = false;

/** \brief Overall maximum number of contacts to compute */
std::size_t max_contacts;
std::size_t max_contacts = 1;

/** \brief Maximum number of contacts to compute per pair of bodies (multiple bodies may be in contact at different
* configurations) */
std::size_t max_contacts_per_pair;
std::size_t max_contacts_per_pair = 1;

/** \brief When costs are computed, this value defines how many of the top cost sources should be returned */
std::size_t max_cost_sources;
std::size_t max_cost_sources = 1;

/** \brief Function call that decides whether collision detection should stop. */
std::function<bool(const CollisionResult&)> is_done;
std::function<bool(const CollisionResult&)> is_done = nullptr;

/** \brief Flag indicating whether information about detected collisions should be reported */
bool verbose;
bool verbose = false;
};

namespace DistanceRequestTypes
Expand All @@ -241,19 +225,6 @@ using DistanceRequestType = DistanceRequestTypes::DistanceRequestType;
/** \brief Representation of a distance-reporting request */
struct DistanceRequest
{
DistanceRequest()
: enable_nearest_points(false)
, enable_signed_distance(false)
, type(DistanceRequestType::GLOBAL)
, max_contacts_per_body(1)
, active_components_only(nullptr)
, acm(nullptr)
, distance_threshold(std::numeric_limits<double>::max())
, verbose(false)
, compute_gradient(false)
{
}

/*** \brief Compute \e active_components_only_ based on \e req_. This
includes links that are in the kinematic model but outside this group, if those links are descendants of
joints in this group that have their values updated. */
Expand All @@ -270,38 +241,38 @@ struct DistanceRequest
}

/// Indicate if nearest point information should be calculated
bool enable_nearest_points;
bool enable_nearest_points = false;

/// Indicate if a signed distance should be calculated in a collision.
bool enable_signed_distance;
bool enable_signed_distance = false;

/// Indicate the type of distance request. If using type=ALL, it is
/// recommended to set max_contacts_per_body to the expected number
/// of contacts per pair because it is used to reserve space.
DistanceRequestType type;
DistanceRequestType type = DistanceRequestType::GLOBAL;

/// Maximum number of contacts to store for bodies (multiple bodies may be within distance threshold)
std::size_t max_contacts_per_body;
std::size_t max_contacts_per_body = 1;

/// The group name
std::string group_name;
std::string group_name = "";

/// The set of active components to check
const std::set<const moveit::core::LinkModel*>* active_components_only;
const std::set<const moveit::core::LinkModel*>* active_components_only = nullptr;

/// The allowed collision matrix used to filter checks
const AllowedCollisionMatrix* acm;
const AllowedCollisionMatrix* acm = nullptr;

/// Only calculate distances for objects within this threshold to each other.
/// If set, this can significantly reduce the number of queries.
double distance_threshold;
double distance_threshold = std::numeric_limits<double>::max();

/// Log debug information
bool verbose;
bool verbose = false;

/// Indicate if gradient should be calculated between each object.
/// This is the normalized vector connecting the closest points on the two objects.
bool compute_gradient;
bool compute_gradient = false;
};

/** \brief Generic representation of the distance information for a pair of objects */
Expand Down Expand Up @@ -366,12 +337,8 @@ using DistanceMap = std::map<const std::pair<std::string, std::string>, std::vec
/** \brief Result of a distance request. */
struct DistanceResult
{
DistanceResult() : collision(false)
{
}

/// Indicates if two objects were in collision
bool collision;
bool collision = false;

/// ResultsData for the two objects with the minimum distance
DistanceResultsData minimum_distance;
Expand Down
3 changes: 3 additions & 0 deletions moveit_core/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,9 @@
<test_depend>ament_cmake_gtest</test_depend>
<test_depend>ament_cmake_gmock</test_depend>
<test_depend>ament_index_cpp</test_depend>
<test_depend>launch_testing_ament_cmake</test_depend>
<test_depend>rclpy</test_depend>
<test_depend>rcl_interfaces</test_depend>

<test_depend>ament_lint_auto</test_depend>
<test_depend>ament_lint_common</test_depend>
Expand Down
8 changes: 7 additions & 1 deletion moveit_core/utils/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,13 @@ add_library(moveit_utils SHARED
src/lexical_casts.cpp
src/message_checks.cpp
src/rclcpp_utils.cpp
src/logger.cpp
)
target_include_directories(moveit_utils PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
$<INSTALL_INTERFACE:include/moveit_core>
)
ament_target_dependencies(moveit_utils Boost moveit_msgs)
ament_target_dependencies(moveit_utils Boost moveit_msgs rclcpp)
set_target_properties(moveit_utils PROPERTIES VERSION "${${PROJECT_NAME}_VERSION}")

install(DIRECTORY include/ DESTINATION include/moveit_core)
Expand All @@ -28,5 +29,10 @@ ament_target_dependencies(moveit_test_utils
srdfdom
urdfdom
urdfdom_headers
rclcpp
)
set_target_properties(moveit_test_utils PROPERTIES VERSION "${${PROJECT_NAME}_VERSION}")

if(BUILD_TESTING)
add_subdirectory(test)
endif()
57 changes: 57 additions & 0 deletions moveit_core/utils/include/moveit/utils/logger.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
/*********************************************************************
* Software License Agreement (BSD License)
*
* Copyright (c) 2023, PickNik Robotics Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of PickNik Robotics Inc. nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*********************************************************************/

/* Author: Tyler Weaver */

#pragma once

#include <rclcpp/logger.hpp>
#include <string>

namespace moveit
{

// Function for getting a reference to a logger object kept in a global variable.
// Use get_logger_mut to set the logger to a node logger.
const rclcpp::Logger& get_logger();

// Function for getting a child logger. In Humble this also creates a node.
// Do not use this in place as it will create a new logger each time,
// instead store it in the state of your class or method.
rclcpp::Logger make_child_logger(const std::string& name);

// Mutable access to global logger for setting to node logger.
rclcpp::Logger& get_logger_mut();

} // namespace moveit
Loading

0 comments on commit d95e6e2

Please sign in to comment.