hall.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #ifndef _HALL_SENSOR_H__
  2. #define _HALL_SENSOR_H__
  3. #include "os/os_type.h"
  4. #include "bsp/bsp.h"
  5. #define NEGATIVE (int8_t)-1
  6. #define POSITIVE (int8_t)1
  7. #define PHASE_0_DEGREE (0)
  8. #define PHASE_60_DEGREE (60)
  9. #define PHASE_120_DEGREE (120)
  10. #define PHASE_180_DEGREE (180)
  11. #define PHASE_240_DEGREE (240)
  12. #define PHASE_300_DEGREE (300)
  13. #define PHASE_360_DEGREE (360)
  14. #define STATE_0 (uint8_t)0
  15. #define STATE_1 (uint8_t)1
  16. #define STATE_2 (uint8_t)2
  17. #define STATE_3 (uint8_t)3
  18. #define STATE_4 (uint8_t)4
  19. #define STATE_5 (uint8_t)5
  20. #define STATE_6 (uint8_t)6
  21. #define STATE_7 (uint8_t)7
  22. #define THETA_NONE (float)0xFFFF
  23. #define SAMPLE_MAX_COUNT 3
  24. typedef struct {
  25. u32 ticks[SAMPLE_MAX_COUNT];
  26. float angles[SAMPLE_MAX_COUNT];
  27. u32 ticks_sum;
  28. float angles_sum;
  29. u32 index;
  30. bool full;
  31. }hall_sample_t;
  32. typedef struct {
  33. float estimate_el_angle; //60度区间内的估计电角度
  34. s32 estimate_delta_angle;
  35. float estimate_el_speed;
  36. u32 estimate_time_ticks;
  37. s32 measured_el_angle; //hall测量到的电角度
  38. float immediately_el_speed; //当前的即时速度,主要用来判断电机转动是否达到稳定
  39. float el_speed; //当前的平均效果的电角速度, 单位:rad/s
  40. float next_delta_angle;
  41. float rpm; //当前的电速度, 单位:RPM
  42. bool trns_detect; //速度变化超过阈值
  43. u8 hall_stat;
  44. u32 hall_ticks;
  45. s8 direction;
  46. s32 phase_offset;
  47. bool is_override_angle;
  48. float override_el_angle;
  49. hall_sample_t samples;
  50. u32 sensor_error;
  51. u16 angle_table[8];
  52. }hall_sensor_t;
  53. void hall_sensor_init(void);
  54. void hall_sensor_clear(void);
  55. float hall_sensor_get_theta(void); //return degree
  56. float hall_sensor_get_speed(void); //return rpm
  57. float hall_sensor_avg_speed(void);
  58. int hall_sensor_calibrate(float voltage);
  59. void hall_sensor_set_theta(bool override, float theta);
  60. int hall_offset_increase(int inc);
  61. u16 *hall_get_table(void);
  62. #endif /* _HALL_SENSOR_H__ */