31 lines
762 B
C
31 lines
762 B
C
|
//
|
|||
|
// Created by SJQ on 2023/12/29.
|
|||
|
//
|
|||
|
|
|||
|
#ifndef WHEEL_LEGGED_LQR_H
|
|||
|
#define WHEEL_LEGGED_LQR_H
|
|||
|
#include "user_lib.h"
|
|||
|
typedef struct
|
|||
|
{
|
|||
|
float* state_vector;
|
|||
|
float* control_vector;
|
|||
|
|
|||
|
float* state_cmd;
|
|||
|
|
|||
|
int state_num; //状态量维数
|
|||
|
int control_num; //控制量维数
|
|||
|
|
|||
|
mat control_matrix; //其实是向量 定义成矩阵方便计算 @todo:更新DSP库 新版本库支持矩阵直接乘数组
|
|||
|
mat state_matrix;
|
|||
|
mat state_cmd_matrix;
|
|||
|
|
|||
|
mat state_err;
|
|||
|
mat K_matrix;
|
|||
|
}LQRInstance;
|
|||
|
|
|||
|
void LQR_Init(LQRInstance* lqrInstance,int state_cnt,int control_cnt);
|
|||
|
void LQR_update(LQRInstance* lqrInstance,float* new_state,float* target_state);
|
|||
|
void LQR_set_K(LQRInstance* lqrInstance, float *K_value);
|
|||
|
|
|||
|
#endif //WHEEL_LEGGED_LQR_H
|