Skip to content

Commit

Permalink
Merge pull request #307 from roveri-marco/add_parameter_for_timeout_o…
Browse files Browse the repository at this point in the history
…f_plan_solver

Add parameter for timeout of plan solver
  • Loading branch information
fmrico authored Apr 7, 2024
2 parents 1d4b405 + 5a55251 commit 6b93bb1
Show file tree
Hide file tree
Showing 9 changed files with 66 additions and 9 deletions.
4 changes: 4 additions & 0 deletions plansys2_bringup/params/plansys2_params.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
planner_client:
ros__parameters:
plan_solver_timeout: 15.0
planner:
ros__parameters:
plan_solver_timeout: 15.0
plan_solver_plugins: ["POPF"]
POPF:
plugin: "plansys2/POPFPlanSolver"
Expand Down
5 changes: 4 additions & 1 deletion plansys2_core/include/plansys2_core/PlanSolverBase.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@
#include "rclcpp/rclcpp.hpp"
#include "rclcpp_lifecycle/lifecycle_node.hpp"

using namespace std::chrono_literals;

namespace plansys2
{

Expand Down Expand Up @@ -52,7 +54,8 @@ class PlanSolverBase
*/
virtual std::optional<plansys2_msgs::msg::Plan> getPlan(
const std::string & domain, const std::string & problem,
const std::string & node_namespace = "") = 0;
const std::string & node_namespace = "",
const rclcpp::Duration solver_timeout = 15s) = 0;

/**
* @brief Exposes a capability to validate a PDDL domain.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ class PlannerClient : public PlannerInterface
get_plan_client_;

rclcpp::Node::SharedPtr node_;
rclcpp::Duration solver_timeout_ = rclcpp::Duration(15, 0);
};

} // namespace plansys2
Expand Down
1 change: 1 addition & 0 deletions plansys2_planner/include/plansys2_planner/PlannerNode.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ class PlannerNode : public rclcpp_lifecycle::LifecycleNode
std::vector<std::string> default_types_;
std::vector<std::string> solver_ids_;
std::vector<std::string> solver_types_;
rclcpp::Duration solver_timeout_;

rclcpp::Service<plansys2_msgs::srv::GetPlan>::SharedPtr
get_plan_service_;
Expand Down
31 changes: 28 additions & 3 deletions plansys2_planner/src/plansys2_planner/PlannerClient.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,15 @@ PlannerClient::PlannerClient()
node_ = rclcpp::Node::make_shared("planner_client");

get_plan_client_ = node_->create_client<plansys2_msgs::srv::GetPlan>("planner/get_plan");

double timeout;
node_->declare_parameter("plan_solver_timeout", timeout);

node_->get_parameter("plan_solver_timeout", timeout);
solver_timeout_ = rclcpp::Duration((int32_t)timeout, 0);
RCLCPP_INFO(
node_->get_logger(), "Planner CLient created with timeout %g",
solver_timeout_.seconds());
}

std::optional<plansys2_msgs::msg::Plan>
Expand All @@ -44,16 +53,32 @@ PlannerClient::getPlan(
get_plan_client_->get_service_name() <<
" service client: waiting for service to appear...");
}
int32_t timeout = solver_timeout_.seconds();
if (timeout <= 0) {
std::string timeout_str = "Get Plan service called with negative timed out:";
timeout_str += std::to_string(timeout);
timeout_str += ". Setting to 15 seconds";
RCLCPP_ERROR(node_->get_logger(), timeout_str.c_str());
timeout = 15;
}

RCLCPP_INFO(node_->get_logger(), "Get Plan service call with time out %d", timeout);

auto request = std::make_shared<plansys2_msgs::srv::GetPlan::Request>();
request->domain = domain;
request->problem = problem;

auto future_result = get_plan_client_->async_send_request(request);

if (rclcpp::spin_until_future_complete(node_, future_result, std::chrono::seconds(15)) !=
rclcpp::FutureReturnCode::SUCCESS)
{
auto outresult = rclcpp::spin_until_future_complete(
node_, future_result,
std::chrono::seconds(timeout));
if (outresult != rclcpp::FutureReturnCode::SUCCESS) {
if (outresult == rclcpp::FutureReturnCode::TIMEOUT) {
RCLCPP_ERROR(node_->get_logger(), "Get Plan service call timed out");
} else {
RCLCPP_ERROR(node_->get_logger(), "Get Plan service call failed");
}
return {};
}

Expand Down
17 changes: 14 additions & 3 deletions plansys2_planner/src/plansys2_planner/PlannerNode.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,16 +22,21 @@

#include "lifecycle_msgs/msg/state.hpp"

using namespace std::chrono_literals;

namespace plansys2
{

PlannerNode::PlannerNode()
: rclcpp_lifecycle::LifecycleNode("planner"),
lp_loader_("plansys2_core", "plansys2::PlanSolverBase"),
default_ids_{},
default_types_{}
default_types_{},
solver_timeout_(15s)
{
declare_parameter("plan_solver_plugins", default_ids_);
double timeout = solver_timeout_.seconds();
declare_parameter("plan_solver_timeout", timeout);
}


Expand All @@ -42,10 +47,14 @@ CallbackReturnT
PlannerNode::on_configure(const rclcpp_lifecycle::State & state)
{
auto node = shared_from_this();
double timeout;

RCLCPP_INFO(get_logger(), "[%s] Configuring...", get_name());

get_parameter("plan_solver_plugins", solver_ids_);
get_parameter("plan_solver_timeout", timeout);

solver_timeout_ = rclcpp::Duration((int32_t)timeout, 0);

if (!solver_ids_.empty()) {
if (solver_ids_ == default_ids_) {
Expand Down Expand Up @@ -83,6 +92,8 @@ PlannerNode::on_configure(const rclcpp_lifecycle::State & state)
"POPF", "plansys2/POPFPlanSolver");
}

RCLCPP_INFO(get_logger(), "[%s] Solver Timeout %g", get_name(), solver_timeout_.seconds());

get_plan_service_ = create_service<plansys2_msgs::srv::GetPlan>(
"planner/get_plan",
std::bind(
Expand Down Expand Up @@ -150,8 +161,8 @@ PlannerNode::get_plan_service_callback(
const std::shared_ptr<plansys2_msgs::srv::GetPlan::Request> request,
const std::shared_ptr<plansys2_msgs::srv::GetPlan::Response> response)
{
const auto plan = solvers_.begin()->second->getPlan(
request->domain, request->problem, get_namespace());
auto plan = solvers_.begin()->second->getPlan(
request->domain, request->problem, get_namespace(), solver_timeout_);

if (plan) {
response->success = true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@

#include "plansys2_core/PlanSolverBase.hpp"

// using namespace std::chrono_literals;
using std::chrono_literals::operator""s;

namespace plansys2
{

Expand All @@ -41,7 +44,8 @@ class POPFPlanSolver : public PlanSolverBase

std::optional<plansys2_msgs::msg::Plan> getPlan(
const std::string & domain, const std::string & problem,
const std::string & node_namespace = "");
const std::string & node_namespace = "",
const rclcpp::Duration solver_timeout = 15s);

bool isDomainValid(
const std::string & domain,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,8 @@ void POPFPlanSolver::configure(
std::optional<plansys2_msgs::msg::Plan>
POPFPlanSolver::getPlan(
const std::string & domain, const std::string & problem,
const std::string & node_namespace)
const std::string & node_namespace,
const rclcpp::Duration solver_timeout)
{
if (system(nullptr) == 0) {
return {};
Expand Down Expand Up @@ -111,6 +112,10 @@ POPFPlanSolver::getPlan(
problem_out << problem;
problem_out.close();

RCLCPP_INFO(
lc_node_->get_logger(), "[%s-popf] called with timeout %d seconds",
lc_node_->get_name(), solver_timeout.seconds());

const auto plan_file_path = output_dir / std::filesystem::path("plan");
const auto args = lc_node_->get_parameter(arguments_parameter_name_).value_to_string();
const int status = system(
Expand Down
3 changes: 3 additions & 0 deletions plansys2_terminal/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,6 @@ The Plansys2 Terminal module is a tool to directly monitor and edit your applica

The node is created inside a Terminal object, which starts a looping run_console() method reading the terminal input and calling the corresponding services and actions.

To enable for using parameters specified in a YAML file for e.g. specifying the timeout for the planner and planner client, you can use the following command:
``ros2 run plansys2_terminal plansys2_terminal --ros-args --params-file `ros2 pkg prefix --share plansys2_bringup`/params/plansys2_params.yaml``

0 comments on commit 6b93bb1

Please sign in to comment.