




已阅读5页,还剩23页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
精品教育 -可编辑- 工业机器人课程设计 基于 Matlab 的工业机器人运动学和雅克比较矩阵求解 精品教育 -可编辑- 目录 PUMA560PUMA560 机器人简介机器人简介.4 4 PUMA560PUMA560 机器人的正解机器人的正解.5 5 1、确定 D-H 坐标系.5 2、确定各连杆 D-H 参数和关节变量.5 3、求出两杆间的位姿矩阵.5 4、求末杆的位姿矩阵.6 5、MATLAB编程.7 6、验证.7 PUMA560PUMA560 机器人的逆解机器人的逆解.8 8 1、求 1 .8 2、求 3 .8 3、求 2 .9 4、求 4 .10 5、求 5 .10 6、求 6 .11 7、解的多重性.11 8、MATLAB编程.11 9、对于机器人解的分析.12 机器人的雅克比矩阵机器人的雅克比矩阵.1212 1、定义.12 2、雅可比矩阵的求法.12 3、微分变换法求机器人的雅可比矩阵.13 4、矢量积法求机器人的雅克比矩阵.15 5、MATLAB编程.15 附录附录 .1616 1、程序.16 2、三维图 .24 精品教育 -可编辑- 摘要 机器人学作为一门高度交叉的前沿学科,引起许多具有不同专业背景人们 的广泛兴趣,对其进行深入研究,并使其获得快速发展。尤其是近年来各种新 兴技术飞速发展,机械工业产品的自动化、高精度、重负载等性能指标变得越来 越突出。因此在机器人学的计算中就要求更高的精度,计算机技术的发展很好 的解决了这一问题。本文将以 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 个关节都是转动关节,如图 11 所示, 前三个关节确定手腕参考点的位置,后三个关节确定手腕的方位。和大多数工 业机器人一样,后三个关节轴线交于一点。该点选作为手腕参考点,也选作为 4、5、6的原点。关节一的轴线为垂直方向,关节 2 和关节 3 的轴线为水 平,且平行,距离为。 a2 关节 1 和关节 2 的轴线 垂直相交,关节 3 和关 节 4 的轴线垂直交错。 距离为。各个连杆坐 a3 标系如图 11 所示,相 应的连杆参数列于表 1 2 中。其中, mm a 8 . 431 2 mm a 32.20 3 mm d 09.149 2 。mm d 07.433 3 在更进一步了解 PUMA560 机器人的转动 角度问题时,我们先来 定义一下 PUMA560 机 器人的初始位姿。首先, 定义机器人的初始位置. 精品教育 -可编辑- 取大臂处于某一朝向时,作为腰关节的初始位置.大臂处在水平位置时,作为肩关 节的初始位置.小臂处在下垂位置,关节轴线 Z4 和 Z0 平行时,作为肘关节的初始 位置.关节轴线 Z5 和 Z3 平行时,作为腕扭转关节的初始位置.关节轴线 Z6 和 Z4 平行时,作为腕弯曲关节的初始位置.抓手两个指尖的连线与大臂平行时,作为腕 旋转关节的初始位置.在上述初始位置的前下,各个关节的零点位置得到确定. PUMA560 机器人的正解 1 1、确定、确定 D-HD-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 2、确定各连杆、确定各连杆 D-HD-H 参数和关节变量参数和关节变量 确定各连杆 D-H 参数和关节变量: 连杆连杆 i i变量变量 i i i-1 i-1 a ai-1 i-1 d di i 变量范围变量范围 1 1 1 1000 00 0-160160-160160 2 2 2 2-90-900 0d d2 2-22545-22545 3 3 3 300a a2 20 0-45225-45225 精品教育 -可编辑- 4 4 4 4-90-90a a3 3d d4 4-110170-110170 5 5 5 590900 00 0-100100-100100 6 6 6 6-90-900 00 0-266266-266266 3 3、求出两杆间的位姿矩阵、求出两杆间的位姿矩阵 第 i 连杆与第 i-1 连杆间的变换矩阵 Ai =Rot(x, i-1)trans(ai-1,0,0)Rot(z, i)trans(0,0,di) = = 1 1111 1111 0 0001 iii iiiiiii iiiiiii csa s cc cssd s sc sccd 相邻两个连杆间的位姿变换矩阵 11 110 1 00 00 0010 0001 cs sc T 22 1 2 22 00 0010 00 0001 cs T sc 33 332 3 00 00 0010 0001 cs sc T 44 3 4 44 00 0010 00 0001 cs T sc 55 4 5 55 00 0010 00 0001 cs T sc 66 5 6 66 00 0010 00 0001 cs T sc 4 4、求末杆的位姿矩阵、求末杆的位姿矩阵 0012345 6112233445566 ( )()()()()()TTTTTTT 精品教育 -可编辑- 001 616 0001 xxxx yyyy zzzz noap noap TT T noap 由上面的矩阵,我们可以得到最终结果: 1234 5 64 623 5 614 5 64 6 1234 5 64 623 5 614 5 64 6 234 5 64 623 5 6 1234 5 64 623 5 614 64 5 6 1234 5 64 623 5 614 x y z x y nccc c cs ss s css c cc s nscc c cs ss s ccs c cc s nsc c cs sc s c occc c ss cs s ss c cs c s oscc c ss cs s sc c c 64 5 6 234 5 64 623 5 6 123 4 523 51 4 5 123 4 523 51 4 5 23 4 523 5 1223 234 232 1 1223 234 232 1 3 232 2423 z x y z x y z s c c osc c ss cc s s ac c c ss cs s s as c c ss cc s s as c sc c pc a ca cd sd s ps a ca cd sd c pa sa sd c 5 5、MatlabMatlab 编程编程 运行 zhengjie.m,根据提示输入的值,回车后的出 T 的解如下: 16 T= 0 1.0000 0 -149.0900 0 0 1.0000 864.8700 1.0000 0 0 20.3200 0 0 0 1.0000 精品教育 -可编辑- 6 6、验证、验证 123456 22346 90 ,0,90 ,0,00 431.8,149.09,20.32,433.07,56.25 oo ammdmmammdmmdmm 2 240 6 3 010 001 100 0001 d ad T a 由课本给出的验证公式进行所编程序的验证,经验证,编程所得结果与课本给出验证 公式得到的结果一致。进一步表明所编程序是正确的。 PUMA560 机器人的逆解 将 PUMA 560 的运动方程(3.64)写为: 0012345 6112233445566 ( )()()()()() 0001 xxxx yyyy zzzz noap noap TTTTTTT noap 若末端连杆的位姿已经给定,求关节变量 的值成为运动逆解。 16 1 1、求、求 1 01012345 1162233445566 TTTTTTT 11 111 6 00 00 0010 00010001 xxxx yyyy zzzz csnopa scnoap T noap 2 1212 2 22 1 222 122 sin()/;cos()1 (/) atan2,1 atan2(,)atan2(, yxxy dd dd ppdppd 精品教育 -可编辑- 式中,正、负号对应于的两个可能解。 1 2 2、求、求 3 113 234 2322 3 234232 2 xy z c ps pa cd sa c pa sd ca s 由以上两式的平方加上的平方可以得到: 112 -s xy pc pd (22) 3 34 3 a cd sk 在上式中, 2222222 2324 2 2 xyz pppaadd k a 式(22)中已经消去,所以可以由三角代换求解得到的解。 2 3 所以:在的表达式中正、负号对应于的两种可能解。 3 3 222 33434 atan2(,)atan2( ,)a dkadk 3 3、求、求 2 010345 31236445566 ,TTTTT (2 23 3) 1 231 23232 3 1 231 23232 33 6 112 0 00010001 xxxx yyyy zzzz c cs csa cnopa c ss sca snoap T scdnoap 4 5 64 64 5 64 64 53 5 65 654334 646 4 5 64 64 5 64 64 5 0 0001 c c cs sc c ss sc sa s ss scd TT T s s sc ss c sc cs s 令矩阵方程(23)两端的元素(1,4)和(2,4)分别对应相等,则得两方程: 1 231 23232 33 1 231 23232 34 xyz xyz c s ps c ps pa ca c s ps s pc pa sd 精品教育 -可编辑- 由以上两式可得的表达式: 23 232332 3112 34 42 3112 33 tan2 ()()(), ()()() zxy xy aaa cpc ps pa sd da spc ps pa ca 由求得的,可求出: 23 2 2233 根据解的四种可能组合可以得到相应的四种可能值,于是可得到 13 和 23 的四种可能解。 2 4 4、求、求 4 1 231 23232 3 1 231 23232 33 6 112 0 00010001 xxxx yyyy zzzz c cs csa cnopa c ss sca snoap T scdnoap 令上式的矩阵方程的两端的元素(1,4)和(2,4)分别对应相等,则得两方程: 1 231 23234 5 114 5 xyz xy a c ca s ca sc s a sa cs s 5 41111 231 2323 42111 231 2323 0 atan2(,) atan2(,) xyxyz xyxyz s a sa ca c ca s ca s a sa c a c ca s ca s 当 当 S5=0 时,机械手处于奇异形位.此时,关节轴 4 和 6 重合,只能解出和的和或 4 6 差.奇异形位可以由式的表达式中的 atan2 的两个变量是否接近零来判别.若都接 4 近零,则为奇异形位,否则,不是奇异形位.在奇异形位时,可任意选取值,再计算相 4 应的值。 6 5 5、求、求 5 根据求出的,可以进一步解出: 4 5 精品教育 -可编辑- 010454 4123465566656 ,TTTTT 因为,在前面均已解出,逆变换为: 1 2 3 4 01 41234 ( ,)T 1 23 41 41 23 41 423 42 3 42 43 4 1 23 41 41 23 41 423 42 3 4243 4 1 231 23232 34 0001 c c cs ss c cc ss ca c cd sa c c c ss ss c sc cs sa c sd ca s c ss sca sd 令矩阵方程两端的元素(1,3)和(3,3)分别对应相等,则得两方程: 1 23 41 41 23 41 423 45 1 231 23235 xyz xyz acc cs sas c cc sas cs ac sas sacc 所以可以得到的最终表达式: 5 555 atan2( ,)s c 6 6、求、求 6 0105 512345666 ,TTT 令矩阵方程两端的元素(3,1)和(1,1)分别对应相等,则得两方程: 61 23 41 41 23 41 423 4 61 23 41 451 23 51 23 41 451 23 5 23 4 523 5 ()()() () () xyz xy z sn c c ss cns c sc cn s s cnc c cs scc s sns c cc s cs s s n s c cc s 得到最后的表达式: 6 666 atan2(,)s c 7 7、解的多重性、解的多重性 PUMA560 的运动反解可能存在 8 种解,但是,由于结构的限制,例如各关 节变量不能在全部 360 度范围内运动,有些解不能实现。在机器人存在多种解 的情况下,应选取其中最满意的一组解,以满足机器人的工作要求。 精品教育 -可编辑- 8 8、MatlabMatlab 编程编程 在 Matlab 中运行 nijie.m,根据提示输入的值并回车,可得, xxxyyyzzz n o a n o an o a 的 8 组解值如下: i 90.0000 -2.6918 -84.6272 -180.0000 2.6810 180.0000 90.0000 -0.0000 -90.0000 0 0.0000 0 90.0000 -2.6918 -84.6272 0.0000 -2.6810 -0.0000 90.0000 -0.0000 -90.0000 0 -0.0000 0 -70.4385 180.0000 -84.6272 104.7629 20.2581 74.3103 -70.4385 182.6918 -90.0000 97.5292 19.7387 82.0067 -70.4385 180.0000 -84.6272 -75.2371 -20.2581 -105.6897 -70.4385 182.6918 -90.0000 -82.4708 -19.7387 -97.9933 9 9、对于机器人解的分析、对于机器人解的分析 通过编程可以知道,我们最终得到八组解。然后对八组解进行分析,对于 的变化范围为从,所以程序中我们得到的两个解都是正确的。 1 00 160160 然后对进行分析,由于的角度变化范围是从,所以在我们所 2 2 00 45225 得到的结果中,后四组是超出的变化范围的,所以我们可以舍去后四组解。 2 再逐个对、进行角度分析,最终可获得适合的解。 3 4 5 6 精品教育 -可编辑- 机器人的雅克比矩阵 1 1、定义、定义 机械手的操作速度与关节速度间的线性变换定义为机械手的雅可比矩阵。 ( )( )xx qxJ q q ( ) ( ),1,2,6,1,2, i ij j x q Jqijn q 2 2、雅可比矩阵的求法、雅可比矩阵的求法 (1)矢量积法 对移动关节 , 00 ii ii vzz qJ w 对转动关节 iooi nin pR p (2)微分变换法 对于转动关节 i,相对连杆 i-1,绕坐标系i的轴所作微分转动,其微分运动 i z i d 矢量为(3-117),对应的夹持器的微分运动矢量为(3-118): , i o n i i ii i o n i i z pz Jq z pz w v 精品教育 -可编辑- 00 0 ,0(3 117)(3 118 01 T x z T y z T z z ii T zx T zy T zz pnd p od pad ddd n o a ) 于是,J(q)的第 i 列如下:对转动关节 i: , z z TT liaiz z z z pnn Jp oJo paa 对移动关节 i: 0 ,0 0 z TT lizai z n JoJ a 3 3、微分变换法求机器人的雅可比矩阵、微分变换法求机器人的雅可比矩阵 PUMA560 的 6 个关节都是转动关节,所以利用(3-121)求取雅克比矩阵的列矢量。 对于第 1 个关节来说,将中的 n,o,a,p 向量代入式(3-121),得到雅克比矩阵的列 1 6 T 矢量。 1 1 1 1 234 5 64 62356 234 5 64 62356 23 4 523 5 T x T y T Tz J J J Jq sc c cs sc s c sc c ss cc s s s c sc c 其中、的表达式如下所示: x TJ 1x TT 2x TT 3 14 5 64 53 232342234 5 64 623 5 6 14 5 64 63 232342234 5 64 623 5 6 14 53 23234223 4 523 5 ()() ()()() ()() T x T y T z Js s sc sa cs dd cc c cs ss s s Js c sc ca cs dd cc c cs ss s s Js s a cs dd c c ss c 对于第 2 个关节来说,将中的 n,o,a,p 向量代入式(3-121),得到雅克比矩阵的列矢 2 6 T 量 2 TJ q 精品教育 -可编辑- 可以得到: 2 2 2 2 4 54 66 4 5 64 6 4 5 T x T y T Tz J J J Jq s cc sc s c sc c s s 其中、三个参数的表达式如下所示: x TJ 2y TJ 2z TJ 2 同理,可求得: 234 5 64 63 5 63 3342 34 5 64 63 5 63 334 234 5 64 63 5 63 3342 34 5 64 63 5 63 334 23 53 4 53 33423 4 53 53 () () () () ()()()( T x T y T z Jsc c cs sc s sa cs da cc c cs ss s sa sc d Jsc c ss sc s sa cs da cc c ss ss s s a sc d Jc cs c sa cs dac c ss ca 334) sc d 3456 , TTTT JqJqJqJq 44 5 64 635 6 44 5 64 635 6 44 53 6 3 4 5 64 6 4 5 64 6 4 5 T dc c cs sas c dc c ss cas s d c sa c Jq s c cc s s c sc c s s 456 5 66 5 66 5 000 000 000 , 0 0 01 TTT JqJqJq s cs s sc c 所以又以上六个矩阵便最后组成了的雅克比矩阵。1666 4 4、矢量积法求机器人的雅克比矩阵、矢量积法求机器人的雅克比矩阵 PUMA560 的 6 个关节都是转动关节,因而其雅克比矩阵具有下列形式: 精品教育 -可编辑- 102060 162666 126 zpzpzp J q zzz 5 5、MatlabMatlab 编程编程 (1)用微分变换法求解雅克比矩阵 在 Matlab 中运行 wfbh.m,根据提示输入的值并回车,得雅克比矩阵如下: 16 -864.8700 0 0 0 0 0 -149.0900 20.3200 20.3200 0 0 0 0 -864.8700 -433.0700 0 0 0 0 -1.0000 -1.0000 0 -1.0000 0 0 0 0 1.0000 0 1.0000 1.0000 0 0 0 0 0 (2)用矢量积法求解雅克比矩阵 在 Matlab 中运行 slj.m,根据提示输入的值并回车,得雅克比矩阵如下: 16 -864.8700 0 0 0 0 0 -149.0900 20.3200 20.3200 0 0 0 0 -864.8700 -433.0700 0 0 0 0 -1.0000 -1.0000 0 -1.0000 0 0 0 0 1.0000 0 1.0000 1.0000 0 0 0 0 0 从以上结果中我们可以看出其运行结果与用微分变换编程所得到的结果是 一致的,进一步证明了所编写程序的正确性。 精品教育 -可编辑- 附录 1 1、程序、程序 1、运动学正解 function zhengjie(c1,c2,c3,c4,c5,c6) clc; a2=431.8; a3=20.32; d2=149.09; d4=433.07; d6=56.25; 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=431.8; a3=20.32; d2=149.09; d4=433.07; 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*(-n
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 乡村豪宅出租合同范本
- 代保管合同范本
- 华盛茶叶合同范本
- 农业投资内部合同范本
- 仓库货源转让合同范本
- 专利租赁合同范本
- 信用评级合同范本
- 农具批发采购合同范本
- 仪表制氮机采购合同范本
- 创建公司合同范本
- 量子力学英文课件格里菲斯Chapter4
- 人教版小学四年级数学下册电子教案 全册
- 氧化铝行业规程试题资料
- 锅炉节能管理制度
- 2023年道路交通安全法实施条例
- 市政工程标准施工组织设计方案
- 马尔文粒度仪MS2000原理及应用
- 护理不良事件管理、上报制度及流程
- GB 9706.224-2021医用电气设备第2-24部分:输液泵和输液控制器的基本安全和基本性能专用要求
- 钢栈桥施工与方案
- 子宫内膜异位症诊疗指南完整课件
评论
0/150
提交评论