/** ****************************************************************************** * @file user_lib.h * @author Wang Hongxi * @version V1.0.0 * @date 2021/2/18 * @brief ****************************************************************************** * @attention * ****************************************************************************** */ #ifndef _USER_LIB_H #define _USER_LIB_H #include "stdint.h" #include "main.h" #include "cmsis_os.h" enum { CHASSIS_DEBUG = 1, GIMBAL_DEBUG, INS_DEBUG, RC_DEBUG, IMU_HEAT_DEBUG, SHOOT_DEBUG, AIMASSIST_DEBUG, }; extern uint8_t GlobalDebugMode; #ifndef user_malloc #ifdef _CMSIS_OS_H #define user_malloc pvPortMalloc #else #define user_malloc malloc #endif #endif /* boolean type definitions */ #ifndef TRUE #define TRUE 1 /**< boolean true */ #endif #ifndef FALSE #define FALSE 0 /**< boolean fails */ #endif /* math relevant */ /* radian coefficient */ #ifndef RADIAN_COEF #define RADIAN_COEF 57.295779513f #endif /* circumference ratio */ #ifndef PI #define PI 3.14159265354f #endif #define VAL_LIMIT(val, min, max) \ do \ { \ if ((val) <= (min)) \ { \ (val) = (min); \ } \ else if ((val) >= (max)) \ { \ (val) = (max); \ } \ } while (0) #define ANGLE_LIMIT_360(val, angle) \ do \ { \ (val) = (angle) - (int)(angle); \ (val) += (int)(angle) % 360; \ } while (0) #define ANGLE_LIMIT_360_TO_180(val) \ do \ { \ if ((val) > 180) \ (val) -= 360; \ } while (0) #define VAL_MIN(a, b) ((a) < (b) ? (a) : (b)) #define VAL_MAX(a, b) ((a) > (b) ? (a) : (b)) typedef struct { float input; //�������� float out; //������� float min_value; //�޷���Сֵ float max_value; //�޷����ֵ float frame_period; //ʱ���� } ramp_function_source_t; typedef struct { uint16_t Order; uint32_t Count; float *x; float *y; float k; float b; float StandardDeviation; float t[4]; } Ordinary_Least_Squares_t; //���ٿ��� float Sqrt(float x); //б��������ʼ�� void ramp_init(ramp_function_source_t *ramp_source_type, float frame_period, float max, float min); //б���������� float ramp_calc(ramp_function_source_t *ramp_source_type, float input); //�������� float abs_limit(float num, float Limit); //�жϷ���λ float sign(float value); //�������� float float_deadband(float Value, float minValue, float maxValue); // int26���� int16_t int16_deadline(int16_t Value, int16_t minValue, int16_t maxValue); //�޷����� float float_constrain(float Value, float minValue, float maxValue); //�޷����� int16_t int16_constrain(int16_t Value, int16_t minValue, int16_t maxValue); //ѭ���޷����� float loop_float_constrain(float Input, float minValue, float maxValue); //�Ƕ� ���޷� 180 ~ -180 float theta_format(float Ang); int float_rounding(float raw); //���ȸ�ʽ��Ϊ-PI~PI #define rad_format(Ang) loop_float_constrain((Ang), -PI, PI) #endif