matlab练习程序(求向量间的旋转矩阵与四元数)

Posted tiandsp

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了matlab练习程序(求向量间的旋转矩阵与四元数)相关的知识,希望对你有一定的参考价值。

问题是这样,如果我们知道两个向量v1和v2,计算从v1转到v2的旋转矩阵和四元数,由于旋转矩阵和四元数可以互转,所以我们先计算四元数。

我们可以认为v1绕着向量u旋转θ?角度到v2,u垂直于v1-v2平面。

四元数q可以表示为cos(θ/2)?+sin(θ/2)?u,即:q0?=cos(θ/2)?,q1?=sin(θ/2)?u.x,q2=sin(θ/2)?u.yq3=sin(θ/2)?u.z

所以我们求出u和θ/2即可,u等于v1与v2的叉积,不要忘了单位化;θ/2用向量夹角公式就能求。

matlab代码如下:

clear all;
close all;
clc;

v1=[1 2 3];
v2=[4 5 6];

%转为单位向量
nv1 = v1/norm(v1);
nv2 = v2/norm(v2);

if norm(nv1+nv2)==0
    q = [0 0 0 0];
else
    u = cross(nv1,nv2);         
    u = u/norm(u);
    
    theta = acos(sum(nv1.*nv2))/2;
    q = [cos(theta) sin(theta)*u];
end

%由四元数构造旋转矩阵
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));
    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));
    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];

s = nv1*R;

%显示结果
v2
s*norm(v2)

参考:

https://stackoverflow.com/questions/1171849/finding-quaternion-representing-the-rotation-from-one-vector-to-another

https://blog.csdn.net/shenshikexmu/article/details/70991286

https://blog.csdn.net/shenshikexmu/article/details/53608224

以上是关于matlab练习程序(求向量间的旋转矩阵与四元数)的主要内容,如果未能解决你的问题,请参考以下文章

matlab练习程序(对应点集配准的四元数法)

四元数绕轴旋转的分量

轴角与四元数的利弊

视觉SLAM中李群李代数与四元数总结

旋转矩阵旋转向量欧拉角四元数的关系

eigen 中四元数欧拉角旋转矩阵旋转向量