对于姿态角解算,目前我所知道的只有两种,一种是DMP库解算出姿态角、一种是算法进行姿态解算;
本次说的是姿态解算,采集的是六轴的原始数据,用python进行姿态解算;废话不多说,看程序,有注解的。。
import math
import csv
Kp=100 #比例增益控制加速度计/磁强计的收敛速度
Ki=0.002 #积分增益控制陀螺仪偏差的收敛速度
halft=0.001 #采样周期的一半
#传感器框架相对于辅助框架的四元数(初始化四元数的值)
q0=1
q1=0
q2=0
q3=0
#由Ki缩放的积分误差项(初始化)
exInt=0
eyInt=0
ezInt=0
'''
举例子:“-0.31,-0.11,-0.95,-26,70,9”
#三轴加速度原始数据
ax=-0.31
ay=-0.11
az=-0.95
#三轴角速度原始数据
gx=-26
gy=70
gz=9
'''
#读取data.csv的数据然后把对比结果数据写入到data.txt文件中
f0=open("data.txt",'w',encoding='utf-8')
f0.write("\n")
csvname="data.csv"
with open(csvname,"r") as f:
csvhandle = csv.reader(f)
for row in csvhandle:
aax=row[0] #原始加速度x轴数据
aay=row[1] #原始加速度y轴数据
aaz=row[2] #原始加速度z轴数据
ggx=row[3] #原始角速度x轴数据
ggy=row[4] #原始角速度y轴数据
ggz=row[5] #原始角速度z轴数据
#把csv的字符串转化为float型
ax=float(aax)
ay=float(aay)
az=float(aaz)
gx=float(ggx)
gy=float(ggy)
gz=float(ggz)
#单元化
norm=math.sqrt(ax*ax+ay*ay+az*az)
ax=ax/norm
ay=ay/norm
az=az/norm
#估计方向的重力
vx=2*(q1*q3-q0*q2)
vy=2*(q0*q1+q2*q3)
vz=q0*q0-q1*q1-q2*q2+q3*q3
# 错误的领域和方向传感器测量参考方向之间的交叉乘积的总和
ex=(ay*vz - az*vy)
ey=(az*vx - ax*vz)
ez=(ax*vy - ay*vx)
# 积分误差比例积分增益
exInt +=ex*Ki
eyInt +=ey*Ki
ezInt +=ez*Ki
# 调整后的陀螺仪测量
gx +=Kp*ex + exInt
gy +=Kp*ey + eyInt
gz +=Kp*ez +ezInt
# 整合四元数
q0 +=(-q1*gx - q2*gy - q3*gz)*halft
q1 +=(q0*gx + q2*gz - q3*gy)*halft
q2 +=(q0*gy - q1*gz + q3*gx)*halft
q3 +=(q0*gz + q1*gy - q2*gx)*halft
# 正常化四元数
norm = math.sqrt(q0*q0+q1*q1+q2*q2+q3*q3)
q0 /=norm
q1 /=norm
q2 /=norm
q3 /=norm
# 获取欧拉角 pitch、roll、yaw
pitch = math.asin(-2*q1*q3+2*q0*q2)*57.3
roll = math.atan2(2*q2*q3+2*q0*q1,-2*q1*q1-2*q2*q2+1)*57.3
yaw = math.atan2(2*(q1*q2 + q0*q3),q0*q0+q1*q1-q2*q2-q3*q3)*57.3
#打印姿态角信息以及把姿态角数据写到txt文本中
print("pry:%.3f,%.3f,%.3f"%(pitch,roll,yaw))
f0.write("pitch:%.3f;roll:%.3f;yaw:%.3f"%(pitch,roll,yaw))
f0.write("\n")