152 lines
3.0 KiB
C
152 lines
3.0 KiB
C
/**
|
|
******************************************************************************
|
|
* @file ins_task.h
|
|
* @author Wang Hongxi
|
|
* @author annotation and modification by NeoZeng
|
|
* @version V2.0.0
|
|
* @date 2022/2/23
|
|
* @brief
|
|
******************************************************************************
|
|
* @attention INS任务的初始化不要放入实时系统!应该由application拥有实例,随后在
|
|
* 应用层调用初始化函数.
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
#ifndef __INS_TASK_H
|
|
#define __INS_TASK_H
|
|
|
|
#include "stdint.h"
|
|
#include "BMI088driver.h"
|
|
#include "QuaternionEKF.h"
|
|
|
|
#define X 0
|
|
#define Y 1
|
|
#define Z 2
|
|
|
|
//#define X 2
|
|
//#define Y 1
|
|
//#define Z 0
|
|
|
|
#define INS_TASK_PERIOD 1
|
|
|
|
typedef struct
|
|
{
|
|
float Gyro[3]; // 角速度
|
|
float Accel[3]; // 加速度
|
|
// 还需要增加角速度数据
|
|
float Roll;
|
|
float Pitch;
|
|
float Yaw;
|
|
float YawTotalAngle;
|
|
|
|
} attitude_t; // 最终解算得到的角度,以及yaw转动的总角度(方便多圈控制)
|
|
|
|
typedef struct
|
|
{
|
|
float q[4]; // 四元数估计值
|
|
|
|
float MotionAccel_b[3]; // 机体坐标加速度
|
|
float MotionAccel_n[3]; // 绝对系加速度
|
|
|
|
float AccelLPF; // 加速度低通滤波系数
|
|
|
|
// bodyframe在绝对系的向量表示
|
|
float xn[3];
|
|
float yn[3];
|
|
float zn[3];
|
|
|
|
// 加速度在机体系和XY两轴的夹角
|
|
// float atanxz;
|
|
// float atanyz;
|
|
|
|
// IMU量测值
|
|
float Gyro[3]; // 角速度
|
|
float Accel[3]; // 加速度
|
|
// 位姿
|
|
float Roll;
|
|
float Pitch;
|
|
float Yaw;
|
|
float YawTotalAngle;
|
|
|
|
float YawAngleLast;
|
|
float YawRoundCount;
|
|
|
|
uint8_t init;
|
|
} INS_t;
|
|
|
|
/* 用于修正安装误差的参数 */
|
|
typedef struct
|
|
{
|
|
uint8_t flag;
|
|
|
|
float scale[3];
|
|
|
|
float Yaw;
|
|
float Pitch;
|
|
float Roll;
|
|
} IMU_Param_t;
|
|
|
|
/**
|
|
* @brief 初始化惯导解算系统
|
|
*
|
|
*/
|
|
attitude_t *INS_Init(void);
|
|
|
|
/**
|
|
* @brief 此函数放入实时系统中,以1kHz频率运行
|
|
* p.s. osDelay(1);
|
|
*
|
|
*/
|
|
void INS_Task(void);
|
|
|
|
/**
|
|
* @brief 四元数更新函数,即实现dq/dt=0.5Ωq
|
|
*
|
|
* @param q 四元数
|
|
* @param gx
|
|
* @param gy
|
|
* @param gz
|
|
* @param dt 距离上次调用的时间间隔
|
|
*/
|
|
void QuaternionUpdate(float *q, float gx, float gy, float gz, float dt);
|
|
|
|
/**
|
|
* @brief 四元数转换成欧拉角 ZYX
|
|
*
|
|
* @param q
|
|
* @param Yaw
|
|
* @param Pitch
|
|
* @param Roll
|
|
*/
|
|
void QuaternionToEularAngle(float *q, float *Yaw, float *Pitch, float *Roll);
|
|
|
|
/**
|
|
* @brief ZYX欧拉角转换为四元数
|
|
*
|
|
* @param Yaw
|
|
* @param Pitch
|
|
* @param Roll
|
|
* @param q
|
|
*/
|
|
void EularAngleToQuaternion(float Yaw, float Pitch, float Roll, float *q);
|
|
|
|
/**
|
|
* @brief 机体系到惯性系的变换函数
|
|
*
|
|
* @param vecBF body frame
|
|
* @param vecEF earth frame
|
|
* @param q
|
|
*/
|
|
void BodyFrameToEarthFrame(const float *vecBF, float *vecEF, float *q);
|
|
|
|
/**
|
|
* @brief 惯性系转换到机体系
|
|
*
|
|
* @param vecEF
|
|
* @param vecBF
|
|
* @param q
|
|
*/
|
|
void EarthFrameToBodyFrame(const float *vecEF, float *vecBF, float *q);
|
|
|
|
#endif
|