5. Moveit moveit编程与空间规划

1.添加配置文件——controllers.yaml

关联了arm_controller控制器名称,follow_joint_trajectory命名空间,FollowJointTrajectory的action类型(规划轨迹是以action发布的),是否为默认控制器,与该规划组所包含的关节。

controller_list:
  - name: arm_controller
    action_ns: follow_joint_trajectory
    type: FollowJointTrajectory
    default: true
    joints:
      - joint1
      - joint2
      - joint3
      - joint4
      - joint5
      - joint6
      
  - name: gripper_controller
    action_ns: gripper_action
    type: GripperCommand
    default: true
    joints:
      - finger_joint1

注意!这个是后加的!这个个控制器是对标ArbotiX的,在配置助手创建config文件时,并不知道ArbotiX这个控制器,用的是moveit中的虚拟控制器,其中虚拟控制器如下,注意区分!细节在书中P323.

controller_list:
  - name: fake_arm_controller
    type: $(arg fake_execution_type)
    joints:
      - joint1
      - joint2
      - joint3
      - joint4
      - joint5
      - joint6
  - name: fake_gripper_controller
    type: $(arg fake_execution_type)
    joints:
      - finger_joint1
initial:  # Define initial robot poses.
  - group: arm
    pose: home

2.修改启动文件的launch文件

因为默认的是加载ros_controllers.yaml——这个是moveit配置助手的默认生成的,而我要用的是关于ArbotiX的控制器,故需要进行修改,将ros_去掉。修改后如下。同时注意<arg name=" " default=" ">  $(arg moveit_controller_manager)的方式。

<launch>
  <!-- Define the controller manager plugin to use for trajectory execution -->
  <param name="moveit_controller_manager" value="moveit_simple_controller_manager/MoveItSimpleControllerManager" />

  <!-- loads controller list to the param server -->
  <rosparam file="$(find marm_moveit_config)/config/controllers.yaml"/>
</launch>

3.关节空间规划

其launch文件

<launch>
    <!-- 不使用仿真时间 -->
    <param name="/use_sim_time" value="false" />

    <!-- 启动 arbotix driver-->
    <arg name="sim" default="true" />

    <param name="robot_description" command="$(find xacro)/xacro --inorder '$(find marm_description)/urdf/arm.xacro'" />

    <node name="arbotix" pkg="arbotix_python" type="arbotix_driver" output="screen">
        <rosparam file="$(find marm_description)/config/arm.yaml" command="load" />
        <param name="sim" value="true"/>
    </node>

    <node name="gripper_controller" pkg="arbotix_controllers" type="gripper_controller">
        <rosparam>
            model: singlesided
            invert: false
            center: 0.0
            pad_width: 0.004
            finger_length: 0.08
            min_opening: 0.0
            max_opening: 0.06
            joint: finger_joint1
        </rosparam>
    </node>

    <node pkg="robot_state_publisher" type="robot_state_publisher" name="rob_st_pub" />

    <include file="$(find marm_moveit_config)/launch/move_group.launch" />

    <!-- 启动rviz可视化界面 -->
    <node name="rviz" pkg="rviz" type="rviz" args="-d $(find marm_planning)/config/pick_and_place.rviz" required="true" />

</launch>

与之前的没有加入moveit控制器的launch文件区别

<launch>
    <!-- 不使用仿真时间 -->
    <param name="/use_sim_time" value="false" />

    <!-- 启动arbotix driver-->
    <arg name="sim" default="true" />

    <param name="robot_description" command="$(find xacro)/xacro --inorder '$(find marm_description)/urdf/arm.xacro'" />

    <node name="arbotix" pkg="arbotix_python" type="arbotix_driver" output="screen">
        <rosparam file="$(find marm_description)/config/arm.yaml" command="load" />
        <param name="sim" value="true"/>
    </node>

    <node name="gripper_controller" pkg="arbotix_controllers" type="gripper_controller">
        <rosparam>
            model: singlesided
            invert: false
            center: 0.0
            pad_width: 0.004
            finger_length: 0.08
            min_opening: 0.0
            max_opening: 0.06
            joint: finger_joint1
        </rosparam>
    </node>

    <node pkg="robot_state_publisher" type="robot_state_publisher" name="rob_st_pub" />

    <!-- 启动rviz -->
    <node name="rviz" pkg="rviz" type="rviz" args="-d $(find marm_description)/urdf.rviz" required="true" />

</launch>

区别:

(1)rviz节点不同,之前是urdf.rviz,目前是pick_and_place.rviz.

(2)加入了move_group.launch,其中书中所说,此处是为了加载之前修改过控制器的插件,即Moveit控制器。

4.开始运动测试

(1)正运动学

roslaunch marm_planning arm_planning.launch
roscore
rosrun marm_planning moveit_fk_demo.py

 marm_planning moveit_fk_demo.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import rospy, sys
import moveit_commander
from control_msgs.msg import GripperCommand

class MoveItFkDemo:
    def __init__(self):
        # 初始化move_group的API
        moveit_commander.roscpp_initialize(sys.argv)

        # 初始化ROS节点
        rospy.init_node('moveit_fk_demo', anonymous=True)
 
        # 初始化需要使用move group控制的机械臂中的arm group
        arm = moveit_commander.MoveGroupCommander('arm')
        
        # 初始化需要使用move group控制的机械臂中的gripper group
        gripper = moveit_commander.MoveGroupCommander('gripper')
        
        # 设置机械臂和夹爪的允许误差值
        arm.set_goal_joint_tolerance(0.1)
        gripper.set_goal_joint_tolerance(0.001)
        
        # 控制机械臂先回到初始化位置
        joint_positions = [0.1145, 0.4544, 0.4777, 0.2171, -0.5156, 0.3817]
        # arm.set_named_target('home')
        arm.set_joint_value_target(joint_positions)
        arm.go()
        rospy.sleep(2)



        # 控制机械臂先回到初始化位置
        joint_positions = [0.2545, 0.5644, 0.5877, 0.3171, -0.6156, 0.4817]
        # arm.set_named_target('home')
        arm.set_joint_value_target(joint_positions)
        arm.go()
        rospy.sleep(2)

        # 控制机械臂先回到初始化位置
        joint_positions = [0.3545, 0.6644, 0.6877, 0.4171, -0.7156, 0.5817]
        # arm.set_named_target('home')
        arm.set_joint_value_target(joint_positions)
        arm.go()
        rospy.sleep(2)


        arm.set_named_target('forward')
        arm.go()
        rospy.sleep(5)
          
        # 设置夹爪的目标位置,并控制夹爪运动
        gripper.set_joint_value_target([0.01])
        gripper.go()
        rospy.sleep(2)
         

         
        # 控制机械臂完成运动
        # arm.go()
        # rospy.sleep(5)
        
        # 关闭并退出moveit
        moveit_commander.roscpp_shutdown()
        moveit_commander.os._exit(0)

if __name__ == "__main__":
    try:
        MoveItFkDemo()
    except rospy.ROSInterruptException:
        pass

注意正运动学幅度不能太大,特别容易规划不出来!

会出现报错,规划失败。ABORTED: No motion plan found. No execution attempted.

(2)逆运动学

rosrun marm_planning moveit_ik_demo.py

运行上述python脚本。

 逆运动学没发现规划出现问题。相比于正确运动学要更加稳定。

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import rospy, sys
import moveit_commander
from moveit_msgs.msg import RobotTrajectory
from trajectory_msgs.msg import JointTrajectoryPoint

from geometry_msgs.msg import PoseStamped, Pose
from tf.transformations import euler_from_quaternion, quaternion_from_euler

class MoveItIkDemo:
    def __init__(self):
        # 初始化move_group的API
        moveit_commander.roscpp_initialize(sys.argv)
        
        # 初始化ROS节点
        rospy.init_node('moveit_ik_demo')
                
        # 初始化需要使用move group控制的机械臂中的arm group
        arm = moveit_commander.MoveGroupCommander('arm')
                
        # 获取终端link的名称
        end_effector_link = arm.get_end_effector_link()
                        
        # 设置目标位置所使用的参考坐标系
        reference_frame = 'base_link'
        arm.set_pose_reference_frame(reference_frame)
                
        # 当运动规划失败后,允许重新规划
        arm.allow_replanning(True)
        
        # 设置位置(单位:米)和姿态(单位:弧度)的允许误差
        arm.set_goal_position_tolerance(0.01)
        arm.set_goal_orientation_tolerance(0.05)
        
        # 控制机械臂先回到初始化位置
        arm.set_named_target('home')
        arm.go()
        rospy.sleep(2)
               
        # 设置机械臂工作空间中的目标位姿,位置使用x、y、z坐标描述,
        # 姿态使用四元数描述,基于base_link坐标系
        target_pose = PoseStamped()
        target_pose.header.frame_id = reference_frame
        target_pose.header.stamp = rospy.Time.now()     
        target_pose.pose.position.x = 0.191995
        target_pose.pose.position.y = 0.213868
        target_pose.pose.position.z = 0.520436
        target_pose.pose.orientation.x = 0.911822
        target_pose.pose.orientation.y = -0.0269758
        target_pose.pose.orientation.z = 0.285694
        target_pose.pose.orientation.w = -0.293653
        
        # 设置机器臂当前的状态作为运动初始状态
        arm.set_start_state_to_current_state()
        
        # 设置机械臂终端运动的目标位姿
        arm.set_pose_target(target_pose, end_effector_link)
        
        # 规划运动路径
        traj = arm.plan()
        
        # 按照规划的运动路径控制机械臂运动
        arm.execute(traj)
        rospy.sleep(1)
         
        # 控制机械臂终端向右移动5cm
        arm.shift_pose_target(1, -0.05, end_effector_link)
        arm.go()
        rospy.sleep(1)
  
        # 控制机械臂终端反向旋转90度
        arm.shift_pose_target(3, -1.57, end_effector_link)
        arm.go()
        rospy.sleep(1)
           
        # 控制机械臂回到初始化位置
        arm.set_named_target('home')
        arm.go()

        # 关闭并退出moveit
        moveit_commander.roscpp_shutdown()
        moveit_commander.os._exit(0)

if __name__ == "__main__":
    MoveItIkDemo()

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MoveIt是一种用于机器人路径规划和控制的功能强大的开源软件包,它可以帮助用户以一种直观且高效的方式在笛卡尔空间规划机器人的移动。 笛卡尔空间规划指的是在三维直角坐标系下进行机器人路径规划。传统的机器人路径规划通常使用关节空间表示机器人的运动轨迹,即通过控制机器人关节的角度来实现机器人的运动。然而,在一些应用场景中,使用笛卡尔坐标系更加直观和方便,例如需要精确控制机器人末端执行器的位置和姿态时。这就需要在笛卡尔空间规划机器人的移动。 使用MoveIt进行笛卡尔空间规划的过程通常包括以下几个步骤: 1. 创建机器人模型: 首先,需要将机器人的运动学模型加载到MoveIt中,这样MoveIt就能够了解机器人的结构和各个关节的运动范围。 2. 设置规划场景: 在规划场景中,需要定义机器人的起始状态和目标状态,以及避障的环境信息。这些信息可以通过传感器获取,也可以手动设定。 3. 进行规划: MoveIt提供了一种灵活且高效的规划算法,可以在定义的规划场景下自动搜索最优的路径。路径规划是一个复杂的计算问题,MoveIt使用了各种搜索算法和优化技术来有效解决这个问题。 4. 执行运动: 一旦找到了最优路径,MoveIt会将路径转化为机器人关节的运动,然后通过控制机器人的硬件来实现运动。 总结来说,MoveIt的笛卡尔空间规划能够帮助用户以一种直观、高效和自动化的方式规划机器人的移动轨迹。它大大提高了机器人的路径规划和控制的效率和精确度,为机器人应用开发者提供了强大的工具和支持。 ### 回答2: MoveIt是一个用于运动规划和控制机器人的软件包,其中包含的功能模块包括笛卡尔空间规划。笛卡尔空间规划是指在机器人工作空间中,通过直接控制机器人的位置和姿态来进行规划和控制。 在MoveIt中,笛卡尔空间规划可以通过以下步骤进行: 1. 设置机器人模型和规划场景:首先,需要提供机器人的模型和规划场景的描述。这些描述包括机器人的运动范围、约束条件以及希望实现的目标。 2. 设置目标位置和姿态:在进行笛卡尔空间规划之前,需要确定目标位置和姿态。这可以通过设置机器人的末端执行器的位置和姿态来实现。 3. 进行规划:通过MoveIt提供的规划模块,可以进行笛卡尔空间规划规划模块根据机器人的模型和规划场景以及目标位置和姿态,计算出机器人的运动轨迹。 4. 执行运动:一旦规划完成,可以通过MoveIt提供的控制模块,将计算出的运动轨迹发送给机器人控制器,实现机器人的移动。 5. 优化和调整:如果规划结果不理想,可以通过优化和调整参数来改进规划结果。MoveIt提供了参数调整和优化的接口,可以根据实际情况对规划过程进行改进。 总之,通过MoveIt的笛卡尔空间规划功能,可以实现对机器人位置和姿态的直接控制,并通过规划和控制模块,实现机器人的运动。这对于许多机器人应用来说是非常重要的,尤其是需要精确控制机器人位置和姿态的任务。 ### 回答3: MoveIt是一个用于机器人运动规划和控制的软件框架,在机器人操作中起着至关重要的作用。笛卡尔空间规划MoveIt中一种常见的规划方法,用于在笛卡尔坐标系中规划机器人的运动。 在MoveIt中,一个机器人的笛卡尔空间由其中各个关节之间的坐标关系所确定。而笛卡尔空间规划方法则是基于机器人的笛卡尔空间进行运动规划。在进行笛卡尔空间规划时,需要给定机器人末端执行器(如机械臂手爪)所需达到的目标位置和姿态。 首先,通过MoveIt的运动规划器,可以根据机器人的运动学模型和关节限制条件,计算出机器人从当前位置到目标位置的一组合适的关节角度值。然后,根据这组关节角度值,可以通过正运动学计算的方法,求得末端执行器所需达到的位置和姿态。 接下来,根据目标位置和姿态,可以结合机器人的运动学模型和逆运动学计算的方法,计算出机器人各个关节所需的角度值。然后,通过控制机器人的关节,使机器人末端执行器达到目标位置和姿态。 在进行笛卡尔空间规划时,需要考虑到机器人的运动范围、安全性及避障等问题。因此,MoveIt提供了一系列的规划器和优化算法,以便有效地规划机器人的运动路径。 总之,通过MoveIt的笛卡尔空间规划方法,我们可以方便地规划机器人在笛卡尔坐标系中的运动,实现精准的位置和姿态控制。这为机器人的自主运动和操作提供了重要的计划基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值