0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于MATLAB的关节型六轴机械臂轨迹规划仿真

新机器视觉 来源:CSDN-mustvvvics 2023-02-08 09:12 次阅读

1.实验目的

基于机器人学理论知识,利用标准D-H参数法建立关节型机器人的数学模型,使用Matlab的Robotics Toolbox工具包搭建模型。

tip:实验工具:Matlab R2021a (有很多玄学问题是因为软件版本)
以及注意先安装Robotics Toolbox工具包!!

2.实验内容

2.1标准D-H参数法

标准D-H参数法常用于建立关节型机器人的数学模型,D-H参数法是一种对连杆的坐标描述,而关节机器人本质上就是一系列连杆通过关节连接起来而组成的空间开式运动链。

对于连杆本身,其功能在于保持其两端的关节轴线具有固定的几何关系,连杆的特性由轴线决定,通常用四个连杆参数来描述,连杆长度,连杆扭转角,连杆偏移量和关节角。

本实验给定的参数表:

24de8910-a736-11ed-bfe3-dac502259ad0.png

2.2实验中使用的Matlab函数

Link函数


用于定义六轴机器人的一个轴。


包含了机器人的运动学参数、动力学参数、刚体惯性矩参数、电机和传动参数;


可采用DH法建立模型,其中包含参数:关节转角,关节距离,连杆长度,连杆转角,关节类型(0转动,1移动)。

% 定义六轴机器人的一个轴
L(1) = Link([theta1, D1, A1, alpha1, offset1], 'standard')

SerialLink函数


用于构建机械臂。


它的类函数比较多,包括显示机器人、动力学、逆动力学、雅可比等;

% 'six'为机械臂名称
robot = SerialLink(L,'name','six');

fkine正解函数


用于求解出末端位姿p。

theta = [0.1,0,0,0,0,0];  %指定的关节角
p=robot.fkine(theta)    %fkine正解函数,根据关节角theta,求解出末端位姿p

ikine逆解函数


用于求解出关节角q。

q=ikine(robot,p)      %ikine逆解函数,根据末端位姿p,求解出关节角q

轨迹规划


(1)jtraj


已知初始和终止的关节角度,利用五次多项式来规划轨迹;

T1=transl(0.5,0,0);   %根据给定起始点,得到起始点位姿
T2=transl(0,0.5,0);   %根据给定终止点,得到终止点位姿
init_ang=robot2.ikine(T1);%根据起始点位姿,得到起始点关节角
targ_ang=robot2.ikine(T2);%根据终止点位姿,得到终止点关节角
step = 20;
[q ,qd, qdd]=jtraj(init_ang,targ_ang,step); %五次多项式轨迹,得到关节角度,角速度,角加速度,50为采样点个数

(2)ctraj


已知初始和终止的末端关节位姿,利用匀加速、匀减速运动来规划轨迹。

T0 = robot2.fkine(init_ang);%运动学正解
T1 = robot2.fkine(targ_ang);%运动学正解
Tc = ctraj(T0,T1,step);   %得到每一步的T阵
tt = transl(Tc);

3.实验结果

24f0143c-a736-11ed-bfe3-dac502259ad0.jpg

2501a9fe-a736-11ed-bfe3-dac502259ad0.jpg

25202aaa-a736-11ed-bfe3-dac502259ad0.jpg

25334536-a736-11ed-bfe3-dac502259ad0.jpg2549dc56-a736-11ed-bfe3-dac502259ad0.jpg

4.全部代码

%% MATLAB素质三连
clear;
close all;
clc;
%% 实验一 基于MATLAB的关节型六轴机械臂仿真


%% 参数定义
%机械臂为六自由度机械臂
clear L;
 
%角度转换
angle=pi/180; %度
 
%D-H参数表
theta1 = 0;  D1 = 0.4;  A1 = 0.025; alpha1 = pi/2; offset1 = 0;
theta2 = pi/2;D2 = 0;   A2 = 0.56; alpha2 = 0;  offset2 = 0;
theta3 = 0;  D3 = 0;   A3 = 0.035; alpha3 = pi/2; offset3 = 0;
theta4 = 0;  D4 = 0.515; A4 = 0;   alpha4 = pi/2; offset4 = 0;
theta5 = pi; D5 = 0;   A5 = 0;   alpha5 = pi/2; offset5 = 0;
theta6 = 0;  D6 = 0.08; A6 = 0;   alpha6 = 0;  offset6 = 0;


%% DH法建立模型,关节转角,关节距离,连杆长度,连杆转角,关节类型(0转动,1移动)


L(1) = Link([theta1, D1, A1, alpha1, offset1], 'standard')
L(2) = Link([theta2, D2, A2, alpha2, offset2], 'standard')
L(3) = Link([theta3, D3, A3, alpha3, offset3], 'standard')
L(4) = Link([theta4, D4, A4, alpha4, offset4], 'standard')
L(5) = Link([theta5, D5, A5, alpha5, offset5], 'standard')
L(6) = Link([theta6, D6, A6, alpha6, offset6], 'standard')


% 定义关节范围
L(1).qlim =[-180*angle, 180*angle];
L(2).qlim =[-180*angle, 180*angle];
L(3).qlim =[-180*angle, 180*angle];
L(4).qlim =[-180*angle, 180*angle];
L(5).qlim =[-180*angle, 180*angle];
L(6).qlim =[-180*angle, 180*angle];


%% 显示机械臂
robot0 = SerialLink(L,'name','six');
f = 1          %画在第1张图上
theta = [0 pi/2 0 0 pi 0];    %初始关节角度
figure(f)
robot0.plot(theta);
title('六轴机械臂模型');
%% 加入teach指令,则可调整各个关节角度
robot1 = SerialLink(L,'name','sixsix');
f = 2
figure(f)
robot1.plot(theta);
robot1.teach
title('六轴机械臂模型可调节');
%% 实验二 基于MATLAB的六轴机械臂轨迹规划仿真


%% 2.2求解运动学正解
robot2 = SerialLink(L,'name','sixsixsix');
theta2 = [0.1,0,0,0,0,0];     %实验二指定的关节角
p=robot2.fkine(theta2)       %fkine正解函数,根据关节角theta,求解出末端位姿p
q=ikine(robot2,p)         %ikine逆解函数,根据末端位姿p,求解出关节角q


%% 2.3 jtraj 已知初始和终止的关节角度,利用五次多项式来规划轨迹
% T1=transl(0.5,0,0);     %根据给定起始点,得到起始点位姿
% T2=transl(0,0.5,0);     %根据给定终止点,得到终止点位姿
T1=transl(0.5,0,0);      %根据给定起始点,得到起始点位姿
T2=transl(0,0.5,0);      %根据给定终止点,得到终止点位姿
init_ang=robot2.ikine(T1);    %根据起始点位姿,得到起始点关节角
targ_ang=robot2.ikine(T2);    %根据终止点位姿,得到终止点关节角
step = 20;
f = 3


%轨迹规划方法
figure(f)
[q ,qd, qdd]=jtraj(init_ang,targ_ang,step); %五次多项式轨迹,得到关节角度,角速度,角加速度,50为采样点个数
grid on
T=robot2.fkine(q);      %根据插值,得到末端执行器位姿
nT=T.T;
plot3(squeeze(nT(1,4,:)),squeeze(nT(2,4,:)),squeeze(nT(3,4,:)));%输出末端轨迹
title('输出末端轨迹');
robot2.plot(q);       %动画演示 


%% 求解位置、速度、加速度变化曲线
f = 4
figure(f)
subplot(3,2,[1,3]);      %subplot 对画面分区 三行两列 占用1到3的位置
plot3(squeeze(nT(1,4,:)),squeeze(nT(2,4,:)),squeeze(nT(3,4,:)));%输出末端轨迹
robot2.plot(q);       %动画演示


figure(f)
subplot(3, 2, 2);
i = 1:6;
plot(q(:,1));
title('位置');
grid on;


figure(f)
subplot(3, 2, 4);
i = 1:6;
plot(qd(:,1));
title('速度');
grid on;


figure(f)
subplot(3, 2, 6);
i = 1:6;
plot(qdd(:,1));
title('加速度');
grid on;


t = robot2.fkine(q);     %运动学正解
rpy=tr2rpy(t);        %t中提取位置(xyz)
figure(f)
subplot(3,2,5);
plot2(rpy);


%% ctraj规划轨迹 考虑末端执行器在两个笛卡尔位姿之间移动 
f = 5
T0 = robot2.fkine(init_ang);   %运动学正解
T1 = robot2.fkine(targ_ang);   %运动学正解


Tc = ctraj(T0,T1,step);     %得到每一步的T阵


tt = transl(Tc);
figure(f)
plot2(tt,'r');
title('直线轨迹');





审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • matlab
    +关注

    关注

    176

    文章

    2928

    浏览量

    228644
  • 机器人
    +关注

    关注

    206

    文章

    27172

    浏览量

    201721
  • 仿真
    +关注

    关注

    50

    文章

    3878

    浏览量

    132294
  • 函数
    +关注

    关注

    3

    文章

    4073

    浏览量

    61400
  • 机械臂
    +关注

    关注

    10

    文章

    478

    浏览量

    23920

原文标题:基于MATLAB的关节型六轴机械臂轨迹规划仿真

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    LabVIEW的工业机器人运动控制系统

    LabVIEW开发工业机器人运动控制系统 本项目开发了一个高效的工业机器人控制系统,重点关注于运动学算法和轨迹规划算法的实现和测试。LabVIEW作为一个关键技术,在项目中扮演了核
    发表于 12-21 20:03

    基于LabVIEW和SolidWorks改进机械的设计流程

    `在求解机器人手臂的逆运动学方程后,无需装配物理测试平台,利用开发测试方程和NI LabVIEW VI的平台,即可仿真测试运动性能并优化设计方法。  解决方案:  使用LabVIEW NI
    发表于 02-12 15:56

    labview 上位机 机械

    大家好,我是一个labview的新人,最近我要做一个毕业设计,需要用USB摄像头采集数据,在用labview做一个上位机控制机械手,请问我要怎么实现?
    发表于 04-15 14:10

    【NanoPi M2申请】机械控制开发

    系统控制的机械控制开发系统,这样可实现由物联网对机械进行远程控制,这样大大地扩大机械的操作
    发表于 04-27 16:16

    请问水平两机械如何控制轨迹

    请问水平关节机器人,步进电机驱动的,一般都是用什么软硬件来控制呢,点到点现在可以实现,如果要求两联动末端走直线要怎么办呢?本人新手,非常感谢。
    发表于 11-30 18:35

    6机器人 轨迹 动态规划

    对于机械运动,当构建轨迹方程完成,然后进行插补。在插补过程中想要再次构建轨迹方程,然后对新的轨迹方程进行插补,主要是想实现新旧
    发表于 12-11 17:18

    做毕设,需要用2812控制由舵机组成的三关节机械,求助

    题目是基于DSP的三关节机械轨迹跟踪控制系统设计主要任务是以DSP-TMS320F2812控制器作为机械
    发表于 04-10 21:42

    【智能控制】机械手参数辨识——双关节机械动力学方程

    【智能控制】机械手参数辨识——双关节机械动力学方程.zip
    发表于 01-11 22:23

    通过ROS控制真实机械之延时时间精确控制

    根据之前的配置,我们已经可以通过move_group发送出机械关节运动的轨迹,并且通过三次样条插补的方法,赋予各个关节在特定角度时的速度
    发表于 06-28 09:45

    深圳关节机械手系统,支持6关节,8联动加工时间更短

    Android系统方便人机交互,手柄示教编程,可实现零基础编程。该关节机械手系统已经广泛应用到等离子切割/激光切割,焊接,抛光,喷涂等行业。关节机械手系统特点:1、最多支持6
    发表于 08-13 09:56

    深圳关节机械手系统有什么特点?

    四元数关节机械手系统是由多个关节组成,以之间的多自由度转动作为运动轨迹的一种自动化机器人
    发表于 10-21 13:46

    如何对机械关节速度进行动态绘图?

    如何对机械关节速度进行动态绘图?
    发表于 11-03 06:05

    基于单片机的三机械控制怎么实现

    文章目录三机械的控制原理三机械接线三
    发表于 12-13 07:14

    基于STC8H1K28双机械驱动模块设计

    ■ 前言这款双机械是应用于实验室中进行自动样品转换的执行机构。为了能够在一定范围内将试剂瓶(试管) 完成自动搬运,需要完成对样品的抓取,提升和放下、水平移动(二维) 等功能。使用带有肘关节
    发表于 02-18 06:01

    六自由度机械轨迹规划仿真

    采用五次多项式插值法进行机械轨迹规划,基于Matlab Robotics Toolbox平台进行关节空间
    的头像 发表于 11-17 16:11 589次阅读
    六自由度<b class='flag-5'>机械</b>臂<b class='flag-5'>轨迹</b><b class='flag-5'>规划</b><b class='flag-5'>仿真</b>