2023-09-04 14:38:39 +00:00
|
|
|
#include <chrono>
|
|
|
|
#include <functional>
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include <Eigen/Geometry>
|
|
|
|
|
|
|
|
#include <rclcpp/rclcpp.hpp>
|
|
|
|
#include "moveit_msgs/msg/robot_trajectory.hpp"
|
|
|
|
#include "geometry_msgs/msg/pose_array.hpp"
|
|
|
|
|
|
|
|
#include "std_msgs/msg/empty.hpp"
|
|
|
|
|
|
|
|
#include "moveit/move_group_interface/move_group_interface.h"
|
|
|
|
#include "moveit_visual_tools/moveit_visual_tools.h"
|
2023-09-05 11:35:50 +00:00
|
|
|
#include "moveit/robot_model_loader/robot_model_loader.h"
|
2023-09-04 14:38:39 +00:00
|
|
|
|
|
|
|
using namespace std::chrono_literals;
|
|
|
|
|
|
|
|
class MoveitInterface : public rclcpp::Node
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
MoveitInterface()
|
|
|
|
: Node("moveit_interface"), trajectory_set(false)
|
|
|
|
{
|
|
|
|
publisher_ = this->create_publisher<moveit_msgs::msg::RobotTrajectory>("moveit_interface/joint_space_trajectory", 10);
|
|
|
|
subcriber_ = this->create_subscription<geometry_msgs::msg::PoseArray>("moveit_interface/task_space_trajectory", 10, std::bind(&MoveitInterface::task_space_callback, this, std::placeholders::_1));
|
|
|
|
execute_sub_ = this->create_subscription<std_msgs::msg::Empty>("moveit_interface/execution", 10, std::bind(&MoveitInterface::execution_callback, this, std::placeholders::_1));
|
2023-09-04 17:32:14 +00:00
|
|
|
|
|
|
|
// Create a shared instance of the current node
|
|
|
|
auto shared_this = std::shared_ptr<rclcpp::Node>(this);
|
|
|
|
|
2023-09-04 14:38:39 +00:00
|
|
|
// Connecting to moveit
|
|
|
|
static const std::string PLANNING_GROUP = "panda_arm";
|
2023-09-05 11:35:50 +00:00
|
|
|
|
2023-09-05 13:45:59 +00:00
|
|
|
// robot_model_loader = std::make_shared<robot_model_loader::RobotModelLoader>(std::shared_ptr<rclcpp::Node>(shared_this), "robot_description");
|
|
|
|
// const moveit::core::RobotModelPtr& robot_model = robot_model_loader->getModel();
|
|
|
|
// robot_state = std::make_shared<moveit::core::RobotState>(robot_model);
|
|
|
|
// const moveit::core::JointModelGroup* joint_model_group = robot_state->getJointModelGroup(PLANNING_GROUP);
|
|
|
|
//
|
|
|
|
// planning_scene = std::make_shared<planning_scene::PlanningScene>(robot_model);
|
|
|
|
// planning_scene->getCurrentStateNonConst().setToDefaultValues(joint_model_group, "ready");
|
2023-09-05 11:35:50 +00:00
|
|
|
|
2023-09-04 17:32:14 +00:00
|
|
|
move_group_ = std::make_shared<moveit::planning_interface::MoveGroupInterface>(std::shared_ptr<rclcpp::Node>(shared_this), PLANNING_GROUP);
|
2023-09-04 14:38:39 +00:00
|
|
|
// const moveit::core::JointModelGroup* joint_model_group = move_group_->getCurrentState()->getJointModelGroup(PLANNING_GROUP);
|
|
|
|
|
|
|
|
// Connection to Rviz
|
2023-09-04 17:32:14 +00:00
|
|
|
visual_tools_ = std::make_shared<moveit_visual_tools::MoveItVisualTools>(std::shared_ptr<rclcpp::Node>(shared_this), "panda_link0", "move_group", move_group_->getRobotModel());
|
2023-09-04 14:38:39 +00:00
|
|
|
Eigen::Isometry3d text_pose = Eigen::Isometry3d::Identity();
|
|
|
|
text_pose.translation().z()=1.0;
|
|
|
|
visual_tools_->publishText(text_pose, "MoveGroupInterface_Demo", rviz_visual_tools::WHITE, rviz_visual_tools::XLARGE);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
void task_space_callback(const geometry_msgs::msg::PoseArray::SharedPtr msg)
|
|
|
|
{
|
2023-09-05 13:45:59 +00:00
|
|
|
// moveit::core::RobotState start_state(*move_group_->getCurrentState());
|
|
|
|
// move_group_->setStartState(start_state);
|
2023-09-04 14:38:39 +00:00
|
|
|
std::vector<geometry_msgs::msg::Pose> waypoints = msg->poses;
|
|
|
|
|
|
|
|
|
|
|
|
const double jump_threshold = 0.0;
|
|
|
|
const double eef_step = 0.001;
|
|
|
|
double fraction = move_group_->computeCartesianPath(waypoints, eef_step,jump_threshold, trajectory);
|
|
|
|
RCLCPP_INFO(logger, "Visualizing plan 4 (Cartesian path) (%.2f%% achieved)", fraction * 100.0);
|
|
|
|
|
|
|
|
visual_tools_->deleteAllMarkers();
|
|
|
|
visual_tools_->publishText(text_pose, "Cartesian_Path", rviz_visual_tools::WHITE, rviz_visual_tools::XLARGE);
|
|
|
|
visual_tools_->publishPath(waypoints, rviz_visual_tools::LIME_GREEN, rviz_visual_tools::SMALL);
|
|
|
|
|
|
|
|
trajectory_set = true;
|
|
|
|
|
|
|
|
|
|
|
|
publisher_->publish(trajectory);
|
|
|
|
}
|
|
|
|
void execution_callback(const std_msgs::msg::Empty::SharedPtr /*msg*/)
|
|
|
|
{
|
|
|
|
if(trajectory_set)
|
|
|
|
{
|
|
|
|
move_group_->execute(trajectory);
|
|
|
|
trajectory_set=false;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
RCLCPP_WARN(logger, "Trajectroy is not set. Unable to execute.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
rclcpp::Publisher<moveit_msgs::msg::RobotTrajectory>::SharedPtr publisher_;
|
|
|
|
rclcpp::Subscription<geometry_msgs::msg::PoseArray>::SharedPtr subcriber_;
|
|
|
|
rclcpp::Subscription<std_msgs::msg::Empty>::SharedPtr execute_sub_;
|
|
|
|
std::shared_ptr<moveit::planning_interface::MoveGroupInterface> move_group_;
|
|
|
|
std::shared_ptr<moveit_visual_tools::MoveItVisualTools> visual_tools_;
|
2023-09-05 11:35:50 +00:00
|
|
|
std::shared_ptr<robot_model_loader::RobotModelLoader> robot_model_loader;
|
|
|
|
std::shared_ptr<moveit::core::RobotState> robot_state;
|
|
|
|
std::shared_ptr<planning_scene::PlanningScene> planning_scene;
|
2023-09-04 14:38:39 +00:00
|
|
|
|
|
|
|
Eigen::Isometry3d text_pose;
|
|
|
|
moveit_msgs::msg::RobotTrajectory trajectory;
|
|
|
|
rclcpp::Logger logger = this->get_logger();
|
|
|
|
bool trajectory_set;
|
|
|
|
};
|
|
|
|
|
|
|
|
int main(int argc, char * argv[])
|
|
|
|
{
|
|
|
|
rclcpp::init(argc, argv);
|
|
|
|
rclcpp::spin(std::make_shared<MoveitInterface>());
|
|
|
|
rclcpp::shutdown();
|
|
|
|
return 0;
|
|
|
|
}
|