zoukankan      html  css  js  c++  java
  • 基于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 仿真结果

  • 相关阅读:
    Django的开发服务的搭建和使用
    Openerp
    Django Url设计 小知识点
    try...finally的用法
    SQL rownum的用法
    oracle 日期常用函數sysdate
    datetime.datetime.now()时间格式转化是碰到的问题
    CSS BACKGROUND汇总
    css3动画效果小结
    javascript花式理解闭包
  • 原文地址:https://www.cnblogs.com/Sonny-xby/p/12371834.html
Copyright © 2011-2022 走看看