基于Python的3R机器人运动仿真

一、问题描述

  如右图所示的三自由度机械臂,关节1和关节2相互垂直,关节2和关节3相互平行。如图所示,所有关节均处于初始状态。

  要求:

  (1) 定义并标注出各关节的正方向;

  (2) 定义机器人基坐标系{0}及连杆坐标系{1},{2},{3};

  (3) 求变换矩阵 , , ;

  (4) 根据末端腕部位置 (x, y, z) 返求出对应关节 , , ;

  (5) 利用软件绘制出机器人模型的三维点线图,并控制机器人腕部沿半径r=0.1的圆弧运动.

图1 3R机器人示意图

二、任务求解

2.1建立坐标系

 

 

 

 

2.2 变换矩阵

2.2.1 变换求解

(1)连杆坐标系{1}——基坐标系{0}

  原点重合,可绕z轴任意旋转

 

 

 

(2)连杆坐标系{2}——连杆坐标系{1}

  先绕x轴旋转90°,再绕新得到的y轴旋转90°,然后沿新得到的y轴平移 ,最后得到的坐标系可绕z轴任意旋转

 

 

 

(3)连杆坐标系{3}——连杆坐标系{2}

  绕z轴旋转-90°,再沿新得到的y轴平移 ,最后得到的坐标系可绕z轴任意旋转

 

 

 

2.2.2 物理意义求解

  变换矩阵的前三列,每列值对应的数为变换坐标系的坐标轴x、y、z在基坐标系中的坐标位置,第四列为变换坐标系的原点在基坐标系中的坐标位置,第四行为齐次补行数据,则可根据坐标系的位置直接列出下式:

 

 

 

  可见,两种方式的结果表达式一致。

2.2.3 变换矩阵终解

 

 

 

2.3 逆运动学求解

2.3.1 矩阵逆推导

  由连杆坐标系{3}到基座坐标系{0}的齐次矩阵可以表示为

 

 

 

 

  末端执行器的位置在基座坐标系{0}中的描述为

 

 

 

 

  末端执行器的位置在连杆坐标系{3}中的描述为

 

  关系为:

 

  根据矩阵对应元素相等,由MATLAB计算可得可得下面等式:

x=-(7*cos(a2)*sin(a1))/25-(7*cos(a2)*sin(a1)*sin(a3))/20(7*cos(a3)*
sin(a1)*sin(a2))/20
y=(7*cos(a1)*cos(a2))/25+(7*cos(a1)*cos(a2)*sin(a3))/20+(7*cos(a1)*cos(a3)*sin(a2))/20
z=(7*sin(a2))/25 + (7*sin(a2)*sin(a3))/20 - (7*cos(a2)*cos(a3))/20 + 47/100

  由

  则:

 

 

 

  由对应元素相等,得:

(x*cos(a1))/(cos(a1)^2 + sin(a1)^2) + (y*sin(a1))/(cos(a1)^2 + sin(a1)^2)=0

 (y*cos(a1))/(cos(a1)^2 + sin(a1)^2) - (x*sin(a1))/(cos(a1)^2 + sin(a1)^2)=(7*cos(a2))/25+(7*cos(a2)*sin(a3))/20+(7*cos(a3)*sin(a2))/20

z=(7*sin(a2))/25 + (7*sin(a2)*sin(a3))/20 - (7*cos(a2)*cos(a3))/20 + 47/100

 

  综上可得,

 

 

 

2.3.2 几何推导

  在x0y平面,将末端执行器的轨迹投影到该平面,蓝色表示原位置,橘色代表移动后的位置,黑色坐标系为基坐标系,如下图:

 

 

  由图易见, 为末端执行器投影到xoy平面x与y的夹角,(逆时针为正),

 

 

  在y0z平面,将末端执行器的轨迹投影到该平面,蓝色表示原位置,橘色代表移动后的位置,黑色坐标系为基坐标系,如下图:

 

 


  

 

 

 

 

 

  将末端执行器的轨迹投影到下图所示平面,蓝色表示原位置,橘色代表移动后的位置,黑色坐标系为基坐标系,如下图:

 

 

  构建直角三角形,可得:

 

 

  综上,得各关节角与坐标位置的关系为:

 

 

三、D-H模型法求解

3.1 坐标系建立

  0号杆件固连在基座上,建立基坐标系

 

 

3.2 D-H参数

 

 

3.3 各关节变换矩阵

  若已知四个参数就完全确定了两连杆之间的相对关系。对此,我们建立基坐标系和连杆运动坐标系之间的变换关系。对于旋转关节可以确定以下的齐次矩阵

 

 

  即先绕x轴旋转,然后沿x轴移动,再沿基坐标系的z轴移动d,最后绕z轴旋转

  将参数代入上式,由此可以得到各关节变换矩阵

3.4 求逆变换

  同2.3.1

四、软件仿真

4.1 程序代码

  用软件python(x,y)编写代码,如下:

 

 

4.2 仿真结果

图7 仿真结果

posted on 2020-02-27 14:03  挽年_Sonny  阅读(6269)  评论(0编辑  收藏  举报

导航