工业机器人课程设计

工业机器人课程设计
工业机器人课程设计

工业机器人课程设计 Company number:【WTUT-WT88Y-W8BBGB-BWYTT-19998】

工业机器人课程设计基于Matlab的工业机器人运动学和雅克比较矩阵求解

目录

摘要

机器人学作为一门高度交叉的前沿学科,引起许多具有不同专业背景人们的广泛兴趣,对其进行深入研究,并使其获得快速发展。尤其是近年来各种新兴技术飞速发展,机械工业产品的自动化、高精度、重负载等性能指标变得越来越突出。因此在机器人学的计算中就要求更高的精度,计算机技术的发展很好的解决了这一问题。本文将以PUMA560为例,利用个人电脑平台的Matlab对其运动学的正解、逆解以及雅克比矩阵进行计算研究。

关键词

PUMA560 Matlab 正解逆解雅克比矩阵微分变换法矢量积法

ABSTRACT

As a highly interspersed subject, the robotics makes many people who major in different subject interest in it, research and develop it. Especially in recent years, with the rapid development of varieties of emerging technologies, mechanical products indexes of automation,high precision and the re-load are becoming more and more outstanding. There is a need of greater precision in the calculation of robotics and computer technology makes it possible. In this paper we will use Matlab to research the kinematics problem and Jacobian array of PUMA560.

KEY WORDS

PUMA560 Matlab Kinematics problem Positive-solution Inverse-solution Jacobian array Differential transformation Vector product transformation

PUMA560机器人简介

PUMA560是属于关节式机器人,6个关节都是转动关节,如图1—1所示,前三个关节确定手腕参考点的位置,后三个关节确定手腕的方位。和大多数工业机器人一样,后三个关节轴线交于一点。该点选作为手腕参考点,也选作为{4}、{5}、{6}的原点。关节一的轴线为垂直方向,关节2和关节3的轴线

为水平,且平行,距离为a 2。关节1和关节2的轴线垂直相交,关节3和关节4的轴线垂直交错。距离为a 3。各个连杆坐标系如图1—1所示,相应的连杆参数列

于表1—2中。其中,mm a 8.4312=,mm a 32.203=,mm d 09.1492=,

mm d

07.4333

=。 在更进一步了解

PUMA560机器人的转动角度问题时,我们先来定义一下PUMA560机器人的初始位姿。首先,定义机器人的初始位置.取大臂处于某一朝向

时,作为腰关节的初始位置.大臂处在水平位置时,作为肩关节的初始位置.小臂处在下垂位置,关节轴线Z4和Z0平行时,作为肘关节的初始位置.关节轴线Z5和Z3平行时,作为腕扭转关节的初始位置.关节轴线Z6和Z4平行时,作为腕弯曲关节的初始位置.抓手两个指尖的连线与大臂平行时,作为腕旋转关节的初始位置.在上述初始位置的前下,各个关节的零点位置得到确定.

PUMA560机器人的正解

1、确定D-H坐标系

PUMA 560的关节全为转动关节:

Zi坐标轴:沿着i+1关节的运动轴;

Xi坐标轴:沿着Zi和Zi-1的公法线,指向离开Zi-1轴的方向;

Yi坐标轴:按右手直角坐标系法则制定;

连杆长度ai; Zi和Zi-1两轴心线的公法线长度;

连杆扭角αi: Zi和Zi-1两轴心线的夹角;

两连杆距离di: Xi和Xi-1两坐标轴的公法线距离;

两杆夹角θi :Xi和Xi-1两坐标轴的夹角;

2、确定各连杆D-H参数和关节变量

确定各连杆D-H参数和关节变量:

3、求出两杆间的位姿矩阵

第i连杆与第i-1连杆间的变换矩阵

A i =Rot(x, αi-1)trans(a i-1,0,0)Rot(z, θi)trans(0,0,d i)

=

1

1111

1111

0001

i i i

i i i i i i i

i i i i i i i

c s a

s c c c s s d

s s c s c c d

θθ

θαθααα

θαθααα

-

----

----

-

??

??

--

??

??

??

??

相邻两个连杆间的位姿变换矩阵

4、求末杆的位姿矩阵

由上面的矩阵,我们可以得到最终结果:

5、Matlab编程

运行,根据提示输入

16

θθ

-的值,回车后的出T的解如下:

T=

0 0

0 0

0 0

0 0 0

6、验证

由课本给出的验证公式进行所编程序的验证,经验证,编程所得结果与课本给出验证公式得到的结果一致。进一步表明所编程序是正确的。

PUMA560机器人的逆解

将PUMA 560的运动方程()写为:

若末端连杆的位姿已经给定,求关节变量16θθ- 的值成为运动逆解。 1、求1θ

式中,正、负号对应于1θ的两个可能解。

2、求

由以上两式的平方加上112-s x y p c p d +=的平方可以得到:

3343a c d s k -=(2—2)

在上式中,22222222324

2

2x y z p p p a a d d k a ++----=

式(2—2)中已经消去2θ,所以可以由三角代换求解得到3θ的解。 所以:在3θ的表达式中正、负号对应于3θ的两种可能解。

3、求

123123232312312323233611200

10

1x

x x x y

y y y z

z z z c c s c s a c n o p a c s s s c a s n o a p T s c d n o a p --????????---????=????--????????

(2—3) 令矩阵方程(2—3)两端的元素(1,4)和(2,4)分别对应相等,则得两方程: 由以上两式可得23θ的表达式: 由求得的23θ,可求出2θ:

根据13θθ和解的四种可能组合可以得到相应的23θ四种可能值,于是可得到 的

2θ四种可能解。

4、求

令上式的矩阵方程的两端的元素(1,4)和(2,4)分别对应相等,则得两方程: 当S5=0时,机械手处于奇异形位.此时,关节轴4和6重合,只能解出4θ和6θ的和或差.奇异形位可以由式4θ的表达式中的atan2的两个变量是否接近零来判别.若都接近零,则为奇异形位,否则,不是奇异形位.在奇异形位时,可任意选取4θ值,再计算相应的6θ值。

5、求

根据求出的4θ,可以进一步解出5θ:

因为1θ,2θ,3θ,4θ在前面均已解出,逆变换0141234(,,,)T θθθθ-为: 令矩阵方程两端的元素(1,3)和(3,3)分别对应相等,则得两方程: 所以可以得到5θ的最终表达式:555atan2(,)s c θ=

6、求

令矩阵方程两端的元素(3,1)和(1,1)分别对应相等,则得两方程: 得到最后6θ的表达式:666atan2(,)s c θ=

7、解的多重性

PUMA560的运动反解可能存在8种解,但是,由于结构的限制,例如各关节变量不能在全部360度范围内运动,有些解不能实现。在机器人存在多种解的情况下,应选取其中最满意的一组解,以满足机器人的工作要求。 8、Matlab 编程

在Matlab 中运行,根据提示输入,,,,,,,,x x x y y y z z z n o a n o a n o a 的值并回车,可得i θ的8组解值如下: 0 0 0 0

9、对于机器人解的分析

通过编程可以知道,我们最终得到八组解。然后对八组解进行分析,对于

1θ的变化范围为从00160~160-,所以程序中我们得到的两个解都是正确的。然后对2θ进行分析,由于2θ的角度变化范围是从0045~225-,所以在我们所得到的结果中,后四组是超出2θ的变化范围的,所以我们可以舍去后四组解。再逐个对3θ、4θ、5θ、6θ进行角度分析,最终可获得适合的解。

机器人的雅克比矩阵

1、定义

机械手的操作速度与关节速度间的线性变换定义为机械手的雅可比矩阵。 2、雅可比矩阵的求法 (1)矢量积法 对移动关节 对转动关节

(2)微分变换法

对于转动关节i,相对连杆i-1,绕坐标系{i}的i z 轴所作微分转动i d θ,其微分运动矢量为(3-117),对应的夹持器的微分运动矢量为(3-118):

于是,J(q)的第i 列如下:对转动关节i :()()(),z z T T li ai z z z z p n n J p o J o p a a ?????

????=?=?????????????

对移动关节i :0,00z T T li z ai z n J o J a ??

??

????==????????????

3、微分变换法求机器人的雅可比矩阵

PUMA560的6个关节都是转动关节,所以利用(3-121)求取雅克比矩阵的列矢量。

,,??

?????=????

???=??????i o n i i i i i o n i i z p z J q z p z w v

对于第1个关节来说,将16T 中的n,o,a,p 向量代入式(3-121),得到雅克比矩阵的列矢量。

其中x T J 1、x T T 2、x T T 3的表达式如下所示:

对于第2个关节来说,将26T 中的n,o,a,p 向量代入式(3-121),得到雅克比矩阵的列矢量()2T J q

可以得到:()2222454664564645T

x T

y T T

z J J J J q s c c s c s c s c c s s ????????=??--????-??

????

其中x T J 2、y T J 2、z T J 2三个参数的表达式如下所示: 同理,可求得:

所以又以上六个16?矩阵便最后组成了66?的雅克比矩阵。 4、矢量积法求机器人的雅克比矩阵

PUMA560的6个关节都是转动关节,因而其雅克比矩阵具有下列形式:

5、Matlab 编程

(1)用微分变换法求解雅克比矩阵

在Matlab 中运行,根据提示输入16θθ-的值并回车,得雅克比矩阵如下: 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 (2)用矢量积法求解雅克比矩阵

在Matlab 中运行,根据提示输入16θθ-的值并回车,得雅克比矩阵如下: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0

从以上结果中我们可以看出其运行结果与用微分变换编程所得到的结果是一致的,进一步证明了所编写程序的正确性。

附录1、程序

1、运动学正解

function zhengjie(c1,c2,c3,c4,c5,c6)

clc;

a2=;

a3=;

d2=;

d4=;

d6=;

c1=input('c1=');

c2=input('c2=');

c3=input('c3=');

c4=input('c4=');

c5=input('c5=');

c6=input('c6=');

T1=[cosd(c1) -sind(c1) 0 0;

sind(c1),cosd(c1),0,0;

0,0,1,0;

0 0 0 1];

T2=[cosd(c2),-sind(c2),0,0;

0,0,1 d2;

-sind(c2) -cosd(c2) 0 0;

0 0 0 1];

T3=[cosd(c3) -sind(c3) 0 a2;

sind(c3) cosd(c3) 0 0;

0 0 1 0;

0 0 0 1];

T4=[cosd(c4) -sind(c4) 0 a3 ;

0 0 1 d4;

-sind(c4) -cosd(c4) 0 0;

0 0 0 1];

T5=[cosd(c5) -sind(c5) 0 0;

0 0 -1 0;

sind(c5) cosd(c5) 0 0;

0 0 0 1];

T6=[cosd(c6) -sind(c6) 0 0;

0 0 1 0;

-sind(c6) -cosd(c6) 0 0;

0 0 0 1];

T=T1*T2*T3*T4*T5*T6;

disp('T=');

disp(T)

2、运动学逆解

function nijie(T)

clc;

nx=input('nx=');ox=input('ox=');ax=input('ax='); ny=input('ny=');oy=input('oy=');ay=input('ay='); nz=input('nz=');oz=input('oz=');az=input('az='); px=input('px=');py=input('py=');pz=input('pz='); a2=;

a3=;

d2=;

d4=;

c1=[atan2(py,px)-atan2(d2,sqrt(px*px+py*py-d2*d2)),atan2(py,px)-atan2(d2,-sqrt(px*px+py*py-d2*d2))];%求解c1

c1=c1/pi*180;

k=(px*px+py*py+pz*pz-a2*a2-a3*a3-d2*d2-d4*d4)/(2*a2);

c3=[atan2(a3,d4)-atan2(k,sqrt(a3*a3+d4*d4-k*k)),atan2(a3,d4)-atan2(k,-

sqrt(a3*a3+d4*d4-k*k))];%求解c3

c3=c3/pi*180;

for i=1:2

for j=1:2

m1=cosd(c1(i));m2=sind(c1(i));

n1=cosd(c3(j));n2=sind(c3(j));

c23(i,j)=atan2(-(a3+a2*n1)*pz+(m1*px+m2*py)*(a2*n2-d4),(-

d4+a2*n2)*pz+(m1*px+m2*py)*(a2*n1+a3));

c23(i,j)=c23(i,j)/pi*180;

c2(i,j)=c23(i,j)-c3(1,j);

end

end%求解c2

for i=1:2

for j=1:2

m1=cosd(c1(i));n1=sind(c1(i));

m2=cosd(c23(i,j));n2=sind(c23(i,j));

c41(i,j)=atan2(-ax*n1+ay*m1,-ax*m1*m2-ay*n1*m2+az*n2);

c411(i,j)=atan2(ax*n1-ay*m1,ax*m1*m2+ay*n1*m2-az*n2);

c41(i,j)=c41(i,j)/pi*180;

c411(i,j)=c411(i,j)/pi*180;

end

end%求解c4

c4=[c41,c411];

disp(c4)

c23=[c23(1,:),c23(1,:);c23(2,:),c23(2,:)];

for i=1:2

for j=1:4

m1=cosd(c1(i));n1=sind(c1(i));

m2=cosd(c23(i,j));n2=sind(c23(i,j));

m3=cosd(c4(i,j));n3=sind(c4(i,j));

sinc5(i,j)=-ax*(m1*m2*m3*n1*n3)-ay*(n1*m2*m3-

m1*n3)+az*(n2*m3);

cosc5(i,j)=ax*(-m1*n2)+ay*(-n1*n2)+az*(-m2);

c5(i,j)=atan2(sinc5(i,j),cosc5(i,j));

c5(i,j)=c5(i,j)/pi*180;

end

end%求解c5

for i=1:2

for j=1:4

m1=cosd(c1(i));n1=sind(c1(i));

m2=cosd(c23(i,j));n2=sind(c23(i,j));

if sind(c5(i,j))<&&sind(c5(i,j))>

c4(i,j)=0;

end

end

end%奇异形位判断

for i=1:2

for j=1:4

m1=cosd(c1(i));n1=sind(c1(i));

m2=cosd(c23(i,j));n2=sind(c23(i,j));

m3=cosd(c4(i,j));n3=sind(c4(i,j));

m4=cosd(c5(i,j));n4=sind(c5(i,j));

sinc6(i,j)=-nx*(m1*m2*n3-n1*m3)-

ny*(n1*m2*n4+m1*m4)+nz*(n2*n3);

cosc6(i,j)=nx*((m1*m2*m3+n1*n3)*m4-

m1*n2*n4)+ny*((n1*m2*m3-m1*n3)*m4-m1*m2*m4)-

nz*(n2*m3*m4+m2*n4);

c6(i,j)=atan2(sinc6(i,j),cosc6(i,j));

c6(i,j)=c6(i,j)/pi*180;

end

end%求解c6

C1=[c1(1),c1(1),c1(1),c1(1),c1(2),c1(2),c1(2),c1(2)];

C2=[c2(1,:),c2(1,:),c2(2,:),c2(2,:)];

C3=[c3(1),c3(2),c3(1),c3(2),c3(1),c3(2),c3(1),c3(2)];

C23=[c23(1,:),c23(2,:)];

C4=[c4(1,:),c4(2,:)];

C5=[c5(1,:),c5(2,:)];

C6=[c6(1,:),c6(2,:)];%排序

C=[C1;C2;C3;C4;C5;C6];%输出

C=C';

disp(C);

3、微分变换法求雅克比矩阵

function wfbh(c1,c2,c3,c4,c5,c6)

c1=input('c1=');

c2=input('c2=');

c3=input('c3=');

c4=input('c4=');

c5=input('c5=');

c6=input('c6=');

a2=;

a3=;

d2=;

d4=;

d6=;

T10=[cosd(c1) -sind(c1) 0 0; sind(c1),cosd(c1),0,0;

0,0,1,0;

0 0 0 1];

T21=[cosd(c2),-sind(c2),0,0; 0,0,1 d2;

-sind(c2) -cosd(c2) 0 0;

0 0 0 1];

T32=[cosd(c3) -sind(c3) 0 a2; sind(c3) cosd(c3) 0 0;

0 0 1 0;

0 0 0 1];

T43=[cosd(c4) -sind(c4) 0 a3 ;

0 0 1 d4;

-sind(c4) -cosd(c4) 0 0;

0 0 0 1];

T54=[cosd(c5) -sind(c5) 0 0;

0 0 -1 0;

sind(c5) cosd(c5) 0 0;

0 0 0 1];

T65=[cosd(c6) -sind(c6) 0 0;

0 0 1 0;

-sind(c6) -cosd(c6) 0 0;

0 0 0 1];

T64=T54*T65;

T63=T43*T64;

T62=T32*T63;

T61=T21*T62;

T60=T10*T61;

T(:,:,1)=T61;

T(:,:,2)=T62;

T(:,:,3)=T63;

T(:,:,4)=T64;

T(:,:,5)=T65;

N=T(1:3,1,:);

O=T(1:3,2,:);

A=T(1:3,3,:);

P=T(1:3,4,:);

PN=cross(P,N);

PN=PN(3,1,:);

PO=cross(P,O);

PO=PO(3,1,:);

PA=cross(P,A);

PA=PA(3,1,:);

J=[PN;PO;PA;N(3,1,:);O(3,1,:);A(3,1,:)]; J6=[0;0;0;0;0;1];

J=[J(:,:,1),J(:,:,2),J(:,:,3),J(:,:,4),J(:,:,5),J6]; R60=T60(1:3,1:3);

J=[R60,zeros(3);zeros(3),R60]*J;

disp(J);

4、矢量积法求雅克比矩阵

function wfbh(c1,c2,c3,c4,c5,c6)

c1=input('c1=');

c2=input('c2=');

c3=input('c3=');

相关主题
相关文档
最新文档