(源代码)四元数与欧拉角间的转换

本文通过MATLAB代码展示了如何进行四元数与欧拉角之间的转换。通过动态改变欧拉角,观察四元数的变化,并将转换结果以图形方式展示,包括γ、θ和ψ三个角度以及四元数q1~q4随时间的变化。
摘要由CSDN通过智能技术生成
clear
clc
 
vartheta_c=0.1;
fea_c=0.1;
gamma_c=0;
q1=sin(fea_c/2)*sin(vartheta_c/2)*cos(gamma_c/2)+cos(fea_c/2)*cos(vartheta_c/2)*sin(gamma_c/2);
q2=sin(fea_c/2)*cos(vartheta_c/2)*cos(gamma_c/2)+cos(fea_c/2)*sin(vartheta_c/2)*sin(gamma_c/2);
q3=cos(fea_c/2)*sin(vartheta_c/2)*cos(gamma_c/2)-sin(fea_c/2)*cos(vartheta_c/2)*sin(gamma_c/2);
q4=cos(fea_c/2)*cos(vartheta_c/2)*cos(gamma_c/2)-sin(fea_c/2)*sin(vartheta_c/2)*sin(gamma_c/2);
        
Dt=0.001;
n=1;
t=0;
for i=1:5000
    if t<1.5
        vartheta_c=vartheta_c;
        fea_c=fea_c;
        gamma_c=gamma_c;
    else
        
        vartheta_c=vartheta_c-Dt*pi/180;
        fea_c=fea_c+Dt*pi/180;
        gamma_c=gamma_c+Dt*pi/180;
    end
        q1_c=sin(fea_c/2)*sin(vartheta_c/2)*cos(gamma_c/2)+cos(fea_c/2)*cos(vartheta_c/2)*sin(gamma_c/2);
        q2_c=sin(fea_c/2)*cos(vartheta_c/2)*cos(gamma_c/2)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值