6.Moveit 笛卡尔运动规划

roslaunch marm_planning arm_planning_with_trail.launch
rosrun marm_planning moveit_cartesian_demo.py _cartesian:=True

注意笛卡尔launch文件已经不同,对比如下。

arm_planning_with_trail.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/arm_paths.rviz" required="true" />

</launch>

arm_planning.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>

区别是rviz文件的差距!现在不知道是官网给的还是自己编写,未知数,全学完解决。

运行效果如下。

 其中python脚本,moveit_cartesian_demo.py

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

import rospy, sys
import moveit_commander
from moveit_commander import MoveGroupCommander
from geometry_msgs.msg import Pose
from copy import deepcopy

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

        # 初始化ROS节点
        rospy.init_node('moveit_cartesian_demo', anonymous=True)
        
        # 是否需要使用笛卡尔空间的运动规划
        cartesian = rospy.get_param('~cartesian', True)
                        
        # 初始化需要使用move group控制的机械臂中的arm group
        arm = MoveGroupCommander('arm')
        
        # 当运动规划失败后,允许重新规划
        arm.allow_replanning(True)
        
        # 设置目标位置所使用的参考坐标系
        arm.set_pose_reference_frame('base_link')
                
        # 设置位置(单位:米)和姿态(单位:弧度)的允许误差
        arm.set_goal_position_tolerance(0.01)
        arm.set_goal_orientation_tolerance(0.1)
        
        # 获取终端link的名称
        end_effector_link = arm.get_end_effector_link()
                                        
        # 控制机械臂运动到之前设置的“forward”姿态
        arm.set_named_target('forward')
        arm.go()
        
        # 获取当前位姿数据最为机械臂运动的起始位姿
        start_pose = arm.get_current_pose(end_effector_link).pose
                
        # 初始化路点列表
        waypoints = []
                
        # 将初始位姿加入路点列表
        if cartesian:
            waypoints.append(start_pose)
            
        # 设置第二个路点数据,并加入路点列表
        # 第二个路点需要向后运动0.2米,向右运动0.2米
        wpose = deepcopy(start_pose)
        wpose.position.x -= 0.2
        wpose.position.y -= 0.2

        if cartesian:
            waypoints.append(deepcopy(wpose))
        else:
            arm.set_pose_target(wpose)
            arm.go()
            rospy.sleep(1)
         
        # 设置第三个路点数据,并加入路点列表
        wpose.position.x += 0.05
        wpose.position.y += 0.15
        wpose.position.z -= 0.15
          
        if cartesian:
            waypoints.append(deepcopy(wpose))
        else:
            arm.set_pose_target(wpose)
            arm.go()
            rospy.sleep(1)
        
        # 设置第四个路点数据,回到初始位置,并加入路点列表
        if cartesian:
            waypoints.append(deepcopy(start_pose))
        else:
            arm.set_pose_target(start_pose)
            arm.go()
            rospy.sleep(1)
            
        if cartesian:
            fraction = 0.0   #路径规划覆盖率
            maxtries = 100   #最大尝试规划次数
            attempts = 0     #已经尝试规划次数
            
            # 设置机器臂当前的状态作为运动初始状态
            arm.set_start_state_to_current_state()
     
            # 尝试规划一条笛卡尔空间下的路径,依次通过所有路点
            while fraction < 1.0 and attempts < maxtries:
                (plan, fraction) = arm.compute_cartesian_path (
                                        waypoints,   # waypoint poses,路点列表
                                        0.01,        # eef_step,终端步进值
                                        0.0,         # jump_threshold,跳跃阈值
                                        True)        # avoid_collisions,避障规划
                
                # 尝试次数累加
                attempts += 1
                
                # 打印运动规划进程
                if attempts % 10 == 0:
                    rospy.loginfo("Still trying after " + str(attempts) + " attempts...")
                         
            # 如果路径规划成功(覆盖率100%),则开始控制机械臂运动
            if fraction == 1.0:
                rospy.loginfo("Path computed successfully. Moving the arm.")
                arm.execute(plan)
                rospy.loginfo("Path execution complete.")
            # 如果路径规划失败,则打印失败信息
            else:
                rospy.loginfo("Path planning failed with only " + str(fraction) + " success after " + str(maxtries) + " attempts.")  

        # 控制机械臂回到初始化位置
        arm.set_named_target('home')
        arm.go()
        rospy.sleep(1)
        
        # 关闭并退出moveit
        moveit_commander.roscpp_shutdown()
        moveit_commander.os._exit(0)

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

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值