adc.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818
  1. /**
  2. ******************************************************************************
  3. * File Name : ADC.c
  4. * Description : This file provides code for the configuration
  5. * of the ADC instances.
  6. ******************************************************************************
  7. ** This notice applies to any and all portions of this file
  8. * that are not between comment pairs USER CODE BEGIN and
  9. * USER CODE END. Other portions of this file, whether
  10. * inserted by the user or by software development tools
  11. * are owned by their respective copyright owners.
  12. *
  13. * COPYRIGHT(c) 2019 STMicroelectronics
  14. *
  15. * Redistribution and use in source and binary forms, with or without modification,
  16. * are permitted provided that the following conditions are met:
  17. * 1. Redistributions of source code must retain the above copyright notice,
  18. * this list of conditions and the following disclaimer.
  19. * 2. Redistributions in binary form must reproduce the above copyright notice,
  20. * this list of conditions and the following disclaimer in the documentation
  21. * and/or other materials provided with the distribution.
  22. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  23. * may be used to endorse or promote products derived from this software
  24. * without specific prior written permission.
  25. *
  26. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  27. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  28. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  29. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  30. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  31. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  32. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  33. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  34. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  35. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. ******************************************************************************
  38. */
  39. /* Includes ------------------------------------------------------------------*/
  40. #include "adc.h"
  41. #include "gpio.h"
  42. #include "dma.h"
  43. /* USER CODE BEGIN 0 */
  44. #include "ntc_sensor.h"
  45. #include "tim.h"
  46. #include "hall_sensor.h"
  47. #include "MC_Globals.h"
  48. #include "gas_sensor.h"
  49. #include "torque_sensor.h"
  50. #include "math_tools.h"
  51. #include "motor_control.h"
  52. uint16_t ADC1_Result[ADC1_DATA_NUM] = {0};
  53. uint16_t ADC1_Result_Filt[ADC1_DATA_NUM] = {0};
  54. uint16_t ADC2_Result[ADC2_DATA_NUM] = {0};
  55. uint16_t ADC2_Result_Filt[ADC2_DATA_NUM]= {0};
  56. FlagStatus ADC2_ConvCpmplete_Flag = RESET;
  57. ADC_SensorData_Struct_t ADC_SensorData = {0, 0};//力矩传感器和指拨传感器
  58. ADC_3ShuntCurrent_OffSet_Struct_t ADC_3ShuntCurrent_OffSet = {32768, 32768, 32768};//三相电流零点
  59. ADC_3ShuntCurrent_Struct_t ADC_3ShuntCurrent = {0};
  60. ADC_3ShuntCurrent_Struct_t ADC_3ShuntCurrent_RMSValue = {0};
  61. uint16_t uw_current_offset = 2048;//母线电流零点
  62. /* USER CODE END 0 */
  63. ADC_HandleTypeDef hadc1;
  64. ADC_HandleTypeDef hadc2;
  65. DMA_HandleTypeDef hdma_adc1;
  66. /* ADC1 init function */
  67. void MX_ADC1_Init(void)
  68. {
  69. ADC_ChannelConfTypeDef sConfig;
  70. /**Common config
  71. */
  72. hadc1.Instance = ADC1;
  73. hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
  74. hadc1.Init.ContinuousConvMode = DISABLE;
  75. hadc1.Init.DiscontinuousConvMode = DISABLE;
  76. hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
  77. hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
  78. hadc1.Init.NbrOfConversion = 11;
  79. if (HAL_ADC_Init(&hadc1) != HAL_OK)
  80. {
  81. _Error_Handler(__FILE__, __LINE__);
  82. }
  83. /**Configure Regular Channel PCB温度
  84. */
  85. sConfig.Channel = ADC_CHANNEL_10;
  86. sConfig.Rank = ADC_REGULAR_RANK_1;
  87. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  88. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  89. {
  90. _Error_Handler(__FILE__, __LINE__);
  91. }
  92. /**Configure Regular Channel 母线电压
  93. */
  94. sConfig.Channel = ADC_CHANNEL_11;
  95. sConfig.Rank = ADC_REGULAR_RANK_2;
  96. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  97. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  98. {
  99. _Error_Handler(__FILE__, __LINE__);
  100. }
  101. /**Configure Regular Channel 绕组温度
  102. */
  103. sConfig.Channel = ADC_CHANNEL_12;
  104. sConfig.Rank = ADC_REGULAR_RANK_3;
  105. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  106. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  107. {
  108. _Error_Handler(__FILE__, __LINE__);
  109. }
  110. /**Configure Regular Channel 母线电流
  111. */
  112. sConfig.Channel = ADC_CHANNEL_13;
  113. sConfig.Rank = ADC_REGULAR_RANK_4;
  114. sConfig.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
  115. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  116. {
  117. _Error_Handler(__FILE__, __LINE__);
  118. }
  119. /**Configure Regular Channel 力矩传感器1
  120. */
  121. sConfig.Channel = ADC_CHANNEL_5;
  122. sConfig.Rank = ADC_REGULAR_RANK_5;
  123. sConfig.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
  124. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  125. {
  126. _Error_Handler(__FILE__, __LINE__);
  127. }
  128. /**Configure Regular Channel 力矩传感器2
  129. */
  130. sConfig.Channel = ADC_CHANNEL_4;
  131. sConfig.Rank = ADC_REGULAR_RANK_6;
  132. sConfig.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
  133. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  134. {
  135. _Error_Handler(__FILE__, __LINE__);
  136. }
  137. /**Configure Regular Channel 力矩传感器3
  138. */
  139. sConfig.Channel = ADC_CHANNEL_15;
  140. sConfig.Rank = ADC_REGULAR_RANK_7;
  141. sConfig.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
  142. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  143. {
  144. _Error_Handler(__FILE__, __LINE__);
  145. }
  146. /**Configure Regular Channel TE工作电压
  147. */
  148. sConfig.Channel = ADC_CHANNEL_7;
  149. sConfig.Rank = ADC_REGULAR_RANK_8;
  150. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  151. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  152. {
  153. _Error_Handler(__FILE__, __LINE__);
  154. }
  155. /**Configure Regular Channel 指拨输入
  156. */
  157. sConfig.Channel = ADC_CHANNEL_14;
  158. sConfig.Rank = ADC_REGULAR_RANK_9;
  159. sConfig.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
  160. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  161. {
  162. _Error_Handler(__FILE__, __LINE__);
  163. }
  164. /**Configure Regular Channel MCU温度
  165. */
  166. sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
  167. sConfig.Rank = ADC_REGULAR_RANK_10;
  168. sConfig.SamplingTime = ADC_SAMPLETIME_13CYCLES_5;
  169. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  170. {
  171. _Error_Handler(__FILE__, __LINE__);
  172. }
  173. /**Configure Regular Channel Vref
  174. */
  175. sConfig.Channel = ADC_CHANNEL_VREFINT;
  176. sConfig.Rank = ADC_REGULAR_RANK_11;
  177. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  178. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  179. {
  180. _Error_Handler(__FILE__, __LINE__);
  181. }
  182. }
  183. /* ADC2 init function */
  184. void MX_ADC2_Init(void)
  185. {
  186. ADC_InjectionConfTypeDef sConfigInjected;
  187. /**Common config
  188. */
  189. hadc2.Instance = ADC2;
  190. hadc2.Init.ScanConvMode = ADC_SCAN_ENABLE;
  191. hadc2.Init.ContinuousConvMode = DISABLE;
  192. hadc2.Init.DiscontinuousConvMode = DISABLE;
  193. hadc2.Init.ExternalTrigConv = ADC_EXTERNALTRIGINJECCONV_EDGE_NONE;
  194. hadc2.Init.DataAlign = ADC_DATAALIGN_RIGHT;
  195. hadc2.Init.NbrOfConversion = 1;
  196. if (HAL_ADC_Init(&hadc2) != HAL_OK)
  197. {
  198. _Error_Handler(__FILE__, __LINE__);
  199. }
  200. /**Configure Injected Channel
  201. */
  202. sConfigInjected.InjectedChannel = ADC_CHANNEL_1;
  203. sConfigInjected.InjectedRank = ADC_INJECTED_RANK_1;
  204. sConfigInjected.InjectedNbrOfConversion = 3;
  205. sConfigInjected.InjectedSamplingTime = ADC_SAMPLETIME_1CYCLE_5;
  206. sConfigInjected.ExternalTrigInjecConv = ADC_EXTERNALTRIGINJECCONV_T1_CC4;
  207. sConfigInjected.AutoInjectedConv = DISABLE;
  208. sConfigInjected.InjectedDiscontinuousConvMode = DISABLE;
  209. sConfigInjected.InjectedOffset = 0;
  210. if (HAL_ADCEx_InjectedConfigChannel(&hadc2, &sConfigInjected) != HAL_OK)
  211. {
  212. _Error_Handler(__FILE__, __LINE__);
  213. }
  214. /**Configure Injected Channel
  215. */
  216. sConfigInjected.InjectedChannel = ADC_CHANNEL_2;
  217. sConfigInjected.InjectedRank = ADC_INJECTED_RANK_2;
  218. if (HAL_ADCEx_InjectedConfigChannel(&hadc2, &sConfigInjected) != HAL_OK)
  219. {
  220. _Error_Handler(__FILE__, __LINE__);
  221. }
  222. /**Configure Injected Channel
  223. */
  224. sConfigInjected.InjectedChannel = ADC_CHANNEL_3;
  225. sConfigInjected.InjectedRank = ADC_INJECTED_RANK_3;
  226. if (HAL_ADCEx_InjectedConfigChannel(&hadc2, &sConfigInjected) != HAL_OK)
  227. {
  228. _Error_Handler(__FILE__, __LINE__);
  229. }
  230. }
  231. void HAL_ADC_MspInit(ADC_HandleTypeDef* adcHandle)
  232. {
  233. GPIO_InitTypeDef GPIO_InitStruct;
  234. if(adcHandle->Instance==ADC1)
  235. {
  236. /* USER CODE BEGIN ADC1_MspInit 0 */
  237. /* USER CODE END ADC1_MspInit 0 */
  238. /* ADC1 clock enable */
  239. __HAL_RCC_ADC1_CLK_ENABLE();
  240. /**ADC1 GPIO Configuration
  241. PC0 ------> ADC1_IN10
  242. PC1 ------> ADC1_IN11
  243. PC2 ------> ADC1_IN12
  244. PC3 ------> ADC1_IN13
  245. PA4 ------> ADC1_IN4
  246. PA5 ------> ADC1_IN5
  247. PA7 ------> ADC1_IN7
  248. PC4 ------> ADC1_IN14
  249. PC5 ------> ADC1_IN15
  250. */
  251. GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3
  252. |GPIO_PIN_4|GPIO_PIN_5;
  253. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  254. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  255. GPIO_InitStruct.Pin = GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_7;
  256. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  257. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  258. /* ADC1 DMA Init */
  259. /* ADC1 Init */
  260. hdma_adc1.Instance = DMA1_Channel1;
  261. hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
  262. hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
  263. hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
  264. hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
  265. hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
  266. hdma_adc1.Init.Mode = DMA_CIRCULAR;
  267. hdma_adc1.Init.Priority = DMA_PRIORITY_LOW;
  268. if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
  269. {
  270. _Error_Handler(__FILE__, __LINE__);
  271. }
  272. __HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc1);
  273. /* USER CODE BEGIN ADC1_MspInit 1 */
  274. /* USER CODE END ADC1_MspInit 1 */
  275. }
  276. else if(adcHandle->Instance==ADC2)
  277. {
  278. /* USER CODE BEGIN ADC2_MspInit 0 */
  279. /* USER CODE END ADC2_MspInit 0 */
  280. /* ADC2 clock enable */
  281. __HAL_RCC_ADC2_CLK_ENABLE();
  282. /**ADC2 GPIO Configuration
  283. PA1 ------> ADC2_IN1
  284. PA2 ------> ADC2_IN2
  285. PA3 ------> ADC2_IN3
  286. */
  287. GPIO_InitStruct.Pin = GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3;
  288. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  289. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  290. /* ADC2 interrupt Init */
  291. HAL_NVIC_SetPriority(ADC1_2_IRQn, 1, 1);
  292. HAL_NVIC_EnableIRQ(ADC1_2_IRQn);
  293. /* USER CODE BEGIN ADC2_MspInit 1 */
  294. /* USER CODE END ADC2_MspInit 1 */
  295. }
  296. }
  297. void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
  298. {
  299. if(adcHandle->Instance==ADC1)
  300. {
  301. /* USER CODE BEGIN ADC1_MspDeInit 0 */
  302. /* USER CODE END ADC1_MspDeInit 0 */
  303. /* Peripheral clock disable */
  304. __HAL_RCC_ADC1_CLK_DISABLE();
  305. /**ADC1 GPIO Configuration
  306. PC0 ------> ADC1_IN10
  307. PC1 ------> ADC1_IN11
  308. PC2 ------> ADC1_IN12
  309. PC3 ------> ADC1_IN13
  310. PA4 ------> ADC1_IN4
  311. PA5 ------> ADC1_IN5
  312. PA7 ------> ADC1_IN7
  313. PC4 ------> ADC1_IN14
  314. PC5 ------> ADC1_IN15
  315. */
  316. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3
  317. |GPIO_PIN_4|GPIO_PIN_5);
  318. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_7);
  319. /* ADC1 DMA DeInit */
  320. HAL_DMA_DeInit(adcHandle->DMA_Handle);
  321. /* USER CODE BEGIN ADC1_MspDeInit 1 */
  322. /* USER CODE END ADC1_MspDeInit 1 */
  323. }
  324. else if(adcHandle->Instance==ADC2)
  325. {
  326. /* USER CODE BEGIN ADC2_MspDeInit 0 */
  327. /* USER CODE END ADC2_MspDeInit 0 */
  328. /* Peripheral clock disable */
  329. __HAL_RCC_ADC2_CLK_DISABLE();
  330. /**ADC2 GPIO Configuration
  331. PA1 ------> ADC2_IN1
  332. PA2 ------> ADC2_IN2
  333. PA3 ------> ADC2_IN3
  334. */
  335. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3);
  336. /* USER CODE BEGIN ADC2_MspDeInit 1 */
  337. /* USER CODE END ADC2_MspDeInit 1 */
  338. }
  339. }
  340. /* USER CODE BEGIN 1 */
  341. void ADC_Start(void)
  342. {
  343. HAL_ADCEx_Calibration_Start(&hadc1);
  344. HAL_ADCEx_Calibration_Start(&hadc2);
  345. HAL_ADC_Start(&hadc1);
  346. HAL_ADC_Start(&hadc2);
  347. HAL_ADCEx_InjectedStart_IT(&hadc2);
  348. HAL_ADC_Start_DMA(&hadc1, (uint32_t *)ADC1_Result, ADC1_DATA_NUM);
  349. __HAL_DMA_DISABLE_IT(hadc1.DMA_Handle, DMA_IT_HT);
  350. HAL_TIM_Base_Start_IT(&PWM_TIMER);
  351. HAL_TIM_PWM_Start(&PWM_TIMER, TIM_CHANNEL_4);
  352. HAL_TIMEx_PWMN_Start(&PWM_TIMER, TIM_CHANNEL_4);
  353. }
  354. //更新三相电流采样值
  355. void HAL_ADCEx_InjectedConvCpltCallback(ADC_HandleTypeDef* hadc)
  356. {
  357. //更新3相电流采样值
  358. ADC2_Result[ADC2_RANK_CURRENT_B] = HAL_ADCEx_InjectedGetValue(hadc,1) << 4;
  359. ADC2_Result[ADC2_RANK_CURRENT_C] = HAL_ADCEx_InjectedGetValue(hadc,2) << 4;
  360. ADC2_Result[ADC2_RANK_CURRENT_A] = HAL_ADCEx_InjectedGetValue(hadc,3) << 4;
  361. //计算三相电流
  362. ADC_3ShuntCurrent.uw_phase_a = (int16_t)(ADC_3ShuntCurrent_OffSet.uw_phase_a_offset - ADC2_Result[ADC2_RANK_CURRENT_A]);
  363. ADC_3ShuntCurrent.uw_phase_b = (int16_t)(ADC_3ShuntCurrent_OffSet.uw_phase_b_offset - ADC2_Result[ADC2_RANK_CURRENT_B]);
  364. ADC_3ShuntCurrent.uw_phase_c = (int16_t)(ADC_3ShuntCurrent_OffSet.uw_phase_c_offset - ADC2_Result[ADC2_RANK_CURRENT_C]);
  365. ///计算三相电流有效值
  366. PhaseCurrent_CalRMSValue(&ADC_3ShuntCurrent, &ADC_3ShuntCurrent_RMSValue);
  367. ADC2_ConvCpmplete_Flag = SET;
  368. }
  369. //更新ADC采样结果
  370. void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
  371. {
  372. #if 1
  373. static uint32_t PeriodTestCnt = 0;
  374. PeriodTestCnt++;
  375. if(PeriodTestCnt > 300)
  376. {
  377. PeriodTestCnt = 0;
  378. }
  379. #endif
  380. int16_t Temp_16;
  381. int32_t Temp_32;
  382. static int32_t BusVoltageFltSum = 0;
  383. static int32_t IdcFltSum = 0;
  384. static uint16_t T_Filt_Cnt = 0;
  385. static uint32_t T_Coil_Sum = 0;
  386. static uint32_t T_PCB_Sum = 0;
  387. static uint32_t T_MCU_Sum = 0;
  388. static TrueOrFalse_Flag_Struct_t T_MCU_Init_Flag = FALSE;
  389. static uint8_t T_MCU_Init = 0;
  390. static uint16_t T_MCU_Init_AD = 0;
  391. static int32_t GasSensorFltSum = 0, HardwareVersionADFltSum=0;
  392. static TrueOrFalse_Flag_Struct_t MOS_NTC_InitFinishedFlag = FALSE;
  393. //更新PCB温度,绕组温度,MCU温度
  394. if(VersionIdentifyFinishedFlag == FALSE) //硬件版本未识别前,温度默认为25度
  395. {
  396. MC_RunInfo.T_PCB = 65;
  397. MC_RunInfo.T_Coil = 65;
  398. MC_RunInfo.T_MCU = 65;
  399. }
  400. else
  401. {
  402. if( MC_HallSensorData.InverterExistFlag == FALSE )
  403. {
  404. if(MOS_NTC_InitFinishedFlag == FALSE)
  405. {
  406. MOS_NTC_InitFinishedFlag = TRUE;
  407. MOS_NTC_Init();
  408. }
  409. }
  410. T_PCB_Sum += ADC1_Result[ADC1_RANK_NTC_PCB];
  411. T_Coil_Sum += ADC1_Result[ADC1_RANK_NTC_COIL];
  412. T_MCU_Sum += ADC1_Result[ADC1_RANK_TP_MCU];
  413. T_Filt_Cnt++;
  414. if(T_Filt_Cnt >= 3000)
  415. {
  416. if( MC_HallSensorData.InverterExistFlag == FALSE )
  417. {
  418. MC_RunInfo.T_PCB = GetNTCTempera_20K(T_PCB_Sum / 3000);
  419. MC_RunInfo.T_Coil = GetNTCTempera_20K(T_Coil_Sum / 3000);
  420. MC_RunInfo.T_MCU = GetNTCTempera_20K(T_MCU_Sum / 3000); //MOS管NTC温度
  421. }
  422. else
  423. {
  424. //计算PCB温度
  425. MC_RunInfo.T_PCB = GetNTCTempera(T_PCB_Sum / 3000);
  426. //计算绕组温度
  427. MC_RunInfo.T_Coil = GetNTCTempera(T_Coil_Sum / 3000);
  428. //MCU温度根据PCB初始温度进行校准
  429. if(T_MCU_Init_Flag == FALSE)
  430. {
  431. T_MCU_Init = MC_RunInfo.T_PCB;//校准时温度
  432. T_MCU_Init_AD = T_MCU_Sum / 3000;//校准时AD值
  433. T_MCU_Init_Flag = TRUE;
  434. }
  435. //计算MCU温度
  436. MC_RunInfo.T_MCU = T_MCU_Init + ((int16_t)(T_MCU_Init_AD - T_MCU_Sum / 3000) * 192 >> 10);//4.3mV/度, 3300 / 4095 / 4.3 * 1024 = 192
  437. }
  438. T_Filt_Cnt = 0;
  439. T_PCB_Sum = 0;
  440. T_Coil_Sum = 0;
  441. T_MCU_Sum = 0;
  442. }
  443. }
  444. //更新母线电压
  445. BusVoltageFltSum += ((ADC1_Result[ADC1_RANK_VIN] << 10) - BusVoltageFltSum) >> 9;
  446. MC_RunInfo.BusVoltage = (uint32_t)((BusVoltageFltSum >> 10) * 18382) >> 10;//3300 * 1047 / (4095 * 47)
  447. MC_RunInfo.BusVoltage += (MC_RunInfo.BusCurrent >> 7) * 8; //根据母线电流和估算的线阻进行补偿, 补偿电阻 0.2 * 128 = 25.6
  448. if( MCUManufacturer == HK32F103RBT6 )
  449. {
  450. MC_RunInfo.BusVoltage = ((MC_RunInfo.BusVoltage - 8100) * 1402) >> 10;
  451. }
  452. //更新母线电流
  453. if( MC_HallSensorData.InverterExistFlag == FALSE )
  454. {
  455. Temp_32 = (ADC1_Result[ADC1_RANK_CURRENT] - uw_current_offset) * 39449 >> 10; //3300/4095* 0.98/8.2 /0.0025
  456. }
  457. else
  458. {
  459. Temp_32 = (ADC1_Result[ADC1_RANK_CURRENT] - uw_current_offset) * 50000 >> 11; //3300/4095* 0.98/13 /0.0025
  460. }
  461. Temp_32 = (Temp_32 <= 0) ? 0 : ((Temp_32 >= 50000) ? 50000 : Temp_32);
  462. IdcFltSum += ((Temp_32 << 10) - IdcFltSum) >> 9;
  463. MC_RunInfo.BusCurrent = IdcFltSum >> 10;
  464. //更新力矩传感器
  465. switch(TorsueSensorFaultStatus.FaultStatusCode)
  466. {
  467. case 0x00://无传感器异常,取三个传感器的平均值
  468. {
  469. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_1] - TorqueSensor_1_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_1_Param.Torque_Cal_K;
  470. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  471. MC_RunInfo.TorqueSensorData1 = Temp_16 / 28;
  472. Temp_32 = Temp_16;
  473. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_2] - TorqueSensor_2_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_2_Param.Torque_Cal_K;
  474. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  475. MC_RunInfo.TorqueSensorData2 = Temp_16 / 28;
  476. Temp_32 += Temp_16;
  477. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_3] - TorqueSensor_3_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_3_Param.Torque_Cal_K;
  478. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  479. MC_RunInfo.TorqueSensorData3 = Temp_16 / 28;
  480. Temp_32 += Temp_16;
  481. Temp_32 = ((Temp_32 <= 0) ? 0 : Temp_32 / 3);
  482. break;
  483. }
  484. case 0x01://传感器1异常,取传感器2,3平均值
  485. {
  486. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_2] - TorqueSensor_2_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_2_Param.Torque_Cal_K;
  487. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  488. MC_RunInfo.TorqueSensorData2 = Temp_16 / 28;
  489. Temp_32 = Temp_16;
  490. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_3] - TorqueSensor_3_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_3_Param.Torque_Cal_K;
  491. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  492. MC_RunInfo.TorqueSensorData3 = Temp_16 / 28;
  493. Temp_32 += Temp_16;
  494. Temp_32 = ((Temp_32 <= 0) ? 0 : Temp_32 / 2);
  495. break;
  496. }
  497. case 0x02://传感器2异常,取传感器1,3平均值
  498. {
  499. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_1] - TorqueSensor_1_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_1_Param.Torque_Cal_K;
  500. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  501. MC_RunInfo.TorqueSensorData1 = Temp_16 / 28;
  502. Temp_32 = Temp_16;
  503. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_3] - TorqueSensor_3_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_3_Param.Torque_Cal_K;
  504. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  505. MC_RunInfo.TorqueSensorData3 = Temp_16 / 28;
  506. Temp_32 += Temp_16;
  507. Temp_32 = ((Temp_32 <= 0) ? 0 : Temp_32 / 2);
  508. break;
  509. }
  510. case 0x04://传感器3异常,取传感器1,2平均值
  511. {
  512. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_1] - TorqueSensor_1_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_1_Param.Torque_Cal_K;
  513. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  514. MC_RunInfo.TorqueSensorData1 = Temp_16 / 28;
  515. Temp_32 = Temp_16;
  516. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_2] - TorqueSensor_2_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_2_Param.Torque_Cal_K;
  517. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  518. MC_RunInfo.TorqueSensorData2 = Temp_16 / 28;
  519. Temp_32 += Temp_16;
  520. Temp_32 = ((Temp_32 <= 0) ? 0 : Temp_32 / 2);
  521. break;
  522. }
  523. case 0x03://传感器1 2异常,取传感器3
  524. {
  525. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_3] - TorqueSensor_3_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_3_Param.Torque_Cal_K;
  526. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  527. MC_RunInfo.TorqueSensorData3 = Temp_16 / 28;
  528. Temp_32 = Temp_16;
  529. break;
  530. }
  531. case 0x05://传感器1 3异常,取传感器2
  532. {
  533. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_2] - TorqueSensor_2_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_2_Param.Torque_Cal_K;
  534. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  535. MC_RunInfo.TorqueSensorData2 = Temp_16 / 28;
  536. Temp_32 = Temp_16;
  537. break;
  538. }
  539. case 0x06://传感器2 3异常,取传感器1
  540. {
  541. Temp_16 = (ADC1_Result[ADC1_RANK_TORQUE_SENSOR_1] - TorqueSensor_1_Param.Torque_OffSetData.PresentData) * 100 / TorqueSensor_1_Param.Torque_Cal_K;
  542. Temp_16 = (Temp_16 <= 0) ? 0 : Temp_16;
  543. MC_RunInfo.TorqueSensorData1 = Temp_16 / 28;
  544. Temp_32 = Temp_16;
  545. break;
  546. }
  547. default://超过3个传感器异常
  548. {
  549. Temp_32 = 0;
  550. break;
  551. }
  552. }
  553. #if 1 //采用原始采集值
  554. #if NormalWork //正常运行
  555. ADC_SensorData.TorqueSensor = Temp_32;
  556. #else //用于寿命测试,模拟输入力矩
  557. if(HAL_GetTick() < 5000)
  558. {
  559. Temp_32 = 0;
  560. }
  561. else
  562. {
  563. static uint32_t WaveTime_Zero = 0;
  564. static uint32_t Time_Enter = 0;
  565. if((HAL_GetTick() - Time_Enter) > 10)
  566. {
  567. WaveTime_Zero = HAL_GetTick();
  568. }
  569. Time_Enter = HAL_GetTick();
  570. Temp_32 = TriangleWaveGenerate(WaveTime_Zero, 250, 500 ,1500);
  571. }
  572. ADC_SensorData.TorqueSensor = Temp_32;
  573. #endif
  574. #else //采用滤波值
  575. static int32_t TorqueFltSum = 0;
  576. TorqueFltSum += ((Temp_32 << 10) - TorqueFltSum) >> 8;
  577. ADC_SensorData.TorqueSensor = TorqueFltSum >> 10;
  578. #endif
  579. //更新指拨
  580. if(IsGasSensorConnectedFlag == TRUE)
  581. {
  582. Temp_32 = ADC1_Result[ADC1_RANK_GAS] - GasSensor_OffSet;
  583. Temp_32 = (Temp_32 <= 0) ? 0 : Temp_32;
  584. GasSensorFltSum += ((Temp_32 << 10) - GasSensorFltSum) >> 8; //滤波延时0.33*256=85.3ms
  585. ADC_SensorData.GasSensor = GasSensorFltSum >> 10;
  586. }
  587. else
  588. {
  589. ADC_SensorData.GasSensor = 0;
  590. }
  591. //更新硬件版本AD
  592. HardwareVersionADFltSum += ((ADC1_Result[ADC1_RANK_HARDWARE_VER] << 10) - HardwareVersionADFltSum) >> 9;
  593. HardwareVersion_AD = (uint16_t)(HardwareVersionADFltSum >> 10);
  594. PowerDownProtection(ADC1_Result[ADC1_RANK_VIN]);
  595. }
  596. //ADC1和ADC2数据滑动滤波
  597. void ADC_SensorData_Filt(uint16_t* p_ADC1_Result_Filt, uint16_t* p_ADC2_Result_Filt)
  598. {
  599. static uint32_t PeriodTimeCnt = 0;
  600. static int32_t ADC1_FltSum[ADC1_DATA_NUM] = {0};
  601. static int32_t ADC2_FltSum[ADC2_DATA_NUM] = {0};
  602. uint8_t i;
  603. if((HAL_GetTick() - PeriodTimeCnt) >= 2)
  604. {
  605. for(i=0; i<ADC1_DATA_NUM; i++)
  606. {
  607. ADC1_FltSum[i] += ((ADC1_Result[i] << 10) - ADC1_FltSum[i]) >> 7;
  608. p_ADC1_Result_Filt[i] = ADC1_FltSum[i] >> 10;
  609. }
  610. for(i=0; i<ADC2_DATA_NUM; i++)
  611. {
  612. ADC2_FltSum[i] += ((ADC2_Result[i] << 10) - ADC2_FltSum[i]) >> 7;
  613. p_ADC2_Result_Filt[i] = ADC2_FltSum[i] >> 10;
  614. }
  615. PeriodTimeCnt = HAL_GetTick();
  616. }
  617. }
  618. //相电流有效值计算,有效值 = 最大值 * 0.707,运行频率15K
  619. void PhaseCurrent_CalRMSValue(ADC_3ShuntCurrent_Struct_t* ADC_3ShuntCurrent, ADC_3ShuntCurrent_Struct_t* PhaseCurrent_RMS)
  620. {
  621. static int16_t PhaseCurrentA_Max = 0;
  622. static int16_t PhaseCurrentB_Max = 0;
  623. static int16_t PhaseCurrentC_Max = 0;
  624. static int16_t Count = 0;
  625. int16_t DataTemp;
  626. static int32_t PhaseCurrentA_FltSum = 0;
  627. static int32_t PhaseCurrentB_FltSum = 0;
  628. static int32_t PhaseCurrentC_FltSum = 0;
  629. //计算A相电流峰值
  630. if(PhaseCurrentA_Max < ADC_3ShuntCurrent->uw_phase_a)
  631. {
  632. PhaseCurrentA_Max = ADC_3ShuntCurrent->uw_phase_a;
  633. }
  634. //计算B相电流峰值
  635. if(PhaseCurrentB_Max < ADC_3ShuntCurrent->uw_phase_b)
  636. {
  637. PhaseCurrentB_Max = ADC_3ShuntCurrent->uw_phase_b;
  638. }
  639. //计算C相电流峰值
  640. if(PhaseCurrentC_Max < ADC_3ShuntCurrent->uw_phase_c)
  641. {
  642. PhaseCurrentC_Max = ADC_3ShuntCurrent->uw_phase_c;
  643. }
  644. Count++;
  645. if(Count >= 500)
  646. {
  647. //计算A相电流有效值
  648. DataTemp = PhaseCurrentA_Max;
  649. PhaseCurrentA_Max = 0;
  650. PhaseCurrentA_FltSum += (((abs(DataTemp) * 724)) - PhaseCurrentA_FltSum) >> 5;
  651. PhaseCurrent_RMS->uw_phase_a = PhaseCurrentA_FltSum >> 10;
  652. //计算B相电流有效值
  653. DataTemp = PhaseCurrentB_Max;
  654. PhaseCurrentB_Max = 0;
  655. PhaseCurrentB_FltSum += (((abs(DataTemp) * 724)) - PhaseCurrentB_FltSum) >> 5;
  656. PhaseCurrent_RMS->uw_phase_b = PhaseCurrentB_FltSum >> 10;
  657. //计算C相电流有效值
  658. DataTemp = PhaseCurrentC_Max;
  659. PhaseCurrentC_Max = 0;
  660. PhaseCurrentC_FltSum += (((abs(DataTemp) * 724)) - PhaseCurrentC_FltSum) >> 5;
  661. PhaseCurrent_RMS->uw_phase_c = PhaseCurrentC_FltSum >> 10;
  662. Count = 0;
  663. }
  664. }
  665. //PA0切换AD,采集MOS管NTC
  666. void MOS_NTC_Init( void )
  667. {
  668. GPIO_InitTypeDef GPIO_InitStruct;
  669. ADC_ChannelConfTypeDef sConfig;
  670. GPIO_InitStruct.Pin = GPIO_PIN_0;
  671. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  672. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  673. __HAL_ADC_DISABLE(&hadc1);
  674. /**Configure Regular Channel MOS温度 */
  675. sConfig.Channel = ADC_CHANNEL_0;
  676. sConfig.Rank = ADC_REGULAR_RANK_10;
  677. sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
  678. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  679. {
  680. _Error_Handler(__FILE__, __LINE__);
  681. }
  682. }
  683. void PowerDownProtection( uint16_t BusVoltage_AD )
  684. {
  685. static uint16_t poweroncount=0, powerdowncount=0;
  686. static TrueOrFalse_Flag_Struct_t poweronFlag = FALSE;
  687. if(poweronFlag == FALSE)
  688. {
  689. if( BusVoltage_AD > 1671 ) //1671对应的母线电压为30V
  690. {
  691. if( ++poweroncount > 30000 ) //电压大于30V并持续10s左右
  692. {
  693. poweroncount=0;
  694. poweronFlag = TRUE;
  695. }
  696. }
  697. else poweroncount=0;
  698. }
  699. else
  700. {
  701. if( BusVoltage_AD < 1504 ) //1504对应的母线电压为27V
  702. {
  703. if( ++powerdowncount > 60 ) //电压小于27V并连续60次,大约持续20ms左右
  704. {
  705. Disable_PwmGpio_Out();
  706. poweronFlag = FALSE;
  707. PowerDown_SaveFlag = TRUE;
  708. }
  709. }
  710. else
  711. {
  712. powerdowncount=0;
  713. }
  714. }
  715. }
  716. /* USER CODE END 1 */
  717. /**
  718. * @}
  719. */
  720. /**
  721. * @}
  722. */
  723. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/