欢迎转载请注明出处:海漩涡
http://blog.csdn.net/tanhuifang520
pr2机器人手臂画圆
零、sudo apt-get install ros-indigo-pr2-desktop
一、cd ~/catkin_ws/src/
二、catkin_create_pkg pr2_draw_circle catkin cmake_modules interactive_markers moveit_core moveit_ros_perception moveit_ros_planning_interface pluginlib roscpp std_msgs
三、vi pr2_draw_circle/src/draw_circle.cpp
写入以下代码(cao了第一次在CSDN里贴代码,居然不会插入代码)
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include "ompl/util/Time.h"
#include
#include
#include
#include
#include
#include
#include
#include
typedef move_group_interface::MoveGroup C_moveGroup;
typedef moveit::planning_interface::MoveGroup::Plan S_Plan;
typedef moveit::planning_interface::PlanningSceneInterface S_PlanningSceneInterface;
void IK_action_one(C_moveGroup &group, double position_action[])
{
geometry_msgs::PoseStamped target_pose;
target_pose.header.frame_id = group.getPoseReferenceFrame();
target_pose.header.stamp = ros::Time::now();
target_pose.pose.position.x = position_action[0];
target_pose.pose.position.y = position_action[1];
target_pose.pose.position.z = position_action[2];
target_pose.pose.orientation.x = position_action[3];
target_pose.pose.orientation.y = position_action[4];
target_pose.pose.orientation.z = position_action[5];
target_pose.pose.orientation.w = position_action[6];
group.setPoseTarget(target_pose, group.getEndEffectorLink());
group.setStartStateToCurrentState() ;
group.move();
usleep(500000);
}
int discretize_circle(double circleCenter[], std::vector > &V_pose_value)
{
std::vector pose_value(7);
pose_value[0] = circleCenter[0];
pose_value[3] = circleCenter[3];
pose_value[4] = circleCenter[4];
pose_value[5] = circleCenter[5];
pose_value[6] = circleCenter[6];
double y_center = circleCenter[1];
double z_center = circleCenter[2];
double angle= 0;
double radius = 0.1;
double angle_resolution = 10; /* 两个采样点间的角度值,减小可提高轨迹规划成功率 */
double d_angle = angle_resolution*3.14/180; /* 两个采样点间的弧度值 */
// 采样圆上的点
for (int i= 0; i< (360/angle_resolution); i++)
{
angle+= d_angle;
pose_value[1] = y_center + radius*sin(angle);
pose_value[2] = z_center + radius*cos(angle);
V_pose_value.push_back(pose_value);
printf("%f %f %f %f %f %f %f \n",pose_value[0],pose_value[1],pose_value[2],pose_value[3],pose_value[4],pose_value[5],pose_value[6]);
}
return 0;
}
int draw_circle(C_moveGroup &group, double circleCenter[])
{
int i, j, len;
S_Plan plan;
std::vector > V_pose_value;
std::vector waypoints;
geometry_msgs::Pose ee_point_goal_tmp;
/* 采样圆上的点 */
discretize_circle(circleCenter, V_pose_value);
for(i=0; i
四、vi pr2_draw_circle/CMakeLists.txt
在末尾添加
aux_source_directory(./src src_list)
add_executable(draw ${src_list})
target_link_libraries(draw ${catkin_LIBRARIES})
add_dependencies(draw pr2_draw_circle_generate_messages_cpp)
五、cd ~/catkin_ws/;catkin_make
六、在虚拟机的桌面打开个终端运行命令:
roslaunch pr2_moveit_config demo.launch
你将看到pr2机器人
七、运行下面命令你将看到pr2机器人的左手在画圆了
rosrun pr2_draw_circle draw