开源七轴myArm协作机械臂正逆运动学技术讲解

news2024/11/24 20:42:42

引言:

在本文中,我们将深入探讨机器人学的两个核心概念:正运动学和逆运动学。这两个概念是理解和控制机械臂运动的基础。通过一个具体的7轴机械臂实例,我们将详细介绍如何计算机械臂的正运动学和逆运动学。我们首先会解释正运动学和逆运动学的基本概念和数学原理,然后我们将展示如何应用这些原理来计算7轴机械臂的运动。我们的目标是让读者对机械臂的运动控制有一个深入的理解,并了解如何在实践中应用这些知识。

myArm 300

我们先来简要介绍我们待会会使用到的机械臂myArm 300.

myArm 300 Pi是一块全新的7自由度的中心对称构型协作机械臂,myArm搭载着7个高精度的伺服电机,使得最大工作半径300mm,末端最大负载成都能够达到200g,重复定位精度最高达到了±0.5mm。

myArm 300 Pi的控制主板采用了树莓派4B 4G,这是一种广受欢迎的微型计算机,因其强大的性能和灵活的编程环境而备受赞誉。这意味着用户可以使用多种编程语言来控制myArm 300 Pi,包括Python、C++、Java等,极大地提高了使用者的便利性和灵活性,它还支持ROS1/ROS2 在ROS操作系统中提供了许多功能,例如路径规划,避障,三维感知等。

基本概念

我们要想控制机械臂,就得有一套关于机械臂运动控制的算法。正逆运动学是其中的重要组成部分。在介绍正逆运动学之前,我们想先介绍DH模型,这个模型使得正逆运动学的计算变得更加直接和简单。

DH模型

DH参数模型是机器人学中一种常用的描述机器人运动学的方法。它通过一组参数来描述机器人的关节连杆,从而方便地计算机器人末端执行器地位置和姿态。

当使用DH模型用来描述机械臂时,我们将机械臂分解为一系列链接和关节,每个链接和关节都与一个坐标系相关联。我们选择一个基准坐标系,通常是机械臂的基座(底座)坐标系,然后,为每个链接和关节定义一个坐标系,我们定义两个坐标系:前一个链接的坐标系和当前链接的坐标系。这两个坐标系之间的变换由四个参数描述:

连杆长度(a):它表示相邻链接之间的距离,沿着前一个链接的法线测量。它通常指的是链接的长度或者链接轴线的长度。

连杆的旋转角度(α):它表示相邻链接之间的旋转角度,围绕前一个链接的法线旋转。它通常指的是链接轴线之间的旋转。

关节的长度(d):它表示链接的长度或者关节的长度,沿着当前链接的法线测量。它通常指的是关节轴线的长度。

关节的旋转角度(θ):它表示关节的旋转角度,围绕当前链接的法线旋转。它通常指的是关节的角度或者关节的转动。

通过组合这些参数,可以构建一个四维的变换矩阵,这个变换矩阵可以表示机械臂末端执行器的位置和姿态。

以myArm为例子,下图是myArm 300 的DH模型图以及SDH参数表。当我们有了一个机械臂的DH模型图我们具体能干些什么呢:

正向运动学:通过给定关节角度,可以使用DH模型图计算机械臂末端执行器的位置和姿态,从而进行路径规划和运动控制

逆向运动学:反过来,也可以用DH模型图来解决逆向运动学问题,即给定目位置和姿态,计算出关节角度的变化,从而实现平滑的运动轨迹。

路径规划:给定一个开始位置和一个结束位置,可以使用DH模型来规划机械臂的运动路径。这可能涉及到解决一系列的逆运动学问题。

除此之外还有很多,比如说碰撞检测和臂章,动画和可视化机械臂,仿真机械臂等等。

正运动学

正运动学是用来描述机械臂从基座到末端执行器的位置和方向的计算方法。给定每个关节的角度,我们可以计算出机械臂末端的位置和方向。这是一个基于几何和三角学的过程。

下面举一个简单的例子,在一个平面坐标系当中,已知连杆的感觉长度为l1和l2,并且已知两个关节的转动角度分别为θ1和θ2,那么其末端执行器的位置(x,y)可以根据三角函数求出。

x=l1cos(θ1)+l2cos(θ1+θ2)

y=l1sin(θ1)+l2sin(θ1+θ2)

就可以求出x,y的坐标了。

在实际应用中,我们通常会直接在三维空间中直接进行计算,我们可以使用齐次坐标来进行转换,在齐次坐标中,一个二维点(x, y)可以表示为一个三维点(x, y, 1),一个三维点(x, y, z)可以表示为一个四维点(x, y, z, 1)。通过这种方式,我们可以使用相同的矩阵乘法操作来描述平移和旋转。

例如,一个二维的平移变换可以表示为以下形式的3x3矩阵:

[[1, 0, dx],
 [0, 1, dy],
 [0, 0, 1]]

其中,dx和dy表示在x轴和y轴方向上的平移距离。同样,一个二维的旋转变换可以表示为以下形式的3x3矩阵:

[[cos(theta), -sin(theta), 0],
 [sin(theta), cos(theta), 0],
 [0, 0, 1]]

其中,theta表示旋转角度,也就是DH参数中的θ。

通过将所有关节的变换矩阵相乘,我们就可以得到从机器人基座到末端执行器的总变换。这就是正运动学的基本计算过程。这个过程可以用以下的数学形式来表示:

T = A1 * A2 * A3 * ... * An

其中 T 是总变换矩阵,Ai 是第 i 个关节的变换矩阵,n 是关节的数量。注意,矩阵乘法不满足交换律,所以乘法的顺序很重要。最终得到的T总变化矩阵算出来的结果就是机械臂末端相对于基座的坐标。提前了解DH模型,对理解后面的矩阵变换很有帮助。

逆运动学

逆向运动学是指根据机械臂末端执行器的位置和姿态,计算机械臂各个关节的角度。刚好跟正运动学反过来,是求取各个关节的角度。逆运动学的计算通常要比正运动学复杂得多,这是一个从效果反推原因的过程,通常需要解决非线性方程组,而且解可能不唯一,或者根本不存在。我们还是举例说明,以2自由度的平面机械臂来做一个了解。我们已知(x,y)的值,要求出θ1和θ2的角度。

首先我们可以x,y到原点的位置的距离d,这可以勾股定理得到(sqrt代表平方根)

d = sqrt(x^2 + y^2)

 然后,我们可以使用余弦定理来求解第二个关节的角度θ2。余弦定理可以描述三个边长已知的三角形中,任何一个角的余弦值。在这里,我们可以将d,L1和L2看作是三个边长,然后求解θ2:

cos(theta2) = (L1^2 + L2^2 - d^2) / (2 * L1 * L2)

因为θ2可能有两个解(顺时针和逆时针),所以我们需要根据实际情况来选择合适的解。

最后,我们可以使用正弦定理或余弦定理来求解第一个关节的角度θ1。正弦定理可以描述三个边长和对应的角的正弦值之间的关系。在这里,我们可以将d,L1和θ1看作是三个已知的值,然后求解θ1:

theta1 = atan2(y, x) - atan2(L2 * sin(theta2), L1 + L2 * cos(theta2))

求解完之后就可以得知各个关节的角度了,这是在二维的空间中的求解方法,在三维空间中的计算方法也是一样的道理,在计算的时候得考虑机械臂关节的限制,以及其他的因素来决定最终的角度。

7轴机械臂实例

接下会用到python对myArm进行编程,用到的是pymycobot库。

正运动学关节控制

正运动学算法通常有一个确定的结果,正运动学的目标是根据给定的关节角度,计算机械臂执行器的位置和姿态,只存在唯一的结果。下面是使用角度控制的代码:

from pymycobot import Myarm
import time

# create myarm object
ma = Myarm('/dev/ttyAMA0',115200)
ma.send_angles([degree_list],speed)

# send_angles function
def send_angles(self, degrees, speed):
        """Send the degrees of all joints to robot arm.

        Args:
            degrees: a list of degree values(List[float]).\n
                        for mycobot: [0.0, 0.0, 0.0, 0.0, 0.0, 0.0].\n
                        for mypalletizer: [0.0, 0.0, 0.0, 0.0]
                        for mypalletizer 340: [0.0, 0.0, 0.0]
                        for myArm: [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0].\n
            speed : (int) 1 ~ 100
        """
        # self.calibration_parameters(degrees=degrees, speed=speed)
        degrees = [self._angle2int(degree) for degree in degrees]
        return self._mesg(ProtocolCode.SEND_ANGLES, degrees, speed)
 

这就是最直观的正运动学算法的控制,关节角度控制机械臂运动。

逆运动学算法控制,坐标控制

前面也有提及到,你运动学算法相对来说复杂很多,可能存在多个解的情况,也可能存在无解的情况。逆运动学算法的控制是通过控制机械臂末端坐标的变化,让机械臂前往下一个坐标位置。我们用python编写控制坐标运动的代码:

from pymycobot import Myarm
import time

# create myarm object
ma = Myarm('/dev/ttyAMA0',115200)
ma.send_coords([coordinates_list],speed,mode)
# mode: 0:linear motion,1:nonlinear motion

 def send_coords(self, coords, speed, mode=None):
        """Send all coords to robot arm.

        Args:
            coords: a list of coords value(List[float]).
                        for mycobot :[x(mm), y, z, rx(angle), ry, rz]\n
                        for mypalletizer: [x, y, z, θ]
                        for mypalletizer 340: [x, y, z]
            speed : (int) 0 ~ 100
            mode : (int) 0 - angluar, 1 - linear (mypalletizer 340 does not require this parameter)
        """
        # self.calibration_parameters(coords=coords, speed=speed)
        coord_list = []
        for idx in range(3):
            coord_list.append(self._coord2int(coords[idx]))
        for angle in coords[3:]:
            coord_list.append(self._angle2int(angle))
        # print(coord_list)
        if mode is not None:
            return self._mesg(ProtocolCode.SEND_COORDS, coord_list, speed, mode)
        else:
            return self._mesg(ProtocolCode.SEND_COORDS, coord_list, speed)

7轴机械臂又被称之为冗余机器人,多的一个轴通常用于提供更多的灵活性和运动自由度,所以就出现了这么一个现象,机械臂的末端坐标值保持不变的时候,会有许多不同的姿态。

这就是开头说到的逆运动学的特点,同一个坐标下有许多不同的解。在坐标控制中还有一个关键的信息就是线性运动和非线性运动,主要是指机械臂末端的运动路径的类型。

  1. 线性运动:在这种模式下,机器人末端执行器在两个点之间直线移动。这就意味着,无论机器人的关节如何移动,末端执行器都会沿着直线路径从一点移动到另一点。这种类型的运动通常在需要精确位置控制的应用中使用,例如在装配线上的装配任务。
  2. 非线性运动:在这种模式下,机器人末端执行器的路径不是直线,而是一条曲线。这种类型的运动可以使机器人在复杂的环境中更灵活地移动,例如在需要避开障碍物或在特定的路径上移动的情况下。

总结

在我们探讨了正逆运动学的基本概念以及数学原理后,我们可以看到这两个概念在机械臂中的控制是特别重要的。然而,正运动学和逆运动学只是机械臂控制的一部分。在实际应用中,我们还需要考虑到动力学、控制理论、传感器反馈、以及实际硬件的限制。

随着技术的发展,机械臂将在很多领域发挥越来越大的作用,包括制造业、医疗保健、家庭服务、搜索和救援等。通过深入理解这些知识,我们可以更加的了解什么是机械臂,让它在各种应用中发挥更大的作用。

如果你喜欢这篇文章的话欢迎在下方留言或者点赞,你的支持是我们更新的动力!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1179762.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深入理解 Django 模板系统

概要 在任何 Web 开发过程中,渲染和展示数据是不可或缺的一部分。Django 作为一个高效的 Python Web 框架,提供了一个强大且灵活的模板系统。本文将详细介绍 Django 模板系统的核心概念、语法和高级功能。 一、Django 模板系统简介 Django 的模板系统允…

使用Wireshark抓包分析ARP协议工作原理

1.什么是ARP协议 ARP协议(Address Resolution Protocol),即地址解析协议,是以太网中用于描述目标IP地址和目标主机MAC地址对应映射。 ARP仅用于IPv4协议,IPv6使用邻居发现协议**(NDP)**替代。 交换机、路由器、主机…

产品经理进阶:产品的起点是发现并理解问题

目录 简介 发现实际问题 接下来选择一个问题 之后就是验证问题 最后总结一下 CSDN学院(硬件产品经理进阶课) 简介 你花费了大量的时间来思考如何构建一款每个人都会喜欢的产品。 但最终却发现没有人愿意为之买单。 这其实就是没有真正理解客户问…

近视眼选择什么台灯好?专家推荐的防近视台灯

年轻的时候不懂,以为自己的眼睛不好,近视度数高,是因为长时间看书造成的,其实我们都忽视了一个最为重要的影响因素,那就是灯光。如今的孩子面临着比我们以前更要繁重的学习压力,因此更需要注意用眼健康了&a…

MFC-网络编程TCP服务端(NBlockSocket)

目录 1、NBlockSocket.h类: (1)、Init接口函数 (2)、Register接口函数 (3)、Send接口函数 (4)、Accept接口函数 (5)、Recv接口函数 2、实现…

ZZ308 物联网应用与服务赛题第B套

2023年全国职业院校技能大赛 中职组 物联网应用与服务 任 务 书 (B卷) 赛位号:______________ 竞赛须知 一、注意事项 1.检查硬件设备、电脑设备是否正常。检查竞赛所需的各项设备、软件和竞赛材料等; 2.竞赛任务中所使用的…

把wpf的窗体保存为png图片

昨晚在stack overflow刷问题时看到有这个问题,今天早上刚好来尝试学习一下 stack overflow的链接如下: c# - How to render a WPF UserControl to a bitmap without creating a window - Stack Overflow 测试步骤如下: 1 新建.net frame…

【双指针+简化去重操作】【int运算溢出】Leetcode 18 四数之和

【双指针简化去重操作】【int运算范围】Leetcode 18 四数之和 解法1 仍然用双指针法 就是在三数求和的基础上扩展一个外层循环 ----------------------题目链接---------------------- ----------------------解析链接---------------------- 解法1 仍然用双指针法 就是在三数…

元宇宙初体验:探秘各元宇宙游戏看点与玩法

元宇宙(Metaverse)是一个虚拟世界,结合了虚拟现实(VR)、增强现实(AR)、区块链、人工智能等技术,为用户提供沉浸式、互动式的体验。随着技术的不断发展,如今,元…

SAP中信息记录未维护工厂导致的成本核算错误

近期遇到一例寄售物料成本核算中,不能确定价格的问题反馈。 由于寄售物料的成本核算测策略是在信息记录中取价,因此,首先想到会不会是这里的问题,按之前的经验,分别检查了供应商(是否冻结)&…

1300*C. Product of Three Numbers(质数数学)

Problem - 1294C - Codeforces 解析&#xff1a; 首先这个数肯定不是质数&#xff0c;然后找到第一个因子p&#xff0c;对于n/p再判断质数&#xff0c;然后找到另外两个因子即可。 注意三个因子不能相同。 #include<bits/stdc.h> using namespace std; #define int long…

2024有哪些免费的苹果mac电脑系统清理软件?

基本上&#xff0c;不管是win版还是Mac版的电脑&#xff0c;其装机必备就是一款电脑系统清理软件&#xff0c;就比如Mac&#xff0c;目前在市面上&#xff0c;电脑系统清理软件是非常多的。 对于不熟悉系统的用户来说&#xff0c;使用一些小众工具&#xff0c;往往很多用户都不…

UnityShader(五)

这次要用表面着色器实现一个水的特效。先翻到最下边看代码&#xff0c;看不懂再看下面的解释。 首先第一步要实现水的深浅判断&#xff0c;实现深水区和浅水区的区分。 这里需要用到深度图的概念。不去说太多概念&#xff0c;只去说怎么实现的&#xff0c;首先我们的水面是在…

宠物商店系统《宠物之家》,巨完善

源码下载地址 支持&#xff1a;远程部署/安装/调试、讲解、二次开发/修改/定制 系统分为用户端和管理员端。 截图中有些图片加载失败&#xff0c;是因为没有上传图片&#xff0c;登录管理员账号上传图片后&#xff0c;图片显示会变成正常。 web的宠物商城系统《宠物之家》。系…

什么是DDD领域驱动设计

一、DDD背景 2003 年埃里克埃文斯&#xff08;Eric Evans&#xff09;发表了《领域驱动设计》&#xff08;Domain-Driven Design –Tackling Complexity in the Heart of Software&#xff09;这本书&#xff0c;从此领域驱动设计&#xff08;Domain Driven Design&#xff0c…

SpringCloud 微服务全栈体系(十二)

第十一章 分布式搜索引擎 elasticsearch 一、初识 elasticsearch 1. 了解 ES 1.1 elasticsearch 的作用 elasticsearch 是一款非常强大的开源搜索引擎&#xff0c;具备非常多强大功能&#xff0c;可以帮助我们从海量数据中快速找到需要的内容 例如&#xff1a; 在 GitHub 搜…

Linux Shell和权限

目录 Shell命令及运行原理 权限 1.文件基本属性 2.文件权限值的表示方法 3.文件访问权限的相关设置方法 3.(1)chmod 组名修改 3.(2)chmod 二进制修改 3.(3)chown 3.(4)chgrp 3.(5)umask 4.目录权限 Shell命令及运行原理 Linux的操作系统&#xff0c;狭义上是…

C++常用格式化输出转换

在C语言中可以用printf以一定的格式打印字符&#xff0c;C当然也可以。 输入输出及命名空间还不太了解的小伙伴可以看一看C入门讲解第一篇。  在C中&#xff0c;可以用流操作符&#xff08;stream manipulators&#xff09;控制数据的输出格式&#xff0c;这些流操作符定义在2…

提升家庭自动化级别:使用HomeAssistant添加HACS插件,实现对米家、HomeKit等智能家居设备的公网控制

提升家庭自动化级别&#xff1a;使用HomeAssistant添加HACS插件&#xff0c;实现对米家、HomeKit等智能家居设备的公网控制 文章目录 提升家庭自动化级别&#xff1a;使用HomeAssistant添加HACS插件&#xff0c;实现对米家、HomeKit等智能家居设备的公网控制基本条件一、下载HA…