HLW8110.c 39 KB

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