2023-12-26 23:54:56 +08:00
|
|
|
//
|
|
|
|
// Created by SJQ on 2023/12/25.
|
|
|
|
//
|
|
|
|
|
2024-03-06 19:44:56 +08:00
|
|
|
#ifndef WHEEL_LEGGED_LEG_OLD_H
|
|
|
|
#define WHEEL_LEGGED_LEG_OLD_H
|
2023-12-26 23:54:56 +08:00
|
|
|
#include "controller.h"
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
float L0;
|
|
|
|
float phi0;
|
|
|
|
|
|
|
|
float phi1;
|
|
|
|
float phi4;
|
|
|
|
|
|
|
|
float phi2;
|
|
|
|
float phi3;
|
2024-01-10 18:27:25 +08:00
|
|
|
|
|
|
|
uint32_t DWT_CNT;
|
|
|
|
float dt; //用于计算时间并求导
|
|
|
|
float last_phi0;
|
|
|
|
float phi0_dot;
|
2024-03-17 17:51:24 +08:00
|
|
|
float phi0_dot_num;
|
2024-01-10 18:27:25 +08:00
|
|
|
|
2024-02-28 17:33:48 +08:00
|
|
|
float L0_dot;
|
2024-03-17 17:51:24 +08:00
|
|
|
float L0_dot_num;
|
2024-02-28 17:33:48 +08:00
|
|
|
|
2023-12-26 23:54:56 +08:00
|
|
|
}Leg_State_t;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
float F;
|
|
|
|
float Tp;
|
|
|
|
}Leg_Input_t;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
float T1;
|
|
|
|
float T2;
|
|
|
|
}Leg_Output_t;
|
|
|
|
|
2024-01-10 18:27:25 +08:00
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
PID_Init_Config_s length_PID_conf;
|
|
|
|
PID_Init_Config_s phi0_PID_conf;
|
|
|
|
float init_target_L0; //初始腿长目标值
|
|
|
|
float F_feedforward;
|
|
|
|
}Leg_init_config_s;
|
2023-12-26 23:54:56 +08:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
Leg_State_t legState;
|
|
|
|
Leg_Input_t legInput;
|
2024-02-28 17:33:48 +08:00
|
|
|
Leg_Input_t legFeedback;
|
2023-12-26 23:54:56 +08:00
|
|
|
Leg_Output_t legOutput;
|
|
|
|
|
|
|
|
float target_L0;
|
|
|
|
float target_phi0;
|
|
|
|
PIDInstance Length_PID;
|
|
|
|
PIDInstance Phi0_PID;
|
|
|
|
|
2024-01-10 18:27:25 +08:00
|
|
|
float F_feedforward; //支持力前馈补偿
|
2024-02-28 17:33:48 +08:00
|
|
|
|
|
|
|
arm_matrix_instance_f32 VMC_Jacobi;
|
|
|
|
float VMC_Jacobi_data[4];
|
|
|
|
arm_matrix_instance_f32 inv_VMC_Jacobi;
|
|
|
|
float inv_VMC_Jacobi_data[4];
|
2023-12-26 23:54:56 +08:00
|
|
|
}LegInstance;
|
|
|
|
|
2024-01-10 18:27:25 +08:00
|
|
|
|
|
|
|
|
|
|
|
void Leg_State_update(LegInstance* legInstance, float phi1,float phi4 ,float phi1_dot,float phi4_dot);
|
2023-12-26 23:54:56 +08:00
|
|
|
void Leg_calc_output(Leg_State_t* leg_state,Leg_Input_t* leg_input,Leg_Output_t* leg_output);
|
|
|
|
void Leg_Input_update(Leg_Input_t* leg_Input, float F,float Tp);
|
2024-02-28 17:33:48 +08:00
|
|
|
void Leg_feedback_update(LegInstance* legInstance,float T1_fb,float T2_fb);
|
2023-12-26 23:54:56 +08:00
|
|
|
|
2024-01-10 18:27:25 +08:00
|
|
|
void Leg_Init(LegInstance* legInstance, Leg_init_config_s* legInitConfig);
|
2023-12-26 23:54:56 +08:00
|
|
|
void Leg_length_control_loop(LegInstance* legInstance);
|
2024-01-10 18:27:25 +08:00
|
|
|
void VMC_getT(LegInstance* legInstance);
|
2023-12-26 23:54:56 +08:00
|
|
|
|
|
|
|
|
2024-03-06 19:44:56 +08:00
|
|
|
#endif //WHEEL_LEGGED_LEG_OLD_H
|