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

引言:

在本文中,我们将深入探讨机器人学的两个核心概念:正运动学和逆运动学。这两个概念是理解和控制机械臂运动的基础。通过一个具体的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.mfbz.cn/a/124526.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[设计模式] 建造者模式

一、引言 起因是学习okhttp过程中遇到的这段代码 Request request original.newBuilder().url(original.url()).header("Authorization", "Bearer " BearerTokenUtils.getToken(configuration.getApiKey(), configuration.getApiSecret())).header(&quo…

《第三期(先导课)》之《Python 开发环境搭建》

文章目录 《第 1 节 初始Python》《第 6 节 pip包管理工具》 《第 1 节 初始Python》 。。。 《第 6 节 pip包管理工具》 pip是Python的包管理工具,用于安装、升级和管理Python包。 pip是Python标准库之外的一个第三方工具,可以从Python Package Index(PyPI)下载和安装各种P…

在PostgreSQL中创建和管理数据库

PostgreSQL是一个强大、开源的关系型数据库管理系统,它提供了丰富的功能和灵活的配置选项,使得它成为许多开发者和组织的首选数据库之一,接下来我会介绍如何在PostgreSQL中创建和管理数据库。 一、安装和配置PostgreSQL 第一步,…

嵌软工程师要掌握的硬件知识2:一文看懂什么是开漏和推挽电路(open-drain / push-pull)

文 / 黑猫学长 本文根据笔者个人工作/学习经验整理而成,如有错误请留言。 文章为付费内容,已加入原创侵权保护,禁止私自转载及抄袭。 文章所在专栏: 嵌软工程师要掌握的硬件知识 1 推挽(push pull)电路 1.1 理解什么是推挽电路 - 详细介绍 如图所示,Q3是个NPN型三极管…

【mysql】CommunicationsException: Communications link failure

CommunicationsException: Communications link failure The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 通信异常:通信链路故障 最后一个成功发送到服务器的数据包是0毫秒前…

【Unity实战】实现强大通用易扩展的对话系统(附项目源码)

先看看实现的最终效果 前言 之前的对话系统因为存在一些错误和原作者不允许我分享,所以被我下架了,而且之前对话系统确实少了一些功能,比如最基本的逐字打印功能,原本来是打算后面补充的。 对话系统在游戏中实现太常见了&#x…

基于 Python 的课程助教智能聊天机器人

温馨提示:文末有 CSDN 平台官方提供的学长 Wechat / QQ 名片 :) 1. 项目简介 课程助教是高校中一种常见的教学模式,其在学生理论知识的掌握与实践能力的提高方面起到关键性的作用,已经成为高校日常教育环节中不可或缺的一环。然而,传统的人力助教有若干关键问题亟待…

Leangoo领歌免费Scrum管理工具中如何看到关于自己的所有任务?

个人工作台 个人工作台是个人最新待办工作的展示区域,它展示了个人所有的待办任务,最新访问的项目和工作动态,当一个人在多个项目和看板上工作时,它可以帮助个人快速看到个人在各个项目的工作,快速进入任务看板处理任…

Flink集群的搭建

1、Flink独立集群模式 1、首先Flink的独立集群模式是不依赖于Hadoop集群。 2、上传压缩包,配置环境: 1、解压: tar -zxvf flink-1.15.2-bin-scala_2.12.tgz2、配置环境变量:vim /etc/profileexport FLINK_HOME/usr/local/soft/fl…

3、FFmpeg基础

1、FFmpeg 介绍 FFmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。采用LGPL或GPL许可证。它提供了录制、转换以及流化音视频的完整解决方案。它包含了非常先进的音频/视频编解码库。 2、FFmpeg 组成 - libavformat:用于…

【理解链表指针赋值】链表中cur->next = cur->next->next->next与cur =cur->next->next的区别

最近在做链表的题目的时候,对于所定义的cur链表指针产生了一些疑惑,查阅资料后整理一下我的理解: /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val(x), next(n…

AI创作系统ChatGPT商业运营系统源码+支持GPT4/支持ai绘画

一、AI创作系统 SparkAi创作系统是基于OpenAI很火的ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统,支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如…

工程(十二)Ubuntu20.04LSD_SLAM运行

博主创建了一个科研互助群Q:772356582,欢迎大家加入讨论。这是一个科研互助群,主要围绕机器人,无人驾驶,无人机方面的感知定位,决策规划,以及论文发表经验,以方便大家很好很快的科研…

CSS 显示、定位、布局、浮动

一、CSS 显示: CSS display属性设置元素应如何显示;CSS visibility属性指定元素应可见还是隐藏。隐藏元素可以通过display属性设置为“none”,也可以通过visibility属性设置为“hidden”。两者的区别:visibility:hidden可以隐藏某…

王道p40 1.设计一个递归算法,递归删除单链表L中所有值为x的结点(c语言)

视频讲解在这里:👇 p40 第1题 王道数据结构课后代码题c语言代码实现_哔哩哔哩_bilibili 本题代码如下 void delete(linklist* L,int x)//递归删除x {if((*L)->next! NULL){if ((*L)->next->data x)//找到x{lnode* p (*L)->next;(*L)-&…

【Springboot】Vue3-Springboot引入JWT实现登录校验以及常见的错误解决方案

文章目录 前言一、JWT简单介绍二、token校验设计思路三、使用步骤Springboot部署JWT引入依赖:创建登录实体类后端:LoginController.java路由守卫函数 四、问题 前言 项目版本: 后端: Springboot 2.7、 Mybatis-plus、Maven 3.8.1…

网络测试工具—— iperf2 安卓APK 下载 及简单使用

网络测试工具—— iperf2 安卓APK 下载 及简单使用 前言一、iperf2是什么?二、使用步骤附上help中命令截图翻译总结 前言 项目上有一款安卓车机加载局域网图片加载非常慢,所以需要测试一个安卓车机设备的带宽,经过调研后使用到了iperf2。 一…

项目管理之如何出道(中)

昨日立冬,各位盆友,有没有吃饺子? 冬天来了,寒冷未约而至,冬雪侵袭北国。未知的变化总能让人产生恐慌和无措,就像行走在荒岛小路,前面遇到的究竟是迷人之景?还是饿狼之瞟&#xff1f…

52基于MATLAB的希尔伯特Hilbert变换求包络谱

基于MATLAB的希尔伯特Hilbert变换求包络谱,对原始信号进行初步滤波,之后进行包络谱分析。可替换自己的数据进行优化。程序已调通,可直接运行。 52的尔伯特Hilbert变换包络谱 (xiaohongshu.com)

计算机三级四级嵌入式备战经验

2023年9月23日于东北大学考完三四级 大四的时候时间比较多,因为本科学了一点嵌入式的知识,研究生又用不到,所以想着考个证金盆洗手。 三级考的是一本书,更多涉及到S3C2410这个芯片;四级考的是两本书:《操作…
最新文章