AppFunc.c 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. /*
  2. * @Author : ChenJie
  3. * @Date : 2021-12-15 10:40:06
  4. * @Version : V3.0
  5. * @LastEditors : ChenJie
  6. * @LastEditTime : 2021-12-29 15:49:58
  7. * @Description : AppFunc
  8. * @FilePath : \VehicleControl\VehicleControl\src\System\Vehicle\AppFunc.c
  9. */
  10. #include "string.h"
  11. #include "stdlib.h"
  12. #include "HardwareLib.h"
  13. #include "CanVar.h"
  14. #include "math.h"
  15. #include "AppFunc.h"
  16. #include "Std_Types.h"
  17. /**
  18. * @brief : 互锁检测函数
  19. * @param {*}
  20. * @return {*}
  21. */
  22. void GetHVLockState(void)
  23. {
  24. UINT8 m_flg_HVlock1 = 0,m_flg_HVlock2 = 0;
  25. // PWM输出,互锁1检测,频率100HZ,占空比30%
  26. uint16 VehCo_fTestUI = 1000;
  27. uint16 VehCo_rTestUW = 3000;
  28. uint32 PwmFreAcq = 0;
  29. uint16 PwmDutyAcq = 0;
  30. PPWMDrv_Interface(_PPWM_INDEX_HVLOCK2, VehCo_fTestUI, VehCo_rTestUW);
  31. PulseAcqDrv_GetChanFreq(_PULSEACQ_INDEX_HVLOCK2, &PwmFreAcq, &PwmDutyAcq);
  32. if (abs(PwmFreAcq - VehCo_fTestUI) < 100 && abs(PwmDutyAcq - VehCo_rTestUW) < 500)
  33. {
  34. m_flg_HVlock1 = 1;
  35. }
  36. else
  37. {
  38. m_flg_HVlock1 = 0;
  39. }
  40. //互锁2检测,配置高有效,悬空为0则未接入,高电平为1则接入,
  41. DINDrv_SetChanThres(_DIN_INDEX_PLUGHVLOCK, 0, 4095 * 3);
  42. m_flg_HVlock2 = DINDrv_GetChanState(_DIN_INDEX_PLUGHVLOCK);
  43. }
  44. /**
  45. * @brief : 数字量传感器信号检测函数
  46. * @param {*}
  47. * @return {*}
  48. */
  49. void GetDIOState(void)
  50. {
  51. uint8 temp[4];
  52. //松开传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  53. memset(temp, 0x00, 4);
  54. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR1, 1, 4095U);
  55. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR2, 1, 4095U);
  56. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR3, 1, 4095U);
  57. DINDrv_SetChanThres(_DIN_INDEX_UNLOCKSENSOR4, 1, 4095U);
  58. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR1);
  59. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR2);
  60. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR3);
  61. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_UNLOCKSENSOR4);
  62. ebcd_st_unlockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  63. //夹紧传感器检测,配置低有效,底层悬空为1,触发为0,应用层输出悬空为0,触发为1
  64. memset(temp, 0x00, 4);
  65. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR1, 1, 4095U);
  66. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR2, 1, 4095U);
  67. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR3, 1, 4095U);
  68. DINDrv_SetChanThres(_DIN_INDEX_LOCKSENSOR4, 1, 4095U);
  69. temp[0] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR1);
  70. temp[1] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR2);
  71. temp[2] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR3);
  72. temp[3] = !DINDrv_GetChanState(_DIN_INDEX_LOCKSENSOR4);
  73. ebcd_st_lockSensor = (getbit(temp[3], 0) << 3) | (getbit(temp[2], 0) << 2) | (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  74. //落座传感器检测,配置高有效,悬空为0则未接入,高电平为1则接入
  75. memset(temp, 0x00, 4);
  76. DINDrv_SetChanThres(_DIN_INDEX_READYSENSOR1, 0, 4095 * 3);
  77. DINDrv_SetChanThres(_DIN_INDEX_READYSENSOR2, 0, 4095 * 3);
  78. temp[0] = DINDrv_GetChanState(_DIN_INDEX_READYSENSOR1);
  79. temp[1] = DINDrv_GetChanState(_DIN_INDEX_READYSENSOR1);
  80. ebcd_st_pedstSensor = (getbit(temp[1], 0) << 1) | (getbit(temp[0], 0) << 0);
  81. }
  82. /**
  83. * @brief : 获取模拟量输入值,并进行转换
  84. * @param {*}
  85. * @return {*}
  86. */
  87. void GetAIOValue(void)
  88. {
  89. uint16 AirPressureTemp_Vol = 0;
  90. uint16 PluginTemp1_Vol = 0;
  91. uint32 PluginTemp1_R = 0;
  92. uint16 PluginTemp2_Vol = 0;
  93. uint32 PluginTemp2_R = 0;
  94. uint16 PluginTemp3_Vol = 0;
  95. uint32 PluginTemp3_R = 0;
  96. uint16 PluginTemp4_Vol = 0;
  97. uint32 PluginTemp4_R = 0;
  98. AirPressureTemp_Vol = ATDDrv_GetChanResult(_ATD_INDEX_AIRPRESSURE);
  99. /*气压数据转换*/
  100. ebcd_P_airSensor = (uint16)(AirPressureTemp_Vol * 1000 / 4095.0);
  101. /*温度采集获取*/
  102. PluginTemp1_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP1);
  103. PluginTemp2_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP2);
  104. PluginTemp3_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP3);
  105. PluginTemp4_Vol = ATDDrv_GetChanResult(_ATD_INDEX_PLUGINTEMP4);
  106. PluginTemp1_R = (uint32)((PluginTemp1_Vol / (5.0 * 4095 - PluginTemp1_Vol)) * 1000.0);
  107. PluginTemp2_R = (uint32)((PluginTemp2_Vol / (5.0 * 4095 - PluginTemp2_Vol)) * 1000.0);
  108. PluginTemp3_R = (uint32)((PluginTemp3_Vol / (5.0 * 4095 - PluginTemp3_Vol)) * 1000.0);
  109. PluginTemp4_R = (uint32)((PluginTemp4_Vol / (5.0 * 4095 - PluginTemp4_Vol)) * 1000.0);
  110. ebcd_T_plugin[0] = (uint8)Look1_u32u16(PluginTemp1_R, R_table, T_table, 240);
  111. ebcd_T_plugin[1] = (uint8)Look1_u32u16(PluginTemp2_R, R_table, T_table, 240);
  112. ebcd_T_plugin[2] = (uint8)Look1_u32u16(PluginTemp3_R, R_table, T_table, 240);
  113. ebcd_T_plugin[3] = (uint8)Look1_u32u16(PluginTemp4_R, R_table, T_table, 240);
  114. }
  115. /**
  116. * @brief : lookUp Table Fun
  117. * @param {uint32} u0 x
  118. * @param {uint32} bp0 x_table
  119. * @param {uint16} table y_table
  120. * @param {uint16} maxIndex
  121. * @return {*}
  122. */
  123. uint16 Look1_u32u16(uint32 u0, uint32 *bp0, uint16 *table, uint16 MaxLen)
  124. {
  125. uint32 bpIdx = 0;
  126. uint32 iLeft = 0;
  127. uint32 iRght = 0;
  128. uint16 y = 0;
  129. uint32 yL_0d0 = 0;
  130. uint32 yR_0d0 = 0;
  131. uint32 maxIndex = MaxLen - 1;
  132. if (u0 <= bp0[0U])
  133. {
  134. iLeft = 0U;
  135. iRght = 0U;
  136. }
  137. else if (u0 < bp0[maxIndex])
  138. {
  139. //对折法寻找u0的位置
  140. bpIdx = maxIndex >> 1U;
  141. iLeft = 0U;
  142. iRght = maxIndex;
  143. while ((iRght - iLeft) > 1)
  144. {
  145. if (u0 < bp0[bpIdx])
  146. {
  147. iRght = bpIdx;
  148. }
  149. else
  150. {
  151. iLeft = bpIdx;
  152. }
  153. bpIdx = (iRght + iLeft) >> 1U;
  154. }
  155. }
  156. else
  157. {
  158. iLeft = maxIndex;
  159. iRght = maxIndex;
  160. }
  161. //找到位置以后计算插值
  162. if (iLeft != iRght)
  163. {
  164. //线性插值
  165. yR_0d0 = table[iLeft + 1U];
  166. yL_0d0 = table[iLeft];
  167. if (yR_0d0 >= yL_0d0)
  168. {
  169. y = (uint16)(((uint32)(u0 - bp0[iLeft]) * (yR_0d0 - yL_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]) + yL_0d0);
  170. }
  171. else
  172. {
  173. y = (uint16)(yL_0d0 - ((uint32)(u0 - bp0[iLeft]) * (yL_0d0 - yR_0d0)) / (bp0[iLeft + 1] - bp0[iLeft]));
  174. }
  175. }
  176. else
  177. {
  178. y = (uint16)table[iLeft];
  179. }
  180. return y;
  181. }
  182. #ifdef _APP_TEST_CODE
  183. void TestDeviceFun(void)
  184. {
  185. uint8 ManuEnable = 0;
  186. //控制算法
  187. AccPedCD_Update();
  188. AccPedCD_Monitor();
  189. PulseAcqDrv_GetChanFreq(_PULSEACQ_INDEX_CP_CHAN, &VehCo_fInputUIA[0], &VehCo_rInputUWA[0]);
  190. // DODrv_SetChanState(_DO_INDEX_CPCTL_CHAN,(uint8)VehCo_bTestCPCtrlUW_C);
  191. uint16 DistenceBufferV[2] = {0, 0}, DistenceBufferR[2] = {0, 0};
  192. //开关1采集
  193. DINDrv_SetChanThres(_DIN_INDEX_BAK1_CHAN, 1, 4095U);
  194. Switch1 = !DINDrv_GetChanState(_DIN_INDEX_BAK1_CHAN);
  195. //手动控制采集
  196. DINDrv_SetChanThres(_DIN_INDEX_BAK2_CHAN, 1, 4095U);
  197. ManuEnable = !DINDrv_GetChanState(_DIN_INDEX_BAK2_CHAN);
  198. //位移量采集
  199. DistenceBufferV[0] = ATDDrv_GetChanResult(_ATD_INDEX_BAK3_CHAN);
  200. DistenceBufferR[0] = (uint16)((DistenceBufferV[0] / (5.0 * 4095 - DistenceBufferV[0])) * 1000.0);
  201. Distence1 = (uint16)((2132 - DistenceBufferR[0]) * (0.1219));
  202. //压力采集
  203. PressureValueBuffer = ATDDrv_GetChanResult(_ATD_INDEX_ACCPED1_CHAN);
  204. PressureValue = (uint32)(PressureValueBuffer * 1000 / 4095.0);
  205. //控制输出
  206. VehCo_ctEEPTestUI += 10;
  207. VehCo_ctEEPTestUB += 10;
  208. if (VehCo_ctEEPTestUI >= 4 * 1000)
  209. {
  210. PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, 1); //输出 解锁持续9-4s
  211. ControlState = 1; //解锁
  212. }
  213. else
  214. {
  215. PSwtDrv_Interface(_PSWT_INDEX_HBAK1_CHAN, 0); //不输出
  216. ControlState = 2; //锁定 4 秒
  217. }
  218. if (VehCo_ctEEPTestUI >= 9 * 1000)
  219. {
  220. Control_Times++;
  221. VehCo_ctEEPTestUI = 0;
  222. }
  223. if (ManuEnable == 0)
  224. {
  225. Control_Times = 0;
  226. VehCo_ctEEPTestUI = 0;
  227. }
  228. }
  229. #endif