机器人工具箱学习(二)

news2024/11/14 20:05:05

一、机械臂及运动学

1.1 机械臂构成

  机械臂多采用关节式机械结构,一般具有6个自由度,其中3个用来确定末端执行器的位置,另外3个则用来确定末端执行装置的方向(姿态)。
  如图所示,一个机械臂是由一组可做相对运动的关节连接的连杆结合体。第一个连杆固定,连接该机械臂的基座,而最后一个连杆连接的是它的末端执行器。
在这里插入图片描述

  通常可将关节划分为两种:第一种称为转动关节(或称为旋转关节),转动关节可绕基准轴转动,相应的转动量称为关节角:第二种称为移动关节,移动关节是沿着基准轴移动,相应的位移称为关节偏距。还有一种特殊的关节称为球关节,球关节拥有三个自由度。可以用三个转动关节和一个零长度的连杆来描述一个球关节。
  位于机械臂固定基座的坐标系称为基坐标系;位于操作臂末端执行器的坐标系称为工具坐标系,通常用它来描述机械臂的位置。

1.2 机器人运动学介绍

  机器人运动学只研究机器人运动,不关注机器人运动过程中各零部件的质量及相关力,也不关注关节驱动力和力矩。
 (1)机器人正运动学:给定一组机器人关节变量(转角或位移),求解末端工具坐标系相对于基坐标系的位置和姿态。
 (2)机器人逆运动学:给定机器人末端工具箱坐标系的位置和姿态,求解机器人各关节变量。

二、D-H参数法

  D-H 参数全称为Denavit-Hartenberg参数,它使用连杆参数来描述机构运动关系。在DH参数法中,描述机械臂中的每一个连杆需要4个运动学参数:
● 连杆长度 a i − 1 a _ { i - 1 } ai1:关节轴 i − 1 i-1 i1与关节轴 i i i之间公垂线的长度;
● 连杆转角 α i − 1 \alpha _ { i-1 } αi1:第 i − 1 i-1 i1个关节轴和第 i i i个关节轴之间的夹角;
● 连杆偏距 d i d_{i} di:沿两个相邻连杆公共轴线方向的距离;
● 关节角 θ i \theta_{i} θi:两相邻连杆绕公共轴线旋转的夹角。
在这里插入图片描述

2.1 标准D-H法(SDH)

建模规则
(1)找出各关节轴,画出关节轴的延长线;
(2)确定 Z Z Z轴:与关节轴线重合,其中 Z i − 1 Z_{i-1} Zi1轴与关节 i i i的轴线重合;
(3)确定 X X X轴: Z i − 1 Z_{i-1} Zi1轴与 Z i Z_{i} Zi轴的公垂线,方向由 Z i − 1 Z_{i-1} Zi1轴指向 Z i Z_{i} Zi
  1)如果 Z i − 1 Z_{i-1} Zi1轴与 Z i Z_{i} Zi轴平行,选取与前一关节的公垂线共线的一条公垂线作为 X X X轴;
  2)如果 Z i − 1 Z_{i-1} Zi1轴与 Z i Z_{i} Zi轴相交, X X X轴为 Z i − 1 Z_{i-1} Zi1轴与 Z i Z_{i} Zi轴的叉积方向;
(4)确定 Y Y Y轴:右手定则。
在这里插入图片描述

D-H参数含义
(1) a i a_{i} ai:关节轴线 i − 1 i-1 i1和关节轴线 i i i的公垂线长度
(2) α i \alpha_{i} αi:关节轴线 i − 1 i-1 i1和关节轴线 i i i的夹角,指向为从轴线 i − 1 i-1 i1到轴线 i i i
(3) d i d_{i} di:关节 i i i上的两条公垂线 a i − 1 a_{i-1} ai1 a i a_{i} ai之间的距离,沿关节轴线 i i i测;
(4) θ i \theta_{i} θi:连杆 i i i相对于连杆 i − 1 i-1 i1绕轴线 i i i的旋转角度。

齐次变换矩阵
  从坐标系 i − 1 i-1 i1到坐标系 i i i,先绕 Z i − 1 Z_{i-1} Zi1轴旋转角度 θ i \theta_{i} θil,再沿 Z i − 1 Z_{i-1} Zi1轴移动 d i d_{i} di,然后沿 X i X_i Xi轴平移 a i a_i ai,最后绕 X i X_i Xi轴旋转 α i \alpha_i αi。齐次变换矩阵 i − 1 i T _ { i - 1 } ^ { i } T i1iT可以写为:
在这里插入图片描述

2.2 改进D-H法(MDH)

建模规则
(1)找出各关节轴,画出关节轴的延长线;
(2)确定 Z Z Z轴:与关节轴线重合,其中 Z i Z_{i} Zi轴与关节 i i i的轴线重合;
(3)确定 X X X轴: Z i Z_{i} Zi轴与 Z i + 1 Z_{i+1} Zi+1轴的公垂线,方向由 Z i Z_{i} Zi轴指向 Z i + 1 Z_{i+1} Zi+1轴;
(4)确定 Y Y Y轴:右手定则。
在这里插入图片描述

D-H参数含义
(1) a i − 1 a_{i-1} ai1:沿 X i − 1 X_{i-1} Xi1轴,从 Z i − 1 Z_{i-1} Zi1轴移动到 Z i Z_{i} Zi轴的距离;
(2) α i − 1 \alpha_{i-1} αi1:绕 X i − 1 X_{i-1} Xi1轴,从 Z i − 1 Z_{i-1} Zi1轴旋转到 Z i Z_{i} Zi轴的角度;
(3) d i d_{i} di:沿 Z i Z_{i} Zi轴,从 X i − 1 X_{i-1} Xi1轴移动到 X i X_{i} Xi轴的距离;
(4) θ i \theta_{i} θi:绕 Z i Z_{i} Zi轴,从 X i − 1 X_{i-1} Xi1轴旋转到 X i X_{i} Xi轴的角度;

齐次变换矩阵
从坐标系 i − 1 i-1 i1到坐标系 i i i,先绕 X i − 1 X_{i-1} Xi1轴旋转角度 α i − 1 \alpha_{i-1} αi1,再沿 X i − 1 X_{i-1} Xi1轴平移 a i − 1 a_{i-1} ai1,然后绕 Z i Z_{i} Zi轴旋转角度 θ i \theta_{i} θi,最后沿 Z i Z_{i} Zi轴移动 d i d_{i} di。齐次变换矩阵 i − 1 i T _ { i - 1 } ^ { i } T i1iT可以写为:
在这里插入图片描述

2.3 SDH和MDH的区别及适用场景

2.3.1 SDH和MDH的区别

  (其实一直以来笔者都不太能区分这两种方法,笔者最开始学习机器人学是看的《机器人学导论》这本书,上面似乎是偏向于MDH方法,所以后续我都是习惯于用MDH去建模)
  (1)区别一:连杆坐标系建立的位置不同。SDH将连杆 i i i的坐标系固定在连杆的远端;MDH将连杆 i i i的坐标系固定在连杆的近端。
在这里插入图片描述

  (2)区别二:执行变换的顺序不同

2.3.2 SDH和MDH的适用场景

  对于树形结构或者闭链机构的机器人来说,按照SDH方法建立的连杆坐标系会产生歧义,因为SDH的建系原则是把连杆 i i i的坐标系建立在连杆的远端,如图(a)所示,导致连杆0上同时出现了两个坐标系。而MDH把连杆坐标系建立在每个连杆的近端,则不会坐标系重合的情况,如图(b)所示,这就克服了SDH方法建系的缺点。
在这里插入图片描述
总结
(1)SDH适合应用于开链结构的机器人;
(2)当使用SDH表示树状或闭链结构的机器人时,会产生歧义;
(3)MDH法对开链、树状、闭链结构的机器人都适用。

三、机器人运动学

3.1 创建一个连杆对象

  在机器人工具箱中,还用变量 σ i \sigma _ { i } σi表示机器人的关节类型, σ i = 0 \sigma _ { i } = 0 σi=0表示转动关节, σ i = 1 \sigma _ { i } = 1 σi=1表示移动关节(若未指定该参数,默认为转动关节)。
  在工具箱中,用函数Link( )可以创建一个机械臂对象,其中输入的参数顺序分别是:关节角 θ i \theta _ { i } θi、连杆偏距 d i d_{i} di、连杆长度 a i − 1 a_{i-1} ai1、连杆转角 α i − 1 \alpha_{i-1} αi1和关节类型。例如,创建一个关节角为30°,连杆偏距为0.2m,连杆长度为0.5m,连杆转角为60°,关节类型为旋转关节的连杆,代码如下所示:

L = Link([pi/6, 0.2, 0.5, pi/3, 0])

在这里插入图片描述

这里,Revolute表示转动关节,std表示标准D-H参数法,offset表示关节偏移量。可以通过以下命令获得连杆的各个参数:
 ● 获取连杆的关节类型:L.type( )(注意:老版本的工具箱是L.RP);
 ● 获取连杆的关节角:L.theta;
 ● 获取连杆的连杆偏距:L.d;
 ● 获取连杆的连杆长度:L.a;
 ● 获取连杆的连杆转角:L.alpha。

在这里插入图片描述
 ● 获取改连杆的齐次变换矩阵:L.A( θ \theta θ),例如连杆转动了30°,其齐次变换矩阵T为:

在这里插入图片描述

3.2 创建一个平面3-DOF的机械臂

  这里创建了一个平面三R机构(三个转动关节),该平面三连杆机构的DH参数表如下所示:
在这里插入图片描述

% standard-表示标准DH法
%               theta(z)   d(z)     a(x)     alpha(x)  
RRR_L(1) = Link([  0       0        1        0    ],'standard');
RRR_L(2) = Link([  0       0      0.8        0    ],'standard');
RRR_L(3) = Link([  0       0      0.6        0    ],'standard');

运行结果:
在这里插入图片描述

通过构造函数SerialLink( )可以给创建的机械臂对象命名,并显示出对象的信息。输入命令:

three_link = SerialLink(RRR_L, 'name', 'three-link-RRR')

运行结果:

在这里插入图片描述
用以下的命令可以获取已创建机械臂的各个参数:

在这里插入图片描述
运行结果:

在这里插入图片描述

同时也可以对创建的机械臂对象进行复制,如复制一个名称为“three_link2”的机械臂输人命令:

three_link2 = SerialLink(RRR_L, 'name', 'three-link-RRR_2')

运行结果:
在这里插入图片描述

使用teach( )函数,可以对创建的机器人进行示教,如图所示:

在这里插入图片描述
在这里插入图片描述

3.3 机器人正运动学

  机器人正运动学即给定一组关节角,计算出机器人末端相对于基坐标系的位置和姿态,如下图:
在这里插入图片描述

  机器人工具箱中,fkine( )可以进行正运动学计算,即给定关节变量,得到末端坐标系关于基坐标系的齐次变换矩阵(位置和姿态)。这里以3.2节的3-DOF平面机械臂为例,当机器人三个关节角都为0°时:

% RRR机械臂
clear;
close all;
clc;

%               theta(z)   d(z)     a(x)     alpha(x)  
RRR_L(1) = Link([  0       0        1        0    ],'standard');
RRR_L(2) = Link([  0       0      0.8        0    ],'standard');
RRR_L(3) = Link([  0       0      0.6        0    ],'standard');

three_link = SerialLink(RRR_L, 'name', 'three-link-RRR');
q0 = [0 0 0]'*pi/180;
T0 = three_link.fkine(q0)

运行结果:

在这里插入图片描述

当机器人一关节10°,二关节-30°,三关节60°时,机器人末端的位置和姿态如图:

在这里插入图片描述
可以用plot( )函数绘制此时机器人的状态,如图:
在这里插入图片描述

例子:给定平面3-RRR机械臂各个关节的角度如图所示,求解机器人运动过程中末端点的三维坐标

在这里插入图片描述

% RRR机械臂
clear;
close all;
clc;

%               theta(z)   d(z)     a(x)     alpha(x)  
RRR_L(1) = Link([  0       0        1        0    ],'standard');
RRR_L(2) = Link([  0       0      0.8        0    ],'standard');
RRR_L(3) = Link([  0       0      0.6        0    ],'standard');

three_link = SerialLink(RRR_L, 'name', '3-DOF');

t = 0:0.05:4;
m = length(t);
theta1 = 120*sin(4*pi*t/4);
theta2 = 60*sin(2*pi*t/4);
theta3 = 30*sin(2*pi*t/4);

q = [theta1;theta2;theta3]*pi/180;

for i = 1:m
    T = three_link.fkine(q(:,i)');
    x(i) = T.t(1);
    y(i) = T.t(2);
    z(i) = T.t(3);
    
    subplot(3,3,[1 4 7])
    hold on
    plot3(x(i),y(i),z(i),'r*');
    hold on
    three_link.plot(q(:,i)');
    
    subplot(3,3,2)
    hold on
    plot(t(i),q(1,i)*180/pi,'b.')
    xlabel('time /s')
    ylabel('\theta_1 /deg')
    
    subplot(3,3,5)
    hold on
    plot(t(i),q(2,i)*180/pi,'r.')
    xlabel('time /s')
    ylabel('\theta_2 /deg')
    
    subplot(3,3,8)
    hold on
    plot(t(i),q(3,i)*180/pi,'m.')
    xlabel('time /s')
    ylabel('\theta_3 /deg')
    
    subplot(3,3,3)
    hold on
    plot(t(i),x(i),'b.')
    xlabel('time /s')
    ylabel('x /m')
    
    subplot(3,3,6)
    hold on
    plot(t(i),y(i),'r.')
    xlabel('time /s')
    ylabel('y /m')
    
    subplot(3,3,9)
    hold on
    plot(t(i),z(i),'m.')
    xlabel('time /s')
    ylabel('z /m')
end

运行结果:
在这里插入图片描述

3.4 机器人逆运动学(未完待续)

笔者最近有点忙。。。

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

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

相关文章

[译]BNF 表示法:深入了解 Python 的语法

[译]BNF 表示法:深入了解 Python 的语法 原文:《BNF Notation: Dive Deeper Into Python’s Grammar》 https://realpython.com/python-bnf-notation/ 在阅读Python文档的时候,你可能已经遇到过BNF(Backus–Naur form)表示法: 下…

运维:记一次寻找定时任务并删除的经历

前言 我相信接手别人的服务器、或者在没有任何文档的情况去看自己原先的服务器,都或多或少会遇到莫名其妙的服务器独有规则。 比如你服务本身跑的好好的,突然啪的一下,没了! 什么原因导致的呢?其中,很大可能是定时任务在作祟。 原因分析 本次,我遇到的问题是:在Ubuntu系…

如何用Elementor创建WordPress会员网站

在下面的文章中,我们将向您展示如何使用Elementor和MemberPress在WordPress中轻松构建会员网站。这篇文章将涵盖WordPress会员网站设置过程、会员资格和受保护内容创建、重要页面和登录表单设计、电子邮件通知管理、报告等。 目录 什么是WordPress会员网站&#x…

某品零食交易平台设计与实现|基于springboot+ Mysql+Java的某品交易平台设计与实现(源码+数据库+文档+PPT)

目录 基于springboot MysqlJava的某品交易平台设计与实现 摘 要 系统详细设计 数据库设计 论文参考 源码获取 文末获取源码联系 基于springboot MysqlJava的某品交易平台设计与实现 摘 要 随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的…

HCIA-HarmonyOS设备开发V2.0证书

目录 一、不墨迹,上证书二、考试总结三、习题四、知识点五、坚持就有收获 HCIA-HarmonyOS Device Developer V2.0 开发者能力认证考试已通过。 一、不墨迹,上证书 一个多月的努力,验证了自己的学习成果,也认识到自己有待提升之处…

promise处理数组里面的多任务,等所有任务处理完再执行后续逻辑

业务需求,有一个数组里面的数据,需要发送异步任务验证这里面的数据是否可用,然后再将可用的数据存储到本地,原本使用的方式是使用forEach遍历数组,然后在遍历中处理每一个异步函数,等处理完异步函数之后&am…

2024最新AI大模型产品汇总

文章目录 1. 写在前面2. 效率工具3. 聊天机器人4. 应用开发工具5. Prompt工具与社区6. 通用基础大模型7. 训练框架8. 开源数据集9. 推理与部署平台及工具 【作者主页】:吴秋霖 【作者介绍】:Python领域优质创作者、阿里云博客专家、华为云享专家。长期致…

springboot+bootstrap+jsp校园二手书交易平台mlg86

考虑到实际生活中在校园二手书交易系统方面的需要以及对该系统认真的分析,将系统权限按管理员和学生这两类涉及用户划分。 (a) 管理员;管理员使用本系统涉到的功能主要有个人中心、学生管理、图书类型管理、二手图书管理、通知公告管理、管理员管理、用户留言、系统…

istio pod不启动及访问报RBAC错误问题解决

istio pod不启动问题解决 在kubernetes集群中安装istio之后,在创建的depoyment中已经使用了注入注解sidecar.istio.io/inject: true’配置,但是istio pod不创建,代码示例如下 kind: Deployment apiVersion: apps/v1 metadata:name: name-an…

【Docker】Docker:解析容器化技术的利器与在Linux中的关键作用

🍎个人博客:个人主页 🏆个人专栏:Linux ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 Docker 是什么? Docker 的作用 Docker 在 Linux 中的重要性 结语 我的其他博客 前言 随着软件开发的不断发展&…

012 Linux_线程控制

前言 本文将会向你介绍线程控制(创建(请见上文),终止,等待,分离) 线程控制 线程终止 pthread_t pthread_self(void); 获取线程自身的ID 如果需要只终止某个线程而不终止整个进程,可以有三种…

鸿蒙实战应用开发:【拨打电话】功能

概述 本示例通过输入电话,进行电话拨打,及电话相关信息的显示。 样例展示 涉及OpenHarmony技术特性 网络通信 基础信息 拨打电话 介绍 本示例使用call相关接口实现了拨打电话并显示电话相关信息的功能 效果预览 使用说明 1.输入电话号码后&#…

7、Linux-防火墙和配置静态ip

一、防火墙(防火墙服务名firewalld) 防火墙配置命令:firewall-cmd firewall-cmd --help:防火墙帮助firewall-cmd --state:查看防火墙状态firewall-cmd --zonepublic --list-ports:查看所有打开的端口firew…

【独立版】表情包小程序完整版源码前后端源码

搭建要求: 1.系统要求Nginx 1.18.0PHP-7.2mysql5.6,开启 ssl,php需要安装 sg11 扩展 2.设置伪静态 location / { index index.php index.html index.htm; if (!-e $request_filename) { rewrite ^/(.*)$ /index.php?s$1; } } location /a…

【三维重建】VastGaussian:用于大场景重建的大3D Gaussian(CVPR 2024)

题目:VastGaussian: Vast 3D Gaussians for Large Scene Reconstruction 来源:清华大学;华为诺亚;中国科学院 链接:https://vastgaussian.github.io/ 总结:VastGaussian:基于3D GS的分块优化重…

栈帧、ELF

前言 大家好我是jiantaoyab,这是我所总结作为学习的笔记第四篇,在这里分享给大家,还有一些书籍《深入理解计算机系统》《计算机组成:结构化方法》《计算机体系结构:量化研究方法》《程序员的自我修养》,今天我们来了解程序栈 为什…

Linux下du命令和df命令的使用

du命令作用是估计文件系统的磁盘已使用量,常用于查看文件或目录所占磁盘容量。df命令是统计磁盘使用情况,可以用来查看磁盘已被使用多少空间和还剩余多少空间。du命令语法du [选项] [文件或目录名称]参数:-a:--all, 列…

Ethersacn的交易数据是什么样的(2)

分析 Raw Transanction RLP(Recursive Length Prefix)是一种以太坊中用于序列化数据的编码方式。它被用于将各种数据结构转换为二进制格式,以便在以太坊中传输和存储。RLP 是一种递归的编码方式,允许对复杂的数据结构进行编码。所…

5G工业智能网关保障煤矿安全生产

随着物联网技术发展与煤矿需求的持续激增,矿山矿井的分布范围广泛、户外环境恶劣等管理问题急需解决,而物联网网关工业级设计能够无惧恶劣环境干扰,轻松解决户外网络部署问题。 工业网关通过采集矿井内的各类传感器数据对矿井进行远程监控&a…

【图论】Dijkstra 算法求最短路 - 构建邻接矩阵(带权无向图)

文章目录 例题:到达目的地的方案数题目描述代码与解题思路构建带权无向图的邻接矩阵 例题:到达目的地的方案数 题目链接:1976. 到达目的地的方案数 题目描述 代码与解题思路 func countPaths(n int, roads [][]int) int {g : make([][]int…