HLW8110.c 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404
  1. /*=========================================================================================================
  2. * File Name : HLW8110.c
  3. * Describe : HLW8110 UART 通讯程序,使用USATR2.(HLW8110 code,use USATE2)
  4. * Author : Tuqiang
  5. * Version : V1.3
  6. * Record : 2019/04/16,V1.2
  7. * Record : 2020/04/02, V1.3
  8. ==========================================================================================================*/
  9. #include "HLW8110.h"
  10. #include "stdio.h"
  11. #include "TM52F1386_bsp.h"
  12. #include "sTimeout.h"
  13. #include "iap.h"
  14. #include "uart2.h"
  15. #include "zigbee.h"
  16. #include "GLOBAL.h"
  17. #define HIGH 1
  18. #define LOW 0
  19. char HLW8110_Int_Result[3] = {0};
  20. // 8112A通道或8110通道校正系数
  21. #define D_CAL_U 1000 / 1000 // 电压校正系数
  22. #define D_CAL_A_I 1000 / 1000 // A通道电流校正系数
  23. #define D_CAL_A_P 1000 / 1000 // A通道功率校正系数
  24. #define D_CAL_A_E 1000 / 1000 // A通道电能校正系数
  25. // 8112 B通道校正系数
  26. #define D_CAL_B_P 1000 / 1000 // B通道功率校正系数
  27. #define D_CAL_B_I 1000 / 1000 // B通道电流校正系数
  28. #define D_CAL_B_E 1000 / 1000 // B通道电能校正系数
  29. #define UART_SEND_TIME 30
  30. unsigned char HLW8110Msg = 0; // 程序状态机
  31. hlw8110_power_t hlw8110_power_data;
  32. long int SystemTimer;
  33. unsigned char power_data[21] = {0};
  34. /*---------------------------------------------------------------------------------------------------------*/
  35. /*---------------------------------------------------------------------------------------------------------*/
  36. union IntData
  37. {
  38. unsigned int inte;
  39. unsigned char byte[2];
  40. };
  41. union LongData
  42. {
  43. unsigned long word_;
  44. unsigned int inte_[2];
  45. unsigned char byte_[4];
  46. };
  47. /*---------------------------------------------------------------------------------------------------------*/
  48. /*---------------------------------------------------------------------------------------------------------*/
  49. unsigned char u8_TxBuf[10] = {0xA5, 0x70};
  50. unsigned char u8_RxBuf[10];
  51. unsigned char u8_TX_Length;
  52. unsigned char u8_RX_Length;
  53. unsigned char u8_RX_Index = 0;
  54. // unsigned char B_ReadReg_Time_EN; // 串口读取寄存器数据,时间计数器标志位,1--开启计数,0--关闭计数
  55. // unsigned char B_Tx_Finish;
  56. unsigned char B_Rx_Finish;
  57. unsigned char B_Rx_Data_ING; // 接收数据标志位 , < 1:接收数据中,0:未接收到数据 >
  58. unsigned char B_Read_Error; // UART读取出据校验和出错,< 1:数据读错,0:数据读取正确 >
  59. unsigned char Temp_Read_Error = 0;
  60. // unsigned char u8_ReadReg_Index;
  61. // unsigned char u8_ReadReg_Time; // 串口读取寄存器数据的时间
  62. /*---------------------------------------------------------------------------------------------------------*/
  63. /*---------------------------------------------------------------------------------------------------------*/
  64. unsigned int U16_TempData;
  65. unsigned int U16_IFData;
  66. unsigned int U16_RIFData;
  67. unsigned int U16_LineFData;
  68. unsigned int U16_AngleData;
  69. unsigned int U16_PFData;
  70. unsigned int U16_HFConst_RegData;
  71. /*---------------------------------------------------------------------------------------------------------*/
  72. /*---------------------------------------------------------------------------------------------------------*/
  73. unsigned int U16_RMSIAC_RegData[3]; // A通道电流转换系数
  74. unsigned int U16_RMSIBC_RegData[3]; // B通道电流转换系数
  75. unsigned int U16_RMSUC_RegData[3]; // 电压通道转换系数
  76. unsigned int U16_PowerPAC_RegData[3]; // A通道功率转换系数
  77. unsigned int U16_PowerPBC_RegData[3]; // B通道功率转换系数
  78. unsigned int U16_PowerSC_RegData[3]; // 视在功率转换系数,如果选择A通道,则是A通道视在功率转换系数。A和B通道只能二者选其一
  79. unsigned int U16_EnergyAC_RegData[3]; // A通道有功电能(量)转换系数
  80. unsigned int U16_EnergyBC_RegData[3]; // A通道有功电能(量)转换系数
  81. unsigned int U16_CheckSUM_RegData[3]; // 转换系数的CheckSum
  82. unsigned int U16_CheckSUM_Data; // 转换系数计算出来的CheckSum
  83. unsigned int U16_Check_SysconReg_Data;
  84. unsigned int U16_Check_EmuconReg_Data;
  85. unsigned int U16_Check_Emucon2Reg_Data;
  86. /*---------------------------------------------------------------------------------------------------------*/
  87. /*---------------------------------------------------------------------------------------------------------*/
  88. unsigned long U32_RMSIA_RegData = 0; // A通道电流有效值寄存器
  89. unsigned long U32_RMSU_RegData = 0; // 电压有效值寄存器
  90. unsigned long U32_POWERPA_RegData = 0; // A通道功率有效值寄存器
  91. unsigned long U32_ENERGY_PA_RegData = 0; // A通道有功电能(量)有效值寄存器
  92. unsigned long U32_RMSIB_RegData; // B通道电流有效值寄存器
  93. unsigned long U32_POWERPB_RegData; // B通道功率有效值寄存器
  94. unsigned long U32_ENERGY_PB_RegData; // B通道有功电能(量)有效值寄存器
  95. /*---------------------------------------------------------------------------------------------------------*/
  96. /*---------------------------------------------------------------------------------------------------------*/
  97. float FF_AC_V = 0; // 电压有效值
  98. float FF_AC_I = 0; // A通道电流
  99. float FF_AC_P = 0; // A通道有功功率
  100. float FF_AC_E = 0; // A通道有功电能(量)
  101. float F_AC_BACKUP_E; // A通道电量备份
  102. float F_AC_PF; // 功率因素,A通道和B通道只能选其一
  103. float F_Angle; // 相角,A通道和B通道只能选其一
  104. /*---------------------------------------------------------------------------------------------------------*/
  105. /*---------------------------------------------------------------------------------------------------------*/
  106. float a_pf = 0.0;
  107. unsigned long b_pf = 0;
  108. float a_ea = 0.0;
  109. unsigned long b_ea = 0;
  110. float a_pa = 0.0;
  111. unsigned long b_pa = 0;
  112. unsigned long c_pa = 0;
  113. float a_u = 0.0;
  114. unsigned long b_u = 0;
  115. float a_i = 0.0;
  116. unsigned long b_i = 0;
  117. /*=========================================================================================================
  118. * Function : void Clear_RxBuf(void)
  119. * Describe : 在准备接收串口数据前,清空接收缓存器的数据
  120. * Input : none
  121. * Output : none
  122. * Return : none
  123. * Record : 2019/04/03
  124. =========================================================================================================*/
  125. void Clear_RxBuf(void)
  126. {
  127. unsigned char i;
  128. for (i = 0; i < 10; i++)
  129. {
  130. u8_RxBuf[i] = 0x00;
  131. }
  132. B_Rx_Data_ING = 0;
  133. B_Rx_Finish = FALSE;
  134. u8_RX_Index = 0;
  135. }
  136. /*=========================================================================================================
  137. * Function : unsigned char HLW8110_checkSum_Write(unsigned char u8_Reg_length)
  138. * Describe :
  139. * Input : none
  140. * Output : none
  141. * Return : none
  142. * Record : 2019/04/03
  143. =========================================================================================================*/
  144. unsigned char HLW8110_checkSum_Write(unsigned char u8_Reg_length)
  145. {
  146. unsigned char i;
  147. unsigned char Temp_u8_checksum;
  148. unsigned int a;
  149. a = 0x0000;
  150. Temp_u8_checksum = 0;
  151. for (i = 0; i < (u8_Reg_length - 1); i++)
  152. {
  153. a += u8_TxBuf[i];
  154. }
  155. a = ~a;
  156. Temp_u8_checksum = a & 0xff;
  157. return Temp_u8_checksum;
  158. }
  159. /*=========================================================================================================
  160. * Function : unsigned char HLW8110_checkSum_Read(void)
  161. * Describe :
  162. * Input : none
  163. * Output : none
  164. * Return : none
  165. * Record : 2019/04/03
  166. ==========================================================================================================*/
  167. unsigned char HLW8110_checkSum_Read(unsigned char u8_Reg_length)
  168. {
  169. unsigned char i;
  170. unsigned char Temp_u8_checksum;
  171. unsigned int a;
  172. a = 0x0000;
  173. Temp_u8_checksum = 0;
  174. for (i = 0; i < (u8_Reg_length - 1); i++)
  175. {
  176. a += u8_RxBuf[i];
  177. }
  178. a = a + u8_TxBuf[0] + u8_TxBuf[1];
  179. a = ~a;
  180. Temp_u8_checksum = a & 0xff;
  181. return Temp_u8_checksum;
  182. }
  183. /*=========================================================================================================
  184. * Function : void Uart_HLW8110_WriteREG_EN(void)
  185. * Describe :
  186. * Input : none
  187. * Output : none
  188. * Return : none
  189. * Record : 2019/04/03
  190. ==========================================================================================================*/
  191. void Uart_HLW8110_WriteREG_EN(void)
  192. {
  193. u8_TX_Length = 4;
  194. u8_RX_Length = 0;
  195. u8_TxBuf[0] = 0xa5;
  196. u8_TxBuf[1] = 0xea;
  197. u8_TxBuf[2] = 0xe5;
  198. // u8_TxBuf[3] = 0x8b; //checksum
  199. u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
  200. Start_Send_UartData(u8_TX_Length);
  201. }
  202. /*=========================================================================================================
  203. * Function : void Uart_HLW8110_WriteREG_DIS(void)
  204. * Describe :
  205. * Input : none
  206. * Output : none
  207. * Return : none
  208. * Record : 2019/04/03
  209. ==========================================================================================================*/
  210. void Uart_HLW8110_WriteREG_DIS(void)
  211. {
  212. u8_TX_Length = 4;
  213. u8_RX_Length = 0;
  214. u8_TxBuf[0] = 0xa5;
  215. u8_TxBuf[1] = 0xea;
  216. u8_TxBuf[2] = 0xdc;
  217. // u8_TxBuf[3] = 0x94; //checksum
  218. u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
  219. Start_Send_UartData(u8_TX_Length);
  220. }
  221. /*=========================================================================================================
  222. * Function : void Uart_HLW8110_Set_Channel_A(void)
  223. * Describe :
  224. * Input : none
  225. * Output : none
  226. * Return : none
  227. * Record : 2019/04/03
  228. ==========================================================================================================*/
  229. void Uart_HLW8110_Set_Channel_A(void)
  230. {
  231. u8_TX_Length = 4;
  232. u8_RX_Length = 0;
  233. u8_TxBuf[0] = 0xa5;
  234. u8_TxBuf[1] = 0xea;
  235. u8_TxBuf[2] = 0x5a;
  236. // u8_TxBuf[3] = 0x16; //checksum
  237. u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
  238. Start_Send_UartData(u8_TX_Length);
  239. }
  240. /*=========================================================================================================
  241. * Function : void Uart_Read_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length)
  242. * Describe :
  243. * Input :
  244. * Output :
  245. * Return :
  246. * Record : 2019/04/04
  247. ==========================================================================================================*/
  248. void Uart_Read_HLW8110_Reg(unsigned char ADDR_Reg, unsigned char u8_reg_length)
  249. {
  250. u8_TxBuf[0] = 0xa5;
  251. u8_TxBuf[1] = ADDR_Reg;
  252. u8_TX_Length = 2;
  253. u8_RX_Length = u8_reg_length + 1; // +1,是因为接收的数据长度,除了REG值,还有一个校验和数据
  254. Clear_RxBuf(); // 清空接收缓冲区
  255. Start_Send_UartData(u8_TX_Length);
  256. }
  257. /*=========================================================================================================
  258. * Function : void Uart_Write_HLW8110_Reg(unsigned char ADDR_Reg,unsigned char u8_reg_length,unsigned long u32_data)
  259. * Describe : 写寄存器命令,u8_reg_length:写入的寄存器数据字节长度
  260. * Input :
  261. * Output :
  262. * Return :
  263. * Record : 2019/04/03
  264. ==========================================================================================================*/
  265. void Uart_Write_HLW8110_Reg(unsigned char ADDR_Reg, unsigned char u8_reg_length, unsigned long u32_data)
  266. {
  267. // unsigned char i;
  268. union LongData;
  269. u8_TxBuf[0] = 0xa5;
  270. u8_TxBuf[1] = ADDR_Reg | 0x80;
  271. // Temp_u32_a.word_ = u32_data;
  272. // for (i = 0; i< u8_reg_length; i++)
  273. // {
  274. // u8_TxBuf[i+2] = Temp_u32_a.byte_[u8_reg_length-1-i]; //STM32,32位MCU,union定义,是低位在前
  275. // //u8_TxBuf[i+2] = Temp_u32_a.byte[4-u8_reg_length + i]; //STM8,STC MCU, union定义,是高位在前
  276. // }
  277. u8_TxBuf[2] = (unsigned char)((u32_data >> 8) & 0xff);
  278. u8_TxBuf[3] = (unsigned char)(u32_data & 0xff);
  279. u8_TX_Length = 3 + u8_reg_length;
  280. u8_RX_Length = 0;
  281. u8_TxBuf[u8_TX_Length - 1] = HLW8110_checkSum_Write(u8_TX_Length);
  282. Start_Send_UartData(u8_TX_Length);
  283. }
  284. /*=========================================================================================================
  285. * Function : void Uart_HLW8110_Reset(void)
  286. * Describe :
  287. * Input : none
  288. * Output : none
  289. * Return : none
  290. * Record : 2019/04/03
  291. ==========================================================================================================*/
  292. void Uart_HLW8110_Reset(void)
  293. {
  294. u8_TX_Length = 4;
  295. u8_RX_Length = 0;
  296. u8_TxBuf[0] = 0xa5;
  297. u8_TxBuf[1] = 0xea;
  298. u8_TxBuf[2] = 0x96;
  299. // u8_TxBuf[3] = 0xda; //checksum
  300. u8_TxBuf[3] = HLW8110_checkSum_Write(u8_TX_Length);
  301. Start_Send_UartData(u8_TX_Length);
  302. }
  303. /*=========================================================================================================
  304. * Function : void Judge_CheckSum_HLW8110_Calfactor(void)
  305. * Describe : 验证地址0x70-0x77地址的系数和
  306. * Input : none
  307. * Output : none
  308. * Return : none
  309. * Record : 2019/03/18
  310. ==========================================================================================================*/
  311. unsigned char Judge_CheckSum_HLW8110_Calfactor(unsigned char nun)
  312. {
  313. unsigned long a;
  314. unsigned int b;
  315. // unsigned int c;
  316. unsigned char d;
  317. // 读取RmsIAC、RmsIBC、RmsUC、PowerPAC、PowerPBC、PowerSC、EnergAc、EnergBc的值
  318. // Uart_Read_HLW8110_Reg(REG_SYSCON_ADDR,2);
  319. Uart_Read_HLW8110_Reg(REG_RMS_IAC_ADDR, 2);
  320. bsp_delay_ms(UART_SEND_TIME);
  321. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  322. {
  323. b = u8_RxBuf[0];
  324. if (nun == 1) // 第一路
  325. {
  326. U16_RMSIAC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
  327. }
  328. else if (nun == 2) // 第二路
  329. {
  330. U16_RMSIAC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
  331. }
  332. else if (nun == 3) // 第三路
  333. {
  334. U16_RMSIAC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("A通道电流转换系数:%x\n " ,U16_RMSIAC_RegData);
  335. }
  336. else
  337. {
  338. }
  339. }
  340. Uart_Read_HLW8110_Reg(REG_RMS_IBC_ADDR, 2);
  341. bsp_delay_ms(UART_SEND_TIME);
  342. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  343. {
  344. b = u8_RxBuf[0];
  345. if (nun == 1) // 第一路
  346. {
  347. U16_RMSIBC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
  348. }
  349. else if (nun == 2) // 第二路
  350. {
  351. U16_RMSIBC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
  352. }
  353. else if (nun == 3) // 第三路
  354. {
  355. U16_RMSIBC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("B通道电流转换系数:%x\n " ,U16_RMSIBC_RegData);
  356. }
  357. }
  358. Uart_Read_HLW8110_Reg(REG_RMS_UC_ADDR, 2);
  359. bsp_delay_ms(UART_SEND_TIME);
  360. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  361. {
  362. b = u8_RxBuf[0];
  363. if (nun == 1) // 第一路
  364. {
  365. U16_RMSUC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
  366. }
  367. else if (nun == 2) // 第二路
  368. {
  369. U16_RMSUC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
  370. }
  371. else if (nun == 3) // 第三路
  372. {
  373. U16_RMSUC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("电压通道转换系数:%x\n " ,U16_RMSUC_RegData);
  374. }
  375. }
  376. Uart_Read_HLW8110_Reg(REG_POWER_PAC_ADDR, 2);
  377. bsp_delay_ms(UART_SEND_TIME);
  378. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  379. {
  380. b = u8_RxBuf[0];
  381. if (nun == 1) // 第一路
  382. {
  383. U16_PowerPAC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  384. }
  385. else if (nun == 2) // 第二路
  386. {
  387. U16_PowerPAC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  388. }
  389. else if (nun == 3) // 第三路
  390. {
  391. U16_PowerPAC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("A通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  392. }
  393. }
  394. Uart_Read_HLW8110_Reg(REG_POWER_PBC_ADDR, 2);
  395. bsp_delay_ms(UART_SEND_TIME);
  396. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  397. {
  398. b = u8_RxBuf[0];
  399. if (nun == 1) // 第一路
  400. {
  401. U16_PowerPBC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  402. }
  403. else if (nun == 2) // 第二路
  404. {
  405. U16_PowerPBC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  406. }
  407. else if (nun == 3) // 第三路
  408. {
  409. U16_PowerPBC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("B通道功率转换系数:%x\n " ,U16_PowerPAC_RegData);
  410. }
  411. }
  412. Uart_Read_HLW8110_Reg(REG_POWER_SC_ADDR, 2);
  413. bsp_delay_ms(UART_SEND_TIME);
  414. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  415. {
  416. b = u8_RxBuf[0];
  417. if (nun == 1) // 第一路
  418. {
  419. U16_PowerSC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
  420. }
  421. else if (nun == 2) // 第二路
  422. {
  423. U16_PowerSC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
  424. }
  425. else if (nun == 3) // 第三路
  426. {
  427. U16_PowerSC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("视在功率转换系数:%x\n " ,U16_PowerSC_RegData);
  428. }
  429. }
  430. Uart_Read_HLW8110_Reg(REG_ENERGY_AC_ADDR, 2);
  431. bsp_delay_ms(UART_SEND_TIME);
  432. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  433. {
  434. b = u8_RxBuf[0];
  435. if (nun == 1) // 第一路
  436. {
  437. U16_EnergyAC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
  438. }
  439. else if (nun == 2) // 第二路
  440. {
  441. U16_EnergyAC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
  442. }
  443. else if (nun == 3) // 第三路
  444. {
  445. U16_EnergyAC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("A通道电量转换系数:%x\n " ,U16_EnergyAC_RegData);
  446. }
  447. }
  448. Uart_Read_HLW8110_Reg(REG_ENERGY_BC_ADDR, 2);
  449. bsp_delay_ms(UART_SEND_TIME);
  450. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  451. {
  452. b = u8_RxBuf[0];
  453. if (nun == 1) // 第一路
  454. {
  455. U16_EnergyBC_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
  456. }
  457. else if (nun == 2) // 第二路
  458. {
  459. U16_EnergyBC_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
  460. }
  461. else if (nun == 3) // 第三路
  462. {
  463. U16_EnergyBC_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("B通道电量转换系数:%x\n " ,U16_EnergyBC_RegData);
  464. }
  465. }
  466. Uart_Read_HLW8110_Reg(REG_CHECKSUM_ADDR, 2);
  467. bsp_delay_ms(UART_SEND_TIME);
  468. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  469. {
  470. b = u8_RxBuf[0];
  471. if (nun == 1) // 第一路
  472. {
  473. U16_CheckSUM_RegData[0] = (b << 8) + u8_RxBuf[1]; // printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
  474. }
  475. else if (nun == 2) // 第二路
  476. {
  477. U16_CheckSUM_RegData[1] = (b << 8) + u8_RxBuf[1]; // printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
  478. }
  479. else if (nun == 3) // 第三路
  480. {
  481. U16_CheckSUM_RegData[2] = (b << 8) + u8_RxBuf[1]; // printf("系数校验和:%x\n " ,U16_CheckSUM_RegData);
  482. }
  483. }
  484. Uart_Read_HLW8110_Reg(REG_EMUCON_ADDR, 2);
  485. bsp_delay_ms(UART_SEND_TIME);
  486. a = 0;
  487. if (nun == 1)
  488. {
  489. a = ~(0xffff + U16_RMSIAC_RegData[0] + U16_RMSIBC_RegData[0] + U16_RMSUC_RegData[0] +
  490. U16_PowerPAC_RegData[0] + U16_PowerPBC_RegData[0] + U16_PowerSC_RegData[0] +
  491. U16_EnergyAC_RegData[0] + U16_EnergyBC_RegData[0]);
  492. U16_CheckSUM_Data = a & 0xffff;
  493. // printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
  494. if (U16_CheckSUM_Data == U16_CheckSUM_RegData[0])
  495. {
  496. d = 1; // printf("校验和正确\r\n ");
  497. HLW8110_Int_Result[0] = 1;
  498. }
  499. else
  500. {
  501. d = 0; // printf("校验和出错\r\n ");
  502. HLW8110_Int_Result[0] = 0;
  503. }
  504. }
  505. else if (nun == 2)
  506. {
  507. a = ~(0xffff + U16_RMSIAC_RegData[1] + U16_RMSIBC_RegData[1] + U16_RMSUC_RegData[1] +
  508. U16_PowerPAC_RegData[1] + U16_PowerPBC_RegData[1] + U16_PowerSC_RegData[1] +
  509. U16_EnergyAC_RegData[1] + U16_EnergyBC_RegData[1]);
  510. U16_CheckSUM_Data = a & 0xffff;
  511. // printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
  512. if (U16_CheckSUM_Data == U16_CheckSUM_RegData[1])
  513. {
  514. d = 1; // printf("校验和正确\r\n ");
  515. HLW8110_Int_Result[1] = 1;
  516. }
  517. else
  518. {
  519. d = 0; // printf("校验和出错\r\n ");
  520. HLW8110_Int_Result[1] = 0;
  521. }
  522. }
  523. else if (nun == 3)
  524. {
  525. a = ~(0xffff + U16_RMSIAC_RegData[2] + U16_RMSIBC_RegData[2] + U16_RMSUC_RegData[2] +
  526. U16_PowerPAC_RegData[2] + U16_PowerPBC_RegData[2] + U16_PowerSC_RegData[2] +
  527. U16_EnergyAC_RegData[2] + U16_EnergyBC_RegData[2]);
  528. U16_CheckSUM_Data = a & 0xffff;
  529. // printf("计算系数校验和:%x\n " ,U16_CheckSUM_Data);
  530. if (U16_CheckSUM_Data == U16_CheckSUM_RegData[2])
  531. {
  532. d = 1; // printf("校验和正确\r\n ");
  533. HLW8110_Int_Result[2] = 1;
  534. }
  535. else
  536. {
  537. d = 0; // printf("校验和出错\r\n ");
  538. HLW8110_Int_Result[2] = 0;
  539. }
  540. }
  541. return d;
  542. }
  543. /*=========================================================================================================
  544. * Function : void Init_HLW8110(void)
  545. * Describe :
  546. * Input : none
  547. * Output : none
  548. * Return : none
  549. * Record : 2019/04/03
  550. ==========================================================================================================*/
  551. void Init_HLW8110(unsigned char nun)
  552. {
  553. unsigned char nun1;
  554. nun1 = nun;
  555. Uart_HLW8110_WriteREG_EN();
  556. bsp_delay_ms(UART_SEND_TIME);
  557. // 电流通道A设置命令,指定当前用于计算视在功率、功率因数、相角、瞬时有功功率、瞬时视在功率和有功功率过载的信号指示 的通道为通道A
  558. Uart_HLW8110_Set_Channel_A();
  559. bsp_delay_ms(UART_SEND_TIME);
  560. Uart_Write_HLW8110_Reg(REG_SYSCON_ADDR, 2, 0x0a04); // 开启A通道,关闭B通道,电压通道PGA = 1,电流通道PGA = 16
  561. bsp_delay_ms(UART_SEND_TIME);
  562. Uart_Write_HLW8110_Reg(REG_EMUCON_ADDR, 2, 0x0001); // 1,使能PFA 脉冲输出和有功电能寄存器累加;
  563. // Uart_Write_HLW8110_Reg(REG_EMUCON_ADDR,2,0x0018); //正向和负向过零点均发生变化,ZXD0 = 1,ZXD1 = 1
  564. Uart_Write_HLW8110_Reg(REG_EMUCON2_ADDR, 2, 0x0465); // 0x0001是EMUCON2的默认值,waveEn = 1,zxEn = 1,A通道电量寄存器,读后不清0,EPA_CB = 1;打开功率因素检测
  565. bsp_delay_ms(UART_SEND_TIME);
  566. Uart_HLW8110_WriteREG_DIS();
  567. bsp_delay_ms(UART_SEND_TIME);
  568. // 读取地址是0x6F至0x77的寄存器,验证系数是否正确
  569. Judge_CheckSum_HLW8110_Calfactor(nun1);
  570. }
  571. /*=========================================================================================================
  572. * Function : void Check_WriteReg_Success(void)
  573. * Describe : 检验写入的REG是否正确写入
  574. * Input : none
  575. * Output : none
  576. * Return : none
  577. * Record : 2020/04/02
  578. ==========================================================================================================*/
  579. void Check_WriteReg_Success(void)
  580. {
  581. unsigned int b;
  582. Uart_Read_HLW8110_Reg(REG_SYSCON_ADDR, 2);
  583. bsp_delay_ms(UART_SEND_TIME);
  584. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  585. {
  586. b = u8_RxBuf[0];
  587. U16_Check_SysconReg_Data = (b << 8) + (u8_RxBuf[1]);
  588. // printf("写入的SysconReg寄存器:%lx\n " ,U16_Check_SysconReg_Data);
  589. Temp_Read_Error = 0;
  590. }
  591. else
  592. {
  593. // printf("SysconReg寄存器读取出错\r\n");
  594. B_Read_Error = 1;
  595. Temp_Read_Error = 1;
  596. }
  597. Uart_Read_HLW8110_Reg(REG_EMUCON_ADDR, 2);
  598. bsp_delay_ms(UART_SEND_TIME);
  599. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  600. {
  601. b = u8_RxBuf[0];
  602. U16_Check_EmuconReg_Data = (b << 8) + (u8_RxBuf[1]);
  603. // printf("写入的EmuconReg寄存器:%lx\n " ,U16_Check_EmuconReg_Data);
  604. }
  605. else
  606. {
  607. // printf("EmuconReg寄存器读取出错\r\n");
  608. B_Read_Error = 1;
  609. }
  610. Uart_Read_HLW8110_Reg(REG_EMUCON2_ADDR, 2);
  611. bsp_delay_ms(UART_SEND_TIME);
  612. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  613. {
  614. b = u8_RxBuf[0];
  615. U16_Check_Emucon2Reg_Data = (b << 8) + (u8_RxBuf[1]);
  616. // printf("写入的Emucon2Reg寄存器寄存器:%lx\n " ,U16_Check_Emucon2Reg_Data);
  617. }
  618. else
  619. {
  620. // printf("Emucon2Reg寄存器读取出错\r\n");
  621. B_Read_Error = 1;
  622. }
  623. }
  624. /*=========================================================================================================
  625. * Function : void Read_HLW8112_IA(void)
  626. * Describe : 读取A通道电流
  627. * Input : none
  628. * Output : none
  629. * Return : none
  630. * Record : 2019/04/03
  631. ==========================================================================================================*/
  632. void Read_HLW8110_IA(unsigned char nun)
  633. {
  634. a_i = 0.0;
  635. b_i = 0;
  636. Uart_Read_HLW8110_Reg(REG_RMSIA_ADDR, 3);
  637. bsp_delay_ms(UART_SEND_TIME);
  638. // delay_ms(3);
  639. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  640. {
  641. b_i = u8_RxBuf[0];
  642. b_i = (b_i << 8) + u8_RxBuf[1];
  643. b_i = (b_i << 8) + u8_RxBuf[2];
  644. U32_RMSIA_RegData = b_i;
  645. // U32_RMSIA_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
  646. // printf("A通道电流寄存器:%lx\n " ,U32_RMSIA_RegData);
  647. }
  648. else
  649. {
  650. // printf("A通道电流寄存器读取出错\r\n");
  651. B_Read_Error = 1;
  652. }
  653. // A通道电流PGA = 16,电压通道PGA = 1;电流采样电阻1mR,电压采样电阻1M
  654. // 计算公式,U16_AC_I = (U32_RMSIA_RegData * U16_RMSIAC_RegData)/(电流系数* 2^23)
  655. if ((U32_RMSIA_RegData & 0x800000) == 0x800000)
  656. {
  657. if (nun == 1)
  658. {
  659. hlw8110_power_data.F_AC_I[0] = 0;
  660. }
  661. else if (nun == 2)
  662. {
  663. hlw8110_power_data.F_AC_I[1] = 0;
  664. }
  665. else if (nun == 3)
  666. {
  667. hlw8110_power_data.F_AC_I[2] = 0;
  668. }
  669. }
  670. else
  671. {
  672. a_i = (float)U32_RMSIA_RegData;
  673. if (nun == 1)
  674. {
  675. a_i = a_i * U16_RMSIAC_RegData[0];
  676. }
  677. else if (nun == 2)
  678. {
  679. a_i = a_i * U16_RMSIAC_RegData[1];
  680. }
  681. else if (nun == 3)
  682. {
  683. a_i = a_i * U16_RMSIAC_RegData[2];
  684. }
  685. // a = a * U16_RMSIAC_RegData;
  686. a_i = a_i / 0x800000; // 电流计算出来的浮点数单位是mA,比如5003.12
  687. a_i = a_i / 1; // 1 = 电流系数
  688. // a = a/1000; //a= 5003ma,a/1000 = 5.003A,单位转换成A
  689. a_i = a_i * D_CAL_A_I; // D_CAL_A_I是校正系数,默认是1
  690. // F_AC_I = a;
  691. // switchState.dp_cur_current = (unsigned long)a;//1000;//1000mA
  692. if (nun == 1)
  693. {
  694. hlw8110_power_data.F_AC_I[0] = a_i;
  695. }
  696. else if (nun == 2)
  697. {
  698. hlw8110_power_data.F_AC_I[1] = a_i;
  699. }
  700. else if (nun == 3)
  701. {
  702. hlw8110_power_data.F_AC_I[2] = a_i;
  703. }
  704. }
  705. }
  706. /*=========================================================================================================
  707. * Function : void Read_HLW8110_U(void)
  708. * Describe : 读取电压
  709. * Input : none
  710. * Output : none
  711. * Return : none
  712. * Record : 2019/04/03
  713. ==========================================================================================================*/
  714. void Read_HLW8110_U(unsigned char nun)
  715. {
  716. a_u = 0.0;
  717. b_u = 0;
  718. Uart_Read_HLW8110_Reg(REG_RMSU_ADDR, 3);
  719. bsp_delay_ms(UART_SEND_TIME);
  720. // delay_ms(3);
  721. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  722. {
  723. b_u = u8_RxBuf[0];
  724. b_u = (b_u << 8) + u8_RxBuf[1];
  725. b_u = (b_u << 8) + u8_RxBuf[2];
  726. U32_RMSU_RegData = b_u;
  727. // U32_RMSU_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
  728. // printf("电压通道寄存器:%lx\n " ,U32_RMSU_RegData);
  729. // switchState.dp_cur_voltage = 128;//(unsigned long)a;
  730. }
  731. else
  732. {
  733. // printf("电压通道寄存器读取出错\r\n");
  734. B_Read_Error = 1;
  735. }
  736. // 电压
  737. // 计算:U16_AC_V = (U32_RMSU_RegData * U16_RMSUC_RegData)/2^23
  738. if ((U32_RMSU_RegData & 0x800000) == 0x800000)
  739. {
  740. // F_AC_V = 0;
  741. hlw8110_power_data.F_AC_V = 0;
  742. }
  743. else
  744. {
  745. a_u = (float)U32_RMSU_RegData;
  746. if (nun == 1)
  747. {
  748. a_u = a_u * U16_RMSUC_RegData[0];
  749. }
  750. else if (nun == 2)
  751. {
  752. a_u = a_u * U16_RMSUC_RegData[1];
  753. }
  754. else if (nun == 3)
  755. {
  756. a_u = a_u * U16_RMSUC_RegData[2];
  757. }
  758. // a = a*U16_RMSUC_RegData;
  759. a_u = a_u / 0x400000;
  760. a_u = a_u / 0.5319; // 1 = 电压系数
  761. a_u = a_u / 100; // 计算出a = 22083.12mV,a/100表示220.8312V,电压转换成V
  762. a_u = a_u * D_CAL_U; // D_CAL_U是校正系数,默认是1,
  763. // F_AC_V = a;
  764. // switchState.dp_cur_voltage = (unsigned long)(a * 10);
  765. if (nun == 1)
  766. {
  767. hlw8110_power_data.F_AC_V = a_u;
  768. }
  769. else if (nun == 2)
  770. {
  771. hlw8110_power_data.F_AC_V = a_u;
  772. }
  773. else if (nun == 3)
  774. {
  775. hlw8110_power_data.F_AC_V = a_u;
  776. }
  777. }
  778. }
  779. /*=========================================================================================================
  780. * Function : void Read_HLW8110_PA(void)
  781. * Describe : 读取A通道功率
  782. * Input : none
  783. * Output : none
  784. * Return : none
  785. * Record : 2019/04/03
  786. ==========================================================================================================*/
  787. void Read_HLW8110_PA(unsigned char nun)
  788. {
  789. a_pa = 0.0;
  790. b_pa = 0;
  791. c_pa = 0;
  792. Uart_Read_HLW8110_Reg(REG_POWER_PA_ADDR, 4);
  793. bsp_delay_ms(UART_SEND_TIME);
  794. // delay_ms(3);
  795. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  796. {
  797. c_pa = u8_RxBuf[0];
  798. c_pa = (c_pa << 8) + u8_RxBuf[1];
  799. c_pa = (c_pa << 8) + u8_RxBuf[2];
  800. c_pa = (c_pa << 8) + u8_RxBuf[3];
  801. U32_POWERPA_RegData = c_pa;
  802. // U32_POWERPA_RegData = (unsigned long)(u8_RxBuf[0]<<24) + (unsigned long)(u8_RxBuf[1]<<16) + (unsigned long)(u8_RxBuf[2]<<8) + (unsigned long)(u8_RxBuf[3]);
  803. // printf("A通道功率寄存器:%lx\n " ,U32_POWERPA_RegData);
  804. }
  805. else
  806. {
  807. // printf("A通道功率寄存器读取出错\r\n");
  808. B_Read_Error = 1;
  809. }
  810. if (B_Read_Error == 1)
  811. {
  812. B_Read_Error = 0;
  813. Uart_Read_HLW8110_Reg(REG_POWER_PA_ADDR, 4);
  814. bsp_delay_ms(UART_SEND_TIME);
  815. // delay_ms(3);
  816. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  817. {
  818. c_pa = u8_RxBuf[0];
  819. c_pa = (c_pa << 8) + u8_RxBuf[1];
  820. c_pa = (c_pa << 8) + u8_RxBuf[2];
  821. c_pa = (c_pa << 8) + u8_RxBuf[3];
  822. U32_POWERPA_RegData = c_pa;
  823. // U32_POWERPA_RegData = (unsigned long)(u8_RxBuf[0]<<24) + (unsigned long)(u8_RxBuf[1]<<16) + (unsigned long)(u8_RxBuf[2]<<8) + (unsigned long)(u8_RxBuf[3]);
  824. // printf("A通道功率寄存器:%lx\n " ,U32_POWERPA_RegData);
  825. }
  826. else
  827. {
  828. // printf("A通道功率寄存器读取出错\r\n");
  829. B_Read_Error = 1;
  830. }
  831. }
  832. if (U32_POWERPA_RegData > 0x80000000)
  833. {
  834. b_pa = ~U32_POWERPA_RegData;
  835. a_pa = (float)b_pa;
  836. }
  837. else
  838. a_pa = (float)U32_POWERPA_RegData;
  839. // 功率需要分正功和负功
  840. // 计算,U16_AC_P = (U32_POWERPA_RegData * U16_PowerPAC_RegData)/(2^31*电压系数*电流系数)
  841. // 单位为W,比如算出来5000.123,表示5000.123W
  842. if (nun == 1)
  843. {
  844. a_pa = a_pa * U16_PowerPAC_RegData[0];
  845. }
  846. else if (nun == 2)
  847. {
  848. a_pa = a_pa * U16_PowerPAC_RegData[1];
  849. }
  850. else if (nun == 3)
  851. {
  852. a_pa = a_pa * U16_PowerPAC_RegData[2];
  853. }
  854. // a = a*U16_PowerPAC_RegData;
  855. a_pa = a_pa / 0x80000000;
  856. a_pa = a_pa / 1; // 1 = 电流系数
  857. a_pa = a_pa / 0.5319; // 1 = 电压系数
  858. a_pa = a_pa * D_CAL_A_P; // D_CAL_A_P是校正系数,默认是1
  859. // F_AC_P = a; //单位为W,比如算出来5000.123,表示5000.123W
  860. // switchState.dp_cur_power = (unsigned long)(a*10);
  861. if (nun == 1)
  862. {
  863. hlw8110_power_data.F_AC_P[0] = a_pa;
  864. }
  865. else if (nun == 2)
  866. {
  867. hlw8110_power_data.F_AC_P[1] = a_pa;
  868. }
  869. else if (nun == 3)
  870. {
  871. hlw8110_power_data.F_AC_P[2] = a_pa;
  872. }
  873. }
  874. /*=========================================================================================================
  875. * Function : void void Read_HLW8112_EA(void)
  876. * Describe : 读取A通道有功电量
  877. * Input : none
  878. * Output : none
  879. * Return : none
  880. * Record : 2019/04/03
  881. ==========================================================================================================*/
  882. void Read_HLW8110_EA(unsigned char nun)
  883. {
  884. a_ea = 0.0;
  885. b_ea = 0;
  886. Uart_Read_HLW8110_Reg(REG_ENERGY_PA_ADDR, 3);
  887. bsp_delay_ms(UART_SEND_TIME);
  888. // delay_ms(3);
  889. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  890. {
  891. b_ea = u8_RxBuf[0];
  892. b_ea = (b_ea << 8) + u8_RxBuf[1];
  893. b_ea = (b_ea << 8) + u8_RxBuf[2];
  894. U32_ENERGY_PA_RegData = b_ea;
  895. // U32_ENERGY_PA_RegData = (unsigned long)(u8_RxBuf[0]<<16) + (unsigned long)(u8_RxBuf[1]<<8) + (unsigned long)(u8_RxBuf[2]);
  896. // printf("A通道有功电量寄存器:%lx\n " ,U32_ENERGY_PA_RegData);
  897. }
  898. else
  899. {
  900. // printf("A通道有功电量寄存器读取出错\r\n");
  901. B_Read_Error = 1;
  902. }
  903. Uart_Read_HLW8110_Reg(REG_HFCONST_ADDR, 2);
  904. bsp_delay_ms(UART_SEND_TIME);
  905. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  906. {
  907. U16_HFConst_RegData = (unsigned int)(u8_RxBuf[0] << 8) + (unsigned int)(u8_RxBuf[1]);
  908. // printf("HFCONST常数 = :%d\n " ,U16_HFConst_RegData);
  909. }
  910. else
  911. {
  912. // printf("HFCONST常数寄存器读取出错\r\n");
  913. B_Read_Error = 1;
  914. }
  915. // 电量计算,电量 = (U32_ENERGY_PA_RegData * U16_EnergyAC_RegData * HFCONST) /(K1*K2 * 2^29 * 4096)
  916. // HFCONST:默认值是0x1000, HFCONST/(2^29 * 4096) = 0x20000000
  917. a_ea = (float)U32_ENERGY_PA_RegData;
  918. if (nun == 1)
  919. {
  920. a_ea = a_ea * U16_EnergyAC_RegData[0];
  921. }
  922. else if (nun == 2)
  923. {
  924. a_ea = a_ea * U16_EnergyAC_RegData[1];
  925. }
  926. else if (nun == 3)
  927. {
  928. a_ea = a_ea * U16_EnergyAC_RegData[2];
  929. }
  930. // a = a*U16_EnergyAC_RegData;
  931. a_ea = a_ea / 0x20000000; // 电量单位是0.001KWH,比如算出来是2.002,表示2.002KWH
  932. a_ea = a_ea / 1; // 1 = 电流系数
  933. a_ea = a_ea / 0.5319; // 1 = 电压系数
  934. a_ea = a_ea * D_CAL_A_E; // D_CAL_A_E是校正系数,默认是1
  935. // F_AC_E = a;
  936. // F_AC_BACKUP_E = F_AC_E;
  937. // switchState.dp_add_ele = (unsigned long)(a*100);
  938. if (nun == 1)
  939. {
  940. hlw8110_power_data.F_AC_E[0] = a_ea;
  941. }
  942. else if (nun == 2)
  943. {
  944. hlw8110_power_data.F_AC_E[1] = a_ea;
  945. }
  946. else if (nun == 3)
  947. {
  948. hlw8110_power_data.F_AC_E[2] = a_ea;
  949. }
  950. }
  951. /*=========================================================================================================
  952. * Function : void Read_HLW8110_PF(void)
  953. * Describe : 读取功率因素
  954. * Input : none
  955. * Output : none
  956. * Return : none
  957. * Record : 2019/03/18
  958. ==========================================================================================================*/
  959. void Read_HLW8110_PF(void)
  960. {
  961. // 测量A通道的功率因素,需要发送EA+5A命令
  962. // 测量B通道的功率因素,需要发送EA+A5命令
  963. b_pf = 0;
  964. a_pf = 0.0;
  965. Uart_Read_HLW8110_Reg(REG_PF_ADDR, 3);
  966. bsp_delay_ms(UART_SEND_TIME);
  967. if (u8_RxBuf[u8_RX_Length - 1] == HLW8110_checkSum_Read(u8_RX_Length))
  968. {
  969. b_pf = (unsigned long)(u8_RxBuf[0] << 16) + (unsigned long)(u8_RxBuf[1] << 8) + (unsigned long)(u8_RxBuf[2]);
  970. // printf("A通道功率因素寄存器:%ld\n " ,b);
  971. }
  972. else
  973. {
  974. // printf("读取A通道功率因素寄存器出错\r\n");
  975. B_Read_Error = 1;
  976. }
  977. if (b_pf > 0x800000) // 为负,容性负载
  978. {
  979. a_pf = (float)(0xffffff - b_pf + 1) / 0x7fffff;
  980. }
  981. else
  982. {
  983. a_pf = (float)b_pf / 0x7fffff;
  984. }
  985. if (FF_AC_P < 0.3) // 小于0.3W,空载或小功率,PF不准
  986. a_pf = 0;
  987. // 功率因素*100,最大为100,最小负100
  988. F_AC_PF = a_pf;
  989. }
  990. /*=========================================================================================================
  991. * Function : void Calculate_HLW8110_MeterData(void);
  992. * Describe :
  993. * Input : none
  994. * Output : none
  995. * Return : none
  996. * Record : 2018/05/10
  997. ==========================================================================================================*/
  998. void Calculate_HLW8110_MeterData(unsigned char nun)
  999. {
  1000. // Check_WriteReg_Success();
  1001. bsp_delay_ms(UART_SEND_TIME);
  1002. Read_HLW8110_IA(nun);
  1003. if (nun == 1) // 电压只读取第一路,三路共用
  1004. {
  1005. bsp_delay_ms(UART_SEND_TIME);
  1006. Read_HLW8110_U(nun);
  1007. }
  1008. bsp_delay_ms(UART_SEND_TIME);
  1009. Read_HLW8110_PA(nun);
  1010. bsp_delay_ms(UART_SEND_TIME);
  1011. Read_HLW8110_EA(nun);
  1012. // Read_HLW8110_LineFreq();
  1013. // Read_HLW8110_Angle();
  1014. // Read_HLW8110_PF();
  1015. }
  1016. void Read_Power_Data_handle(void)
  1017. {
  1018. int i = 0;
  1019. switch (HLW8110Msg)
  1020. {
  1021. case HLW8110_1int:
  1022. if (sTimeout(&SystemTimer, 800)) // 等待1s初始化8110
  1023. {
  1024. open_first_passageway();
  1025. bsp_delay_ms(UART_SEND_TIME);
  1026. Init_HLW8110(1);
  1027. bsp_delay_ms(UART_SEND_TIME);
  1028. // Uart_HLW8110_Reset();
  1029. if (HLW8110_Int_Result[0] == 1)
  1030. {
  1031. #ifdef ZIGBEE_ZTU_T1_SW
  1032. HLW8110Msg = HLW8110_1;
  1033. #endif
  1034. #ifdef ZIGBEE_ZTU_T3_SW
  1035. HLW8110Msg++;
  1036. #endif
  1037. #ifdef ZIGBEE_ZTU_T2_SW
  1038. HLW8110Msg++;
  1039. #endif
  1040. // HLW8110Msg = HLW8110_1;//HLW8110_IDEL; 测试用直接跳转
  1041. // 增加上电读取存储的电量数据 start
  1042. Raed_ele_data();
  1043. // 增加上电读取存储的电量数据 end
  1044. open_second_passageway(); // 第一路初始化成功以后开启第二路
  1045. }
  1046. else
  1047. {
  1048. HLW8110Msg = HLW8110_1int;
  1049. }
  1050. // HLW8110Msg = HLW8110_IDEL;
  1051. sTimeout(&SystemTimer, 0);
  1052. for (i = 0; i < 3; i++)
  1053. {
  1054. switchState.dp_add_ele[i] = 0;
  1055. switchState.dp_cur_current[i] = 0;
  1056. switchState.dp_cur_power[i] = 0;
  1057. }
  1058. switchState.dp_cur_voltage = 0;
  1059. }
  1060. break;
  1061. case HLW8110_2int:
  1062. if (sTimeout(&SystemTimer, 50)) // 等待1s初始化8110
  1063. {
  1064. bsp_delay_ms(UART_SEND_TIME);
  1065. Init_HLW8110(2);
  1066. bsp_delay_ms(UART_SEND_TIME);
  1067. if (HLW8110_Int_Result[1] == 1) // 第二路初始化成功
  1068. {
  1069. #ifdef ZIGBEE_ZTU_T3_SW
  1070. HLW8110Msg++;
  1071. open_third_passageway(); // 第二路初始化成功以后开启第三路
  1072. #endif
  1073. #ifdef ZIGBEE_ZTU_T2_SW
  1074. HLW8110Msg = HLW8110_1;
  1075. open_first_passageway();
  1076. #endif
  1077. }
  1078. else
  1079. {
  1080. HLW8110Msg = HLW8110_2int;
  1081. }
  1082. sTimeout(&SystemTimer, 0);
  1083. }
  1084. break;
  1085. case HLW8110_3int:
  1086. if (sTimeout(&SystemTimer, 50)) // 等待1s初始化8110
  1087. {
  1088. bsp_delay_ms(UART_SEND_TIME);
  1089. Init_HLW8110(3);
  1090. bsp_delay_ms(UART_SEND_TIME);
  1091. if (HLW8110_Int_Result[2] == 1) // 第三路初始化成功
  1092. {
  1093. HLW8110Msg++;
  1094. open_first_passageway(); // 第三路初始化成功以后开启第一路
  1095. }
  1096. else
  1097. {
  1098. HLW8110Msg = HLW8110_3int;
  1099. }
  1100. sTimeout(&SystemTimer, 0);
  1101. }
  1102. break;
  1103. case HLW8110_1:
  1104. if (sTimeout(&SystemTimer, 400)) // 等待5s读取第一路数据
  1105. {
  1106. Calculate_HLW8110_MeterData(1);
  1107. #ifdef ZIGBEE_ZTU_T1_SW
  1108. HLW8110Msg = HLW8110_IDEL;
  1109. #endif
  1110. #ifdef ZIGBEE_ZTU_T3_SW
  1111. HLW8110Msg++;
  1112. #endif
  1113. #ifdef ZIGBEE_ZTU_T2_SW
  1114. HLW8110Msg++;
  1115. #endif
  1116. open_second_passageway(); // 打开第二通道
  1117. // HLW8110Msg = HLW8110_IDEL; //用于测试直接跳转
  1118. sTimeout(&SystemTimer, 0);
  1119. }
  1120. break;
  1121. case HLW8110_2:
  1122. if (sTimeout(&SystemTimer, 100)) // 等待100ms读取第二路数据
  1123. {
  1124. Calculate_HLW8110_MeterData(2);
  1125. #ifdef ZIGBEE_ZTU_T3_SW
  1126. open_third_passageway(); // 打开第三通道
  1127. HLW8110Msg++;
  1128. #endif
  1129. #ifdef ZIGBEE_ZTU_T2_SW
  1130. HLW8110Msg = HLW8110_IDEL;
  1131. #endif
  1132. // HLW8110Msg = HLW8110_IDEL;
  1133. sTimeout(&SystemTimer, 0);
  1134. }
  1135. break;
  1136. case HLW8110_3:
  1137. if (sTimeout(&SystemTimer, 100)) // 等待100ms读取第三路数据
  1138. {
  1139. Calculate_HLW8110_MeterData(3);
  1140. sTimeout(&SystemTimer, 0);
  1141. HLW8110Msg++;
  1142. }
  1143. break;
  1144. case HLW8110_IDEL:
  1145. if (sTimeout(&SystemTimer, 50)) //
  1146. {
  1147. open_first_passageway(); // 打开第一通道
  1148. // open_second_passageway();
  1149. // open_third_passageway(); // 打开第三通道
  1150. // Uart_HLW8110_Reset();
  1151. // 增加发送数据给zigbee
  1152. // FF_AC_I = hlw8110_power_data.F_AC_I[0];// + hlw8110_power_data.F_AC_I[1] + hlw8110_power_data.F_AC_I[2];
  1153. // FF_AC_V = hlw8110_power_data.F_AC_V[0];// + hlw8110_power_data.F_AC_V[1] + hlw8110_power_data.F_AC_V[2];
  1154. // FF_AC_P = hlw8110_power_data.F_AC_P[0];// + hlw8110_power_data.F_AC_P[1] + hlw8110_power_data.F_AC_P[2];
  1155. // FF_AC_E = hlw8110_power_data.F_AC_E[0];// + hlw8110_power_data.F_AC_E[1] + hlw8110_power_data.F_AC_E[2];
  1156. // FF_AC_I++;// = 100.4;// 模拟测试用
  1157. // FF_AC_V++;// = 220.5;//
  1158. // FF_AC_P++;// = 320.8;//
  1159. // FF_AC_E++;// = 358.3;//
  1160. for (i = 0; i < 3; i++)
  1161. {
  1162. switchState.dp_add_ele[i] = (unsigned long)(hlw8110_power_data.F_AC_E[i] * 100); // 100*100;//100 kW·h
  1163. switchState.dp_add_ele[i] = switchState.dp_add_ele[i] + Flash_dp_add_ele[i];
  1164. switchState.dp_cur_current[i] = (unsigned long)hlw8110_power_data.F_AC_I[i]; // 1000;//1000mA
  1165. switchState.dp_cur_power[i] = (unsigned long)(hlw8110_power_data.F_AC_P[i] * 10); // 330*10;//330w
  1166. // switchState.dp_add_ele[i] = (unsigned long)(FF_AC_E *100); //100*100;//100 kW·h 模拟测试用
  1167. // switchState.dp_cur_current[i] = (unsigned long)FF_AC_I;//1000;//1000mA
  1168. // switchState.dp_cur_power[i] = (unsigned long)(FF_AC_P*10); //330*10;//330w
  1169. }
  1170. switchState.dp_cur_voltage = (unsigned long)(hlw8110_power_data.F_AC_V * 10); // 220*10;//220v
  1171. // switchState.dp_cur_voltage = (unsigned long)(FF_AC_V*10); //220*10;//220v 模拟测试用
  1172. // if(switchState.dp_add_ele[0] == 0) //如果数据丢失变为0,读取备份数据 //del by zzw 20241112
  1173. // {
  1174. // if(Flash_dp_add_ele_backups[0] != 0)
  1175. // {
  1176. // for(i = 0; i < 3; i++)
  1177. // {
  1178. // switchState.dp_add_ele[i] = Flash_dp_add_ele_backups[i];
  1179. // Flash_dp_add_ele[i] = Flash_dp_add_ele_backups[i];
  1180. // }
  1181. // Save_data_ele_flag = 1;
  1182. // }
  1183. // }
  1184. all_power_data_update(); // 数据上报
  1185. // 增加电量数据保存
  1186. if (Save_data_ele_flag)
  1187. {
  1188. for (i = 0; i < 3; i++)
  1189. {
  1190. power_data[i * 4] = ((switchState.dp_add_ele[i] >> 24) & 0xFF);
  1191. power_data[i * 4 + 1] = ((switchState.dp_add_ele[i] >> 16) & 0xFF);
  1192. power_data[i * 4 + 2] = ((switchState.dp_add_ele[i] >> 8) & 0xFF);
  1193. power_data[i * 4 + 3] = ((switchState.dp_add_ele[i]) & 0xFF);
  1194. }
  1195. user_write_INFO_byte(INFO6_ADDR, power_data, 20);
  1196. Save_data_ele_flag = 0;
  1197. if (Save_data_nun >= 86400) // 24小时
  1198. {
  1199. Save_data_nun = 0;
  1200. // Flash_dp_add_ele_backups[0] = switchState.dp_add_ele[0];
  1201. // Flash_dp_add_ele_backups[1] = switchState.dp_add_ele[1];
  1202. // Flash_dp_add_ele_backups[2] = switchState.dp_add_ele[2];
  1203. // for(i = 0; i < 3; i++)
  1204. // {
  1205. // power_data[i*4] = ((Flash_dp_add_ele_backups[i] >>24) & 0xFF);
  1206. // power_data[i*4+1] = ((Flash_dp_add_ele_backups[i] >>16) & 0xFF);
  1207. // power_data[i*4+2] = ((Flash_dp_add_ele_backups[i] >>8) & 0xFF);
  1208. // power_data[i*4+3] = ((Flash_dp_add_ele_backups[i]) & 0xFF);
  1209. // }
  1210. // user_write_INFO_byte(INFO7_ADDR, power_data, 20);
  1211. }
  1212. }
  1213. sTimeout(&SystemTimer, 0);
  1214. for (i = 0; i < 3; i++)
  1215. {
  1216. switchState.dp_add_ele[i] = 0;
  1217. switchState.dp_cur_current[i] = 0;
  1218. switchState.dp_cur_power[i] = 0;
  1219. }
  1220. switchState.dp_cur_voltage = 0;
  1221. HLW8110Msg = HLW8110_1; // 返回读取第一路数据
  1222. // HLW8110Msg = HLW8110_1int;
  1223. }
  1224. break;
  1225. case HLW8110_ERR:
  1226. HLW8110Msg++;
  1227. break;
  1228. default:
  1229. HLW8110Msg = HLW8110_ERR; // 开机初始化
  1230. break;
  1231. }
  1232. }
  1233. void Raed_ele_data(void)
  1234. {
  1235. char i;
  1236. user_read_INFO_byte(INFO6_ADDR, power_data, 20); // 读取INFO6地址存储的数据
  1237. if (power_data[3] != 0xFF) // 第一路电量数据
  1238. {
  1239. Flash_dp_add_ele[0] = power_data[0];
  1240. Flash_dp_add_ele[0] = (Flash_dp_add_ele[0] << 8) + power_data[1];
  1241. Flash_dp_add_ele[0] = (Flash_dp_add_ele[0] << 8) + power_data[2];
  1242. Flash_dp_add_ele[0] = (Flash_dp_add_ele[0] << 8) + power_data[3];
  1243. }
  1244. if (power_data[7] != 0xFF) // 第二路电量数据
  1245. {
  1246. Flash_dp_add_ele[1] = power_data[4];
  1247. Flash_dp_add_ele[1] = (Flash_dp_add_ele[1] << 8) + power_data[5];
  1248. Flash_dp_add_ele[1] = (Flash_dp_add_ele[1] << 8) + power_data[6];
  1249. Flash_dp_add_ele[1] = (Flash_dp_add_ele[1] << 8) + power_data[7];
  1250. }
  1251. if (power_data[11] != 0xFF) // 第三路电量数据
  1252. {
  1253. Flash_dp_add_ele[2] = power_data[8];
  1254. Flash_dp_add_ele[2] = (Flash_dp_add_ele[2] << 8) + power_data[9];
  1255. Flash_dp_add_ele[2] = (Flash_dp_add_ele[2] << 8) + power_data[10];
  1256. Flash_dp_add_ele[2] = (Flash_dp_add_ele[2] << 8) + power_data[11];
  1257. }
  1258. for (i = 0; i < 12; i++)
  1259. {
  1260. power_data[i] = 0;
  1261. }
  1262. // user_read_INFO_byte(INFO7_ADDR, power_data, 20); // 读取INFO6地址存储的数据
  1263. // if(power_data[3] != 0xFF) //第一路电量数据
  1264. // {
  1265. // Flash_dp_add_ele_backups[0] = power_data[0];
  1266. // Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[1];
  1267. // Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[2];
  1268. // Flash_dp_add_ele_backups[0] = (Flash_dp_add_ele_backups[0]<<8) + power_data[3];
  1269. // }
  1270. // if(power_data[7] != 0xFF) //第二路电量数据
  1271. // {
  1272. // Flash_dp_add_ele_backups[1] = power_data[4];
  1273. // Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[5];
  1274. // Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[6];
  1275. // Flash_dp_add_ele_backups[1] = (Flash_dp_add_ele_backups[1]<<8) + power_data[7];
  1276. // }
  1277. // if(power_data[11] != 0xFF) //第三路电量数据
  1278. // {
  1279. // Flash_dp_add_ele_backups[2] = power_data[8];
  1280. // Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[9];
  1281. // Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[10];
  1282. // Flash_dp_add_ele_backups[2] = (Flash_dp_add_ele_backups[2]<<8) + power_data[11];
  1283. // }
  1284. }