设为首页收藏本站

EPS数据狗论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1718|回复: 1

matlab练习程序(旋转矩阵、欧拉角、四元数互转)

[复制链接]

17

主题

222

金钱

324

积分

入门用户

发表于 2019-4-28 14:53:28 | 显示全部楼层 |阅读模式

欧拉角转旋转矩阵公式:
1.png
旋转矩阵转欧拉角公式:
2.png
旋转矩阵转四元数公式,其中1+r11+r22+r33>0:
3.png
四元数转旋转矩阵公式,q0^2+q1^2+q2^2+q3^2=1:
4.png
欧拉角转四元数公式:
5.png
四元数转欧拉角公式:
6.png

matlab代码如下:
  1. clear all;
  2. close all;
  3. clc;

  4. %欧拉角
  5. x = 0.5;
  6. y = 0.6;
  7. z = 0.7;
  8. Ang1 = [x y z];

  9. %欧拉角转旋转矩阵
  10. Rx = [1      0      0;
  11.     0 cos(x) -sin(x);
  12.     0 sin(x) cos(x)];
  13. Ry = [cos(y)  0 sin(y);
  14.     0       1      0;
  15.     -sin(y) 0 cos(y)];
  16. Rz = [cos(z) -sin(z) 0;
  17.     sin(z) cos(z)  0;
  18.     0      0       1];
  19. R = Rz*Ry*Rx;
  20. R1 = R;

  21. %旋转矩阵转欧拉角
  22. x = atan2(R(3,2),R(3,3));
  23. y = atan2(-R(3,1),sqrt(R(3,2)^2+R(3,3)^2));
  24. z = atan2(R(2,1),R(1,1));
  25. Ang2 = [x y z];

  26. %旋转矩阵转四元数
  27. t=sqrt(1+R(1,1)+R(2,2)+R(3,3))/2;
  28. q=[t (R(3,2)-R(2,3))/(4*t) (R(1,3)-R(3,1))/(4*t) (R(2,1)-R(1,2))/(4*t)];
  29. Q1 = q;

  30. %四元数转旋转矩阵
  31. R=[ 2*q(1).^2-1+2*q(2)^2    2*(q(2)*q(3)-q(1)*q(4)) 2*(q(2)*q(4)+q(1)*q(3));
  32.     2*(q(2)*q(3)+q(1)*q(4)) 2*q(1)^2-1+2*q(3)^2     2*(q(3)*q(4)-q(1)*q(2));
  33.     2*(q(2)*q(4)-q(1)*q(3)) 2*(q(3)*q(4)+q(1)*q(2)) 2*q(1)^2-1+2*q(4)^2];
  34. R2 = R;

  35. %欧拉角转四元数
  36. q = [cos(x/2)*cos(y/2)*cos(z/2) + sin(x/2)*sin(y/2)*sin(z/2) ...
  37.     sin(x/2)*cos(y/2)*cos(z/2) - cos(x/2)*sin(y/2)*sin(z/2) ...
  38.     cos(x/2)*sin(y/2)*cos(z/2) + sin(x/2)*cos(y/2)*sin(z/2) ...
  39.     cos(x/2)*cos(y/2)*sin(z/2) - sin(x/2)*sin(y/2)*cos(z/2)];
  40. Q2 = q;

  41. %四元数转欧拉角
  42. x = atan2(2*(q(1)*q(2)+q(3)*q(4)),1 - 2*(q(2)^2+q(3)^2));
  43. y = asin(2*(q(1)*q(3) - q(2)*q(4)));
  44. z = atan2(2*(q(1)*q(4)+q(2)*q(3)),1 - 2*(q(3)^2+q(4)^2));
  45. Ang3 = [x y z];

  46. Ang1
  47. Ang2
  48. Ang3

  49. R1
  50. R2

  51. Q1
  52. Q2
复制代码

351

主题

2万

金钱

3万

积分

版主

QQ
发表于 2019-5-3 09:00:49 | 显示全部楼层
谢谢分享
dog rich, don't forget
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

客服中心
关闭
在线时间:
周一~周五
8:30-17:30
QQ群:
653541906
联系电话:
010-85786021-8017
在线咨询
客服中心

意见反馈|网站地图|手机版|小黑屋|EPS数据狗论坛 ( 京ICP备09019565号-3 )   

Powered by BFIT! X3.4

© 2008-2028 BFIT Inc.

快速回复 返回顶部 返回列表