measure_task.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include "bsp/gpio.h"
  2. #include "app/sox/measure.h"
  3. #include "app/sox/health.h"
  4. #include "libs/shark_task.h"
  5. #include "libs/logger.h"
  6. #include "measure_task.h"
  7. #include "state.h"
  8. static measure_value_t _measure_value;
  9. static measure_notify _current_notify;
  10. static measure_notify _voltage_notify;
  11. static measure_notify _temperature_notify;
  12. /* 测量task,用来定时测量电流,电压,温度等adc数据 */
  13. struct means_task {
  14. shark_task_t _task;
  15. u32 delay;
  16. u8 index;
  17. };
  18. static void init_pack_current_task(void);
  19. static void init_cell_task(void);
  20. static void init_temp_task(void);
  21. void measure_task_init(measure_notify cn, measure_notify vn, measure_notify tn){
  22. _current_notify = cn;
  23. _voltage_notify = vn;
  24. _temperature_notify = tn;
  25. measure_adc_init();
  26. init_pack_current_task();
  27. init_cell_task();
  28. init_temp_task();
  29. set_log_level(MOD_MEASURE, L_debug);
  30. }
  31. measure_value_t * measure_value(void){
  32. return &_measure_value;
  33. }
  34. /*
  35. * 测量总电流,放电和充电
  36. */
  37. static struct means_task _pack_current_task;
  38. static u32 pack_current_task_handler(void);
  39. static void init_pack_current_task(void){
  40. _pack_current_task._task.handler = pack_current_task_handler;
  41. _pack_current_task.delay = 30;
  42. _pack_current_task.index = 0;
  43. _measure_value.load_current = get_pack_current();
  44. shark_task_add(&_pack_current_task._task);
  45. }
  46. static u32 pack_current_task_handler(void){
  47. _measure_value.load_current = get_pack_current();
  48. _current_notify();//通知bms state 有新的电流数据
  49. //measure_debug("load current = %f\n", _measure_value.load_current);
  50. return _pack_current_task.delay;
  51. }
  52. /*
  53. * 测量电芯电压,计算出总电压
  54. */
  55. static struct means_task _cell_task;
  56. static u32 cell_task_handler(void);
  57. static void init_cell_task(void){
  58. _cell_task._task.handler = cell_task_handler;
  59. _cell_task.delay = 30;
  60. _cell_task.index = 0;
  61. for (int i = 0; i < CELLS_NUM; i++){
  62. _measure_value.cell_vol[i] = get_cell_voltage(i);
  63. }
  64. shark_task_add(&_cell_task._task);
  65. }
  66. static u32 cell_task_handler(void){
  67. if (bms_state_get()->pack_balancing){ //if balance, do'nt sample cell voltage
  68. return _cell_task.delay;
  69. }
  70. //用内阻对cell的电压进行补偿,充电减,放电加
  71. _measure_value.cell_vol[_cell_task.index] = get_cell_voltage(_cell_task.index) - bms_health()->internal_resistance[_cell_task.index] * _measure_value.load_current/1000;
  72. //measure_debug("cell[%d]=%f\n", _cell_task.index, _measure_value.cell_vol[_cell_task.index]/1000.0f);
  73. _cell_task.index = (_cell_task.index + 1) % CELLS_NUM;
  74. _voltage_notify();//通知bms state 有新的电压数据
  75. return _cell_task.delay;
  76. }
  77. /*
  78. * 测量4个温度
  79. */
  80. static struct means_task _temp_task;
  81. static u32 temp_task_handler(void);
  82. static void init_temp_task(void){
  83. _temp_task._task.handler = temp_task_handler;
  84. _temp_task.delay = 2 * 1000;
  85. _temp_task.index = 0;
  86. for (int i = 0; i < PACK_TEMPS_NUM; i++){
  87. _measure_value.pack_temp[i] = get_pack_temperature(i);
  88. }
  89. shark_task_add(&_temp_task._task);
  90. }
  91. static u32 temp_task_handler(void){
  92. _measure_value.pack_temp[_temp_task.index] = get_pack_temperature(_temp_task.index);
  93. //measure_debug("pack temp[%d]=%d\n", _temp_task.index, _measure_value.pack_temp[_temp_task.index]);
  94. _temp_task.index = (_temp_task.index + 1) % (PACK_TEMPS_NUM);
  95. _temperature_notify();//通知bms state 有新的温度数据
  96. return _temp_task.delay;
  97. }