speed_sensor.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. #include <stdbool.h>
  2. #include "speed_sensor.h"
  3. #include "math_tools.h"
  4. #include "enviolo_can.h"
  5. //局部变量定义
  6. //全局变量定义
  7. MC_SpeedSensorData_Struct_t MC_SpeedSensorData = {0, TRUE, FALSE, 0, 0xFFFFFFFF, 0};
  8. uint16_t MC_Speed_Array[10] = {0};
  9. /**************************局部函数定义*************************/
  10. /**************************全局函数定义*************************/
  11. //速度传感器IO初始化
  12. void SpeedSensor_GPIO_Init(void)
  13. {
  14. GPIO_InitTypeDef GPIO_InitStruct;
  15. __HAL_RCC_GPIOD_CLK_ENABLE();
  16. GPIO_InitStruct.Pin = SPEED_SENSOR_Pin;
  17. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
  18. GPIO_InitStruct.Pull = GPIO_PULLUP;
  19. HAL_GPIO_Init(SPEED_SENSOR_GPIO_Port, &GPIO_InitStruct);
  20. HAL_NVIC_SetPriority(SPEED_SENSOR_EXTI_IRQn, 2, 0);
  21. HAL_NVIC_EnableIRQ(SPEED_SENSOR_EXTI_IRQn);
  22. }
  23. //车速计算和停止判断处理
  24. void SpeedSensor_Process(MC_SpeedSensorData_Struct_t* p_MC_SpeedSensorData, uint16_t* AvgResult, uint8_t WheelSize, uint8_t Poles)
  25. {
  26. //车速计算
  27. static uint32_t PeriodTimeCnt = 0;
  28. static uint16_t FiltTemp[10];
  29. if((HAL_GetTick() - PeriodTimeCnt) >= 50)
  30. {
  31. //停止判断
  32. static uint32_t StopDelayTimeCnt = 0;
  33. if(p_MC_SpeedSensorData->IsTrigFlag == TRUE)
  34. {
  35. StopDelayTimeCnt = HAL_GetTick();
  36. p_MC_SpeedSensorData->IsTrigFlag = FALSE;
  37. }
  38. if((HAL_GetTick() - StopDelayTimeCnt) > (4000 / Poles)) // 超时信号触发标志未更新,认为停车
  39. {
  40. p_MC_SpeedSensorData->IsStopFlag = TRUE;
  41. }
  42. //车速计算,计算周期50ms
  43. if(p_MC_SpeedSensorData->IsStopFlag == FALSE)
  44. {
  45. if(p_MC_SpeedSensorData->DiffTime_ms == 0)
  46. {
  47. p_MC_SpeedSensorData->DiffTime_ms = 0xFFFFFFFF;
  48. }
  49. p_MC_SpeedSensorData->Speed_Data = (uint32_t)WheelSize * 360 / Poles / p_MC_SpeedSensorData->DiffTime_ms;//单位0.1km/h
  50. //滑动均值滤波
  51. *AvgResult = MovingAverageFilter(p_MC_SpeedSensorData->Speed_Data, FiltTemp, sizeof(FiltTemp) >> 1);
  52. //在确定停止前进行衰减
  53. if((HAL_GetTick() - p_MC_SpeedSensorData->TrigSysTime) > (p_MC_SpeedSensorData->DiffTime_ms * 2))
  54. {
  55. p_MC_SpeedSensorData->DiffTime_ms = (p_MC_SpeedSensorData->DiffTime_ms * 1038) >> 10;
  56. }
  57. }
  58. else
  59. {
  60. p_MC_SpeedSensorData->Speed_Data = 0;
  61. *AvgResult = 0;
  62. ArrayFillZero(FiltTemp, sizeof(FiltTemp) >> 1);
  63. p_MC_SpeedSensorData->DiffTime_ms = 0xFFFFFFFF;
  64. return;
  65. }
  66. PeriodTimeCnt = HAL_GetTick();
  67. }
  68. }
  69. void SpeedCal_ByCadence(uint16_t CadenceData, uint16_t* SpeedData, uint8_t T_Front, uint8_t T_Tail, uint16_t WheelSize, uint16_t* BikeSpeed)
  70. {
  71. static uint32_t PeriodTimeCnt = 0;
  72. static uint8_t FltCount = 0;
  73. static uint32_t FltSum = 0;
  74. if((HAL_GetTick() - PeriodTimeCnt) >= 50)
  75. {
  76. PeriodTimeCnt = HAL_GetTick();
  77. *SpeedData = ((CadenceData * T_Front / T_Tail * WheelSize * 144) / 10000);//车速 = 踏频 * 2.4 * 前飞齿数 / 后飞齿数 * 60 / 1000 km/h,结果单位0.1km/h
  78. FltSum += *SpeedData;
  79. FltCount++;
  80. if(FltCount >= 8)
  81. {
  82. FltCount = 0;
  83. *BikeSpeed = FltSum >> 3;
  84. FltSum = 0;
  85. }
  86. }
  87. }
  88. //SpeedCal_ByCommunication(&MC_SpeedSensorData, &MC_RunInfo.BikeSpeed, MC_ConfigParam1.WheelSize + MC_ConfigParam1.WheelSizeAdj);
  89. void SpeedCal_ByCommunication(MC_SpeedSensorData_Struct_t* p_MC_SpeedSensorData, uint16_t* AvgResult, uint8_t WheelSize)
  90. {
  91. //粗暴简单将自动变速器的值传递过来,因为自动变速器已做滤波
  92. if(p_MC_SpeedSensorData->IsStopFlag == FALSE)
  93. {
  94. *AvgResult = CanEnvioloData.u16Get_Gear_Vehicle_Speed;
  95. p_MC_SpeedSensorData->Speed_Data = CanEnvioloData.u16Get_Gear_Vehicle_Speed;
  96. }
  97. else
  98. {
  99. p_MC_SpeedSensorData->Speed_Data = 0;
  100. *AvgResult = 0;
  101. }
  102. #if 0
  103. //车速计算
  104. // static uint32_t PeriodTimeCnt = 0;
  105. // static uint16_t u16FiltTemp[10];
  106. // static bool BArrayFullFalg = false;
  107. // static uint8_t i = 0;
  108. if((HAL_GetTick() - PeriodTimeCnt) >= 200)
  109. {
  110. if(p_MC_SpeedSensorData->IsStopFlag == FALSE)
  111. {
  112. if(BArrayFullFalg == false)
  113. {
  114. u16FiltTemp[i++] = CanEnvioloData.u16Get_Gear_Vehicle_Speed;
  115. *AvgResult = MovingAverageFilter(CanEnvioloData.u16Get_Gear_Vehicle_Speed, u16FiltTemp, i);
  116. if(i >= 10)
  117. {
  118. BArrayFullFalg = true;
  119. i = 0;
  120. }
  121. }
  122. else
  123. {
  124. *AvgResult = MovingAverageFilter(CanEnvioloData.u16Get_Gear_Vehicle_Speed, u16FiltTemp, sizeof(u16FiltTemp) >> 1);
  125. //p_MC_SpeedSensorData->Speed_Data = *AvgResult;
  126. }
  127. p_MC_SpeedSensorData->Speed_Data = *AvgResult;
  128. }
  129. //车速计算
  130. // if(p_MC_SpeedSensorData->IsStopFlag == FALSE)
  131. // {
  132. //// if(p_MC_SpeedSensorData->DiffTime_ms == 0)
  133. //// {
  134. //// p_MC_SpeedSensorData->DiffTime_ms = 0xFFFFFFFF;
  135. //// }
  136. // //p_MC_SpeedSensorData->Speed_Data = (uint32_t)WheelSize * 360 / p_MC_SpeedSensorData->DiffTime_ms;//单位0.1km/h
  137. // p_MC_SpeedSensorData->Speed_Data = CanEnvioloData.u16Get_Gear_Vehicle_Speed;
  138. // //滑动均值滤波
  139. // *AvgResult = MovingAverageFilter(p_MC_SpeedSensorData->Speed_Data, u16FiltTemp, sizeof(u16FiltTemp) >> 1);
  140. // //*AvgResult = CanEnvioloData.u16Get_Gear_Vehicle_Speed;
  141. // }
  142. else
  143. {
  144. p_MC_SpeedSensorData->Speed_Data = 0;
  145. *AvgResult = 0;
  146. ArrayFillZero(u16FiltTemp, sizeof(u16FiltTemp) >> 1);
  147. return;
  148. }
  149. PeriodTimeCnt = HAL_GetTick();
  150. }
  151. #endif
  152. }