Skip to content

Commit

Permalink
This stage uses action messages to communicate with an action server …
Browse files Browse the repository at this point in the history
…external to MTC.

The action server can use machine learning pipelines to sample grasps given a point cloud/depth image.
This removes complex dependencies from MTC. The stage sends a request for grasps. If a time out is reached or no grasps are found then planning fails.
This stage uses a template parameter which is the action message and inherits from an action base class.
This allows other stages to inherit these properties and use action messages.
  • Loading branch information
bostoncleek committed Mar 11, 2021
1 parent f99d033 commit 7717231
Show file tree
Hide file tree
Showing 9 changed files with 459 additions and 2 deletions.
2 changes: 2 additions & 0 deletions core/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ project(moveit_task_constructor_core)

find_package(Boost REQUIRED)
find_package(catkin REQUIRED COMPONENTS
actionlib
eigen_conversions
geometry_msgs
moveit_core
Expand All @@ -24,6 +25,7 @@ catkin_package(
geometry_msgs
moveit_core
moveit_task_constructor_msgs
rviz_marker_tools
visualization_msgs
)

Expand Down
126 changes: 126 additions & 0 deletions core/include/moveit/task_constructor/stages/action_base.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,126 @@
/*********************************************************************
* BSD 3-Clause License
*
* Copyright (c) 2020 PickNik 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 the copyright holder 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 HOLDER 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: Boston Cleek
Desc: Abstact class for stages using a simple action client.
*/

#pragma once

#include <memory>
#include <string>
#include <limits>

#include <actionlib/client/simple_action_client.h>

namespace moveit {
namespace task_constructor {
namespace stages {

/**
* @brief Interface allowing stages to use a simple action client
* @param ActionSpec - action message (action message name + "ACTION")
* @details Some stages may require an action client. This class wraps the
* simple client action interface and exposes event based execution callbacks.
*/
template <class ActionSpec>
class ActionBase
{
protected:
ACTION_DEFINITION(ActionSpec);

public:
/**
* @brief Constructor
* @param action_name - action namespace
* @param spin_thread - spins a thread to service this action's subscriptions
* @param goal_timeout - goal to completed time out (0 is considered infinite timeout)
* @param server_timeout - connection to server time out (0 is considered infinite timeout)
* @details Initialize the action client and time out parameters
*/
ActionBase(const std::string& action_name, bool spin_thread, double goal_timeout, double server_timeout);

/**
* @brief Constructor
* @param action_name - action namespace
* @param spin_thread - spins a thread to service this action's subscriptions
* @details Initialize the action client and time out parameters to infinity
*/
ActionBase(const std::string& action_name, bool spin_thread);

/* @brief Destructor */
virtual ~ActionBase() = default;

/* @brief Called when goal becomes active */
virtual void activeCallback() = 0;

/**
* @brief Called every time feedback is received for the goal
* @param feedback - pointer to the feedback message
*/
virtual void feedbackCallback(const FeedbackConstPtr& feedback) = 0;

/**
* @brief Called once when the goal completes
* @param state - state info for goal
* @param result - pointer to result message
*/
virtual void doneCallback(const actionlib::SimpleClientGoalState& state, const ResultConstPtr& result) = 0;

protected:
ros::NodeHandle nh_;
std::string action_name_; // action name space
std::unique_ptr<actionlib::SimpleActionClient<ActionSpec>> clientPtr_; // action client
double server_timeout_, goal_timeout_; // connection and goal completed time out
};

template <class ActionSpec>
ActionBase<ActionSpec>::ActionBase(const std::string& action_name, bool spin_thread, double goal_timeout,
double server_timeout)
: action_name_(action_name), server_timeout_(server_timeout), goal_timeout_(goal_timeout) {
clientPtr_.reset(new actionlib::SimpleActionClient<ActionSpec>(nh_, action_name_, spin_thread));

// Negative timeouts are set to zero
server_timeout_ = server_timeout_ < std::numeric_limits<double>::epsilon() ? 0.0 : server_timeout_;
goal_timeout_ = goal_timeout_ < std::numeric_limits<double>::epsilon() ? 0.0 : goal_timeout_;
}

template <class ActionSpec>
ActionBase<ActionSpec>::ActionBase(const std::string& action_name, bool spin_thread)
: action_name_(action_name), server_timeout_(0.0), goal_timeout_(0.0) {
clientPtr_.reset(new actionlib::SimpleActionClient<ActionSpec>(nh_, action_name_, spin_thread));
}

} // namespace stages
} // namespace task_constructor
} // namespace moveit

Loading

0 comments on commit 7717231

Please sign in to comment.