本篇文章主要与大家分享一下如何使用matlab进行二维和三维空间的位姿描述及坐标系的变换,文章内容处于更新和补充中,(我同时安装了机器人工具箱9.10版本和10.4版本,因此文章也介绍了两种版本工具箱下的用法)

   一、

   1、二维空间的位姿描述

  (1)在二维空间下对进行坐标系的平移和旋转可以使用se2函数(在9.10版本工具箱中用se2函数,10.4版本为SE2函数),我们在matlab的命令行窗口输入help se2可以查看matlab的帮助文档中对se2函数使用的解释,其参数X,Y分别是在X、Y方向平移的距离,参数THETA是旋转的角度,具体的例子如下:

在这里插入图片描述


  ①在X方向平移1,在Y方向平移2 ,旋转90度


%9.10版本机器人工具箱
T=se2(1,2,90,‘deg’) %参数THETA为角度制
T=se2(1,2,pi/2) %参数THETA为弧度制


%10.4版本机器人工具箱
T=SE2(1,2,pi/2) %参数THETA为弧度制
T=SE2(1,2,90,‘deg’) %参数THETA为角度制


       运行结果如下:


    T =

    0.0000 -1.0000 1.0000
    1.0000 0.0000 2.0000
    0 0 1.0000

      (2)在二维空间下对进行坐标系的旋转可以使用rot2函数(10.4版本工具箱),其参数为旋转的角度,具体的例子如下:

    R=rot2(pi)

       运行结果如下:


    R =

    -1.0000 -0.0000
    0.0000 -1.0000

      (3)求二维平面内,平移、旋转的齐次变换矩阵,可以分别用transl2()函数和trot2()函数,具体的例子如下:


    %原点平移至(1,2
    transl2(1,2)

    %逆时针旋转30
    trot2(30,‘deg’)

       运行结果如下:


    ans =

    1 0 1
    0 1 2
    0 0 1



    ans =

    0.8660 -0.5000 0
    0.5000 0.8660 0
    0 0 1.0000


      (4)我们可以使用trplot2函数(9.10和10.4版本均可使用)绘制出上面介绍的坐标变换图像,我们在matlab的命令行窗口输入help trplot2可以查看matlab的帮助文档中对trplot2函数使用的解释(本文后面介绍的函数也会适当的截取帮助文档内的内容,后面就不做此说明了 在命令行窗口输入help 后面跟想要查询的名字就可以了)通过帮助文档中列出的Options,可以知道我们可以对很多参数进行设定,具体的例子如下:


    在这里插入图片描述


      ①例子1:最简单的例子,按照默认值画出上面介绍的T的图像


    trplot2(T)

       运行结果如下:


    在这里插入图片描述


      ②例子2:画出上面介绍的T的图像,并将新的坐标系命名为A,颜色线条颜色设定为红色


    trplot2(T, ‘frame’, ‘A’, ‘color’, ‘r’)

       运行结果如下:

    在这里插入图片描述

       2、三维空间的位姿描述

      (1)在三维空间下对进行坐标系的平移可以使用transl函数,其参数X,Y,Z分别是在X、Y、Z方向上平移的距离,具体的例子如下:

    在这里插入图片描述

      ①在X方向平移1,在Y方向平移2 ,在Z方向上平移3

    T = transl(1, 2, 3)

       运行结果如下:

    T =

    1 0 0 1
    0 1 0 2
    0 0 1 3
    0 0 0 1


      (2)在三维空间下对进行坐标系的旋转可以使用rotx、roty、rotz函数,或者trotx、troty、trotz函数,这两类函数的不同之处是rotx、roty、rotz函数是3X3的矩阵,而trotx、troty、trotz函数是4X4的矩阵


    在这里插入图片描述




    在这里插入图片描述




      ①例子1:沿X轴旋转60度(π/3)


    T1=rotx(60,‘deg’)  %角度制  3x3
    T2=rotx(pi/3) %弧度制 3x3
    T3=trotx(pi/3) %弧度制 4x4

       运行结果如下:

    T1 =

    1.0000 0 0
    0 0.5000 -0.8660
    0 0.8660 0.5000


    T2 =

    1.0000 0 0
    0 0.5000 -0.8660
    0 0.8660 0.5000


    T3 =

    1.0000 0 0 0
    0 0.5000 -0.8660 0
    0 0.8660 0.5000 0
    0 0 0 1.0000



      (3)我们可以利用trplot函数绘制出绘制出上面介绍的坐标变换图像,同样我们可以对Options中所列出的参数根据需要进行设定,一些具体的例子如下:

    在这里插入图片描述
    在这里插入图片描述


    在这里插入图片描述

      ①例子1:绘制出绕X轴旋转60度的图像

    T1=rotx(60,‘deg’)   %也可以使用T1=trotx(60,‘deg’)
    trplot(T1)

       运行结果如下:

    在这里插入图片描述

      ②例子2:绘制出绕X轴旋转60度的图像,并分别以红色、绿色、蓝色显示X、Y、Z轴

    T1=rotx(60,‘deg’)   %也可以使用T1=trotx(60,‘deg’)
    trplot(T1,‘rgb’)

       运行结果如下:

    在这里插入图片描述




      (4)我们可以利用tranimate函数查看动态的变换效果,一些具体的例子如下:

    在这里插入图片描述

      ①例子1:绘制出绕X轴旋转60度的动态图像

    T1=rotx(60,‘deg’)   %也可以使用T1=trotx(60,‘deg’)
    tranimate(T1)

       运行结果如下:

    在这里插入图片描述

      ②例子2:绘制出在X方向平移1,在Y方向平移2 ,在Z方向上平移3的动态图像

    T4=transl(1,2,3)
    tranimate(T4)

       运行结果如下:

    在这里插入图片描述

      ③例子3:绘制出绕X轴旋转60度的动态图像,并设定每秒要显示的帧数为5(默认为10)

    T1=rotx(60,‘deg’)   %也可以使用T1=trotx(60,‘deg’)
    tranimate(T1,‘fps’,‘5’)

      ④例子4:绘制出绕X轴旋转60度的动态图像,并将每一帧的图像以图片的形式保存在名为text_001的文件夹中

    T1=rotx(60,‘deg’)   %也可以使用T1=trotx(60,‘deg’)
    tranimate(T1,‘movie’,‘text_001’)

    在这里插入图片描述

       3、将二维空间的位姿矩阵转换成三维空间位姿矩阵

      (1)我们可以利用se3函数将二维空间的位姿矩阵转换成三维空间位姿矩阵,具体的例子如下:

    在这里插入图片描述

    T1=se2(1,2,pi/3)
    T2=se3(T1)

         运行结果如下:

      T1 =

      0.5000 -0.8660 1.0000
      0.8660 0.5000 2.0000
      0 0 1.0000

      T2 =

      0.5000 -0.8660 0 1.0000
      0.8660 0.5000 0 2.0000
      0 0 1.0000 0
      0 0 0 1.0000

        (2)我们可以利用tranimate函数将其动态变换的过程显示出来

      T1=se2(1,2,pi/3)
      T2=se3(T1)
      tranimate(T2)

      在这里插入图片描述



         4、坐标变换的综合实例

        (1)绕动坐标系进行旋转,比如先绕X轴旋转π/2,再绕新的Y轴旋转π/2 。(此种旋转方式等效于先绕定坐标系Y轴旋转π/2,再绕定坐标系的X轴旋转π/2)

      T1=trotx(pi/2);
      T2=troty(pi/2);
      T5=T1_T2;
      tranimate(T5)

      在这里插入图片描述

        (2)先在在X方向平移1,在Y方向平移2,在Z方向上平移3,再绕动坐标系进行旋转,比如先绕X轴旋转π/2,再绕新的Y轴旋转π/3

      T1=trotx(pi/2);
      T2=troty(pi/3);
      T3=transl(1,2,3);
      T4=T3_T1*T2;
      tranimate(T4)

      在这里插入图片描述



         5、各种姿态表示方法之间的转化

        (1)从欧拉角直接转换为旋转矩阵 用eul2r()函数,如:

      R=eul2r(0.1,0.2,0.3)

        (2)从旋转矩阵求欧拉角,用tr2eul()函数,如:

      gamma = tr2eul(R)

        (3)从旋转矩阵求RPY角,用tr2rpy()函数,如:

      R1 = rpy2r(0.1, 0.2, 0.3)
      gamma = tr2rpy(R1)