speed_sensor.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #include "speed_sensor.h"
  2. //局部变量定义
  3. //全局变量定义
  4. MC_SpeedSensorData_Struct_t MC_SpeedSensorData = {0, TRUE, FALSE, 0, 0xFFFFFFFF, 0};
  5. uint16_t MC_Speed_Array[10] = {0};
  6. /**************************局部函数定义*************************/
  7. /**************************全局函数定义*************************/
  8. //速度传感器IO初始化
  9. void SpeedSensor_GPIO_Init(void)
  10. {
  11. GPIO_InitTypeDef GPIO_InitStruct;
  12. __HAL_RCC_GPIOB_CLK_ENABLE();
  13. GPIO_InitStruct.Pin = SPEED_SENSOR_Pin;
  14. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
  15. GPIO_InitStruct.Pull = GPIO_PULLUP;
  16. HAL_GPIO_Init(SPEED_SENSOR_GPIO_Port, &GPIO_InitStruct);
  17. HAL_NVIC_SetPriority(SPEED_SENSOR_EXTI_IRQn, 2, 0);
  18. HAL_NVIC_EnableIRQ(SPEED_SENSOR_EXTI_IRQn);
  19. }
  20. //车速计算和停止判断处理
  21. void SpeedSensor_Process(MC_SpeedSensorData_Struct_t* p_MC_SpeedSensorData, uint16_t* AvgResult, uint8_t WheelSize)
  22. {
  23. //车速计算
  24. static uint32_t PeriodTimeCnt = 0;
  25. static uint32_t SpeedFltSum = 0;
  26. static uint8_t Count = 0;
  27. if((HAL_GetTick() - PeriodTimeCnt) >= 50)
  28. {
  29. //停止判断
  30. static uint32_t StopDelayTimeCnt = 0;
  31. if(p_MC_SpeedSensorData->IsTrigFlag == TRUE)
  32. {
  33. StopDelayTimeCnt = HAL_GetTick();
  34. p_MC_SpeedSensorData->IsTrigFlag = FALSE;
  35. }
  36. if((HAL_GetTick() - StopDelayTimeCnt) > 4000) // 超时4s信号触发标志未更新,认为停车
  37. {
  38. p_MC_SpeedSensorData->IsStopFlag = TRUE;
  39. }
  40. //车速计算,计算周期50ms
  41. if(p_MC_SpeedSensorData->IsStopFlag == FALSE)
  42. {
  43. if(p_MC_SpeedSensorData->DiffTime_ms == 0)
  44. {
  45. p_MC_SpeedSensorData->DiffTime_ms = 0xFFFFFFFF;
  46. }
  47. p_MC_SpeedSensorData->Speed_Data = (uint32_t)WheelSize * 360 / p_MC_SpeedSensorData->DiffTime_ms;//单位0.1km/h
  48. //在确定停止前进行衰减
  49. p_MC_SpeedSensorData->DiffTime_ms = p_MC_SpeedSensorData->DiffTime_ms * 1030 >> 10;
  50. }
  51. else
  52. {
  53. p_MC_SpeedSensorData->Speed_Data = 0;
  54. *AvgResult = 0;
  55. SpeedFltSum = 0;
  56. Count = 0;
  57. p_MC_SpeedSensorData->DiffTime_ms = 0xFFFFFFFF;
  58. return;
  59. }
  60. //计算400ms平均值
  61. SpeedFltSum += p_MC_SpeedSensorData->Speed_Data;
  62. Count++;
  63. if(Count >= 8)
  64. {
  65. *AvgResult = SpeedFltSum >> 3;
  66. SpeedFltSum = 0;
  67. Count = 0;
  68. }
  69. PeriodTimeCnt = HAL_GetTick();
  70. }
  71. }