15 #include "nav2_mppi_controller/critics/twirling_critic.hpp"
17 #include <Eigen/Dense>
19 namespace mppi::critics
24 auto getParentParam = parameters_handler_->
getParamGetter(parent_name_);
25 getParentParam(enforce_path_inversion_,
"enforce_path_inversion",
false);
29 getParam(power_,
"cost_power", 1);
30 getParam(weight_,
"cost_weight", 10.0f);
33 logger_,
"TwirlingCritic instantiated with %d power and %f weight.", power_, weight_);
42 geometry_msgs::msg::Pose goal = utils::getCriticGoal(data, enforce_path_inversion_);
44 if (utils::withinPositionGoalTolerance(
45 data.goal_checker, data.state.pose.pose, goal))
51 data.costs += ((data.state.wz.abs().rowwise().mean()) * weight_).pow(power_).eval();
53 data.costs += ((data.state.wz.abs().rowwise().mean()) * weight_).eval();
59 #include <pluginlib/class_list_macros.hpp>
61 PLUGINLIB_EXPORT_CLASS(
auto getParamGetter(const std::string &ns)
Get an object to retrieve parameters.
Abstract critic objective function to score trajectories.
void initialize() override
Initialize critic.
void score(CriticData &data) override
Evaluate cost related to robot orientation at goal pose (considered only if robot near last goal in c...
Data to pass to critics for scoring, including state, trajectories, pruned path, global goal,...