Module_RatedCurrent.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <stdint.h>
  4. #include <string.h>
  5. #include <stdarg.h>
  6. #include <time.h>
  7. #include <math.h>
  8. #include <sys/timeb.h>
  9. #include "Module_RatedCurrent.h"
  10. //------------------------------------------------------------------------------
  11. //------------------------------------------------------------------------------
  12. #define PASS (1)
  13. #define FAIL (-1)
  14. #define log_info(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  15. #define log_warn(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  16. #define log_error(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  17. //------------------------------------------------------------------------------
  18. static SymStruct modelTable[] = {
  19. { "AC", MODEL_AC },
  20. { "AW", MODEL_AW },
  21. { "AP", MODEL_AP },
  22. { "AX", MODEL_AX },
  23. { "DW", MODEL_DW },
  24. { "DS", MODEL_DS },
  25. { "DM", MODEL_DM },
  26. { "DR", MODEL_DR },
  27. //{ "DM", MODEL_DM },
  28. { "DD", MODEL_DD },
  29. { "DO", MODEL_DO },
  30. { "DQ", MODEL_DQ },
  31. { "DK", MODEL_DK },
  32. { "DX", MODEL_DX },
  33. };
  34. static SymStruct regulationTable[] = {
  35. {"E", REG_CE},
  36. {"U", REG_UL},
  37. {"G", REG_GB},
  38. {"C", REG_CNS},
  39. {"J", REG_JARI},
  40. {"T", REG_TR25},
  41. {"K", REG_KC},
  42. {"B", REG_B},
  43. {"Z", REG_Z},
  44. {"M", REG_M},
  45. {"P", REG_P},
  46. {"I", REG_I},
  47. {"F", REG_F},
  48. {"L", REG_L},
  49. };
  50. static SymStruct powerTable[] = {
  51. {"301", POWER_30W},
  52. {"601", POWER_60W},
  53. {"801", POWER_80W},
  54. {"901", POWER_90W},
  55. {"122", POWER_120W},
  56. {"152", POWER_150W},
  57. {"162", POWER_160W},
  58. {"182", POWER_180W},
  59. {"212", POWER_210W},
  60. {"242", POWER_240W},
  61. {"272", POWER_270W},
  62. {"302", POWER_300W},
  63. {"332", POWER_330W},
  64. {"362", POWER_360W},
  65. {"482", POWER_480W},
  66. {"722", POWER_720W},
  67. };
  68. static SymStruct gunTypeTable[] = {
  69. {"0", GUN_TYPE_0},
  70. {"1", GUN_TYPE_1},
  71. {"2", GUN_TYPE_2},
  72. {"3", GUN_TYPE_3},
  73. {"4", GUN_TYPE_4},
  74. {"5", GUN_TYPE_5},
  75. {"6", GUN_TYPE_6},
  76. {"7", GUN_TYPE_7},
  77. {"8", GUN_TYPE_8},
  78. {"J", GUN_TYPE_J},
  79. {"U", GUN_TYPE_U},
  80. {"V", GUN_TYPE_V},
  81. {"E", GUN_TYPE_E},
  82. {"F", GUN_TYPE_F},
  83. {"G", GUN_TYPE_G},
  84. {"T", GUN_TYPE_T},
  85. {"D", GUN_TYPE_D},
  86. {"K", GUN_TYPE_K},
  87. {"M", GUN_TYPE_M},
  88. {"N", GUN_TYPE_N},
  89. {"P", GUN_TYPE_P},
  90. {"R", GUN_TYPE_R},
  91. {"C", GUN_TYPE_C},
  92. {"W", GUN_TYPE_W},
  93. {"B", GUN_TYPE_B},
  94. {"H", GUN_TYPE_H},
  95. {"A", GUN_TYPE_A},
  96. };
  97. //------------------------------------------------------------------------------
  98. static int StoreLogMsg(const char *fmt, ...)
  99. {
  100. char Buf[4096 + 256] = {0};
  101. char buffer[4096] = {0};
  102. int rc = 0;
  103. va_list args;
  104. struct timeb SeqEndTime;
  105. struct tm *tm;
  106. va_start(args, fmt);
  107. rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  108. va_end(args);
  109. ftime(&SeqEndTime);
  110. SeqEndTime.time = time(NULL);
  111. tm = localtime(&SeqEndTime.time);
  112. //if (ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag == YES) {
  113. // sprintf(Buf, "%02d:%02d:%02d:%03d - %s",
  114. // tm->tm_hour, tm->tm_min, tm->tm_sec, SeqEndTime.millitm, buffer);
  115. // printf("%s \n", Buf);
  116. //} else {
  117. sprintf(Buf, "echo \"%04d-%02d-%02d %02d:%02d:%02d:%03d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  118. tm->tm_year + 1900,
  119. tm->tm_mon + 1,
  120. tm->tm_mday,
  121. tm->tm_hour,
  122. tm->tm_min,
  123. tm->tm_sec,
  124. SeqEndTime.millitm,
  125. buffer,
  126. tm->tm_year + 1900,
  127. tm->tm_mon + 1);
  128. system(Buf);
  129. //}
  130. return rc;
  131. }
  132. static int keyfromstring(char *key, SymStruct *table, int tableCount)
  133. {
  134. int i = 0;
  135. //int loop = sizeof(table) / sizeof(SymStruct);
  136. SymStruct *sym = NULL;
  137. for (i = 0; i < tableCount; i++) {
  138. sym = (SymStruct *)&table[i];
  139. if (strcmp(sym->key, key) == 0) {
  140. //printf("val = %x\r\n", sym->val);
  141. return sym->val;
  142. }
  143. }
  144. return BADKEY;
  145. }
  146. //------------------------------------------------------------------------------
  147. static uint16_t defaultRatedCurrent(uint8_t modelType, uint32_t gunType, int powerKey)
  148. {
  149. uint16_t ret = RC_0A;
  150. if (powerKey == BADKEY)
  151. {
  152. powerKey = POWER_30W;
  153. if (modelType == MODEL_DD || modelType == MODEL_DX)
  154. {
  155. powerKey = POWER_360W;
  156. }
  157. }
  158. switch (gunType) {
  159. case GUN_TYPE_J:
  160. if(powerKey == POWER_30W)
  161. ret = RC_60A;
  162. else if(powerKey >= POWER_60W)
  163. ret = RC_120A;
  164. break;
  165. case GUN_TYPE_U:
  166. case GUN_TYPE_E:
  167. if(powerKey == POWER_30W)
  168. ret = RC_60A;
  169. else if(powerKey == POWER_60W)
  170. ret = RC_120A;
  171. else if(powerKey > POWER_60W)
  172. ret = RC_200A;
  173. break;
  174. case GUN_TYPE_G:
  175. case GUN_TYPE_B:
  176. if(powerKey == POWER_30W)
  177. ret = RC_60A;
  178. else if(powerKey == POWER_60W)
  179. ret = RC_120A;
  180. else if(powerKey > POWER_60W)
  181. ret = RC_250A;
  182. break;
  183. case GUN_TYPE_M:
  184. case GUN_TYPE_N:
  185. if(powerKey == POWER_30W)
  186. ret = RC_80A;
  187. else if(powerKey == POWER_60W)
  188. ret = RC_120A;
  189. else if(powerKey > POWER_60W)
  190. ret = RC_200A;
  191. break;
  192. case GUN_TYPE_K:
  193. ret = RC_200A;
  194. break;
  195. case GUN_TYPE_V:
  196. case GUN_TYPE_F:
  197. case GUN_TYPE_P:
  198. case GUN_TYPE_R:
  199. ret = RC_500A;
  200. break;
  201. case GUN_TYPE_T:
  202. case GUN_TYPE_D:
  203. ret = RC_300A;
  204. break;
  205. case GUN_TYPE_H:
  206. ret = RC_500A;
  207. break;
  208. case GUN_TYPE_A:
  209. ret = RC_400A;
  210. break;
  211. case GUN_TYPE_0:
  212. ret = RC_0A;
  213. break;
  214. case GUN_TYPE_1:
  215. case GUN_TYPE_2:
  216. case GUN_TYPE_3:
  217. case GUN_TYPE_4:
  218. case GUN_TYPE_5:
  219. case GUN_TYPE_6:
  220. case GUN_TYPE_7:
  221. case GUN_TYPE_8:
  222. default:
  223. log_error("The gun type is not on the default current table\r\n");
  224. return RC_0A;
  225. break;
  226. }
  227. return ret;
  228. }
  229. static uint16_t exchangeRatingCur(uint32_t key)
  230. {
  231. switch (key) {
  232. //60A J
  233. case DW_CE_30_J:
  234. case DM_CE_30_J:
  235. case DW_CE_30_E:
  236. case DM_CE_30_E:
  237. //60A U
  238. case DW_UL_30_U:
  239. case DM_UL_30_U:
  240. case DW_CNS_30_U:
  241. case DM_CNS_30_U:
  242. //60A J
  243. case DW_UL_30_J:
  244. case DM_UL_30_J:
  245. case DW_CNS_30_J:
  246. case DM_CNS_30_J:
  247. //60A G
  248. case DM_CNS_30_G:
  249. case DS_UL_30_G:
  250. return RC_60A; //rating current 60A
  251. //80A M
  252. case DW_CE_30_M:
  253. case DM_CE_30_M:
  254. //80A N
  255. case DW_UL_30_N:
  256. case DM_UL_30_N:
  257. case DW_CNS_30_N:
  258. case DM_CNS_30_N:
  259. return RC_80A; //rating current 80A
  260. //120A J
  261. case DS_CE_60_J:
  262. case DS_CE_90_J:
  263. case DS_CE_120_J:
  264. case DS_CE_150_J:
  265. case DS_CE_180_J:
  266. case DS_UL_60_J:
  267. case DS_UL_90_J:
  268. case DS_UL_120_J:
  269. case DS_UL_150_J:
  270. case DS_UL_180_J:
  271. case DS_CNS_60_J:
  272. case DS_CNS_90_J:
  273. case DS_CNS_120_J:
  274. case DS_CNS_150_J:
  275. case DS_CNS_180_J:
  276. //120A U
  277. case DS_UL_60_U:
  278. case DS_CNS_60_U:
  279. //120A E
  280. case DS_CE_60_E:
  281. return RC_120A; //rating current 120A
  282. //200A U
  283. case DD_CE_180_U:
  284. case DD_CE_360_U:
  285. case DS_UL_90_U:
  286. case DS_UL_120_U:
  287. case DS_UL_150_U:
  288. case DS_UL_180_U:
  289. case DD_UL_360_U:
  290. case DS_CNS_90_U:
  291. case DS_CNS_120_U:
  292. case DS_CNS_150_U:
  293. case DS_CNS_180_U:
  294. case DD_CNS_180_U:
  295. case DD_CNS_360_U:
  296. //200A E
  297. case DS_CE_90_E:
  298. case DS_CE_120_E:
  299. case DS_CE_150_E:
  300. case DS_CE_180_E:
  301. //200A K
  302. case DS_CE_90_K:
  303. case DS_CE_120_K:
  304. case DS_CE_150_K:
  305. case DS_CE_180_K:
  306. case DD_CE_180_K:
  307. case DD_CE_360_K:
  308. case DS_UL_90_K:
  309. case DS_UL_120_K:
  310. case DS_UL_150_K:
  311. case DS_UL_180_K:
  312. case DD_UL_180_K:
  313. case DD_UL_360_K:
  314. return RC_200A; //rating current 200A
  315. //250A G
  316. case DS_CNS_120_G:
  317. return RC_250A;
  318. //300A T
  319. case DS_CE_90_T:
  320. case DS_CE_120_T:
  321. case DS_CE_150_T:
  322. case DS_CE_180_T:
  323. case DD_CE_180_T:
  324. case DD_CE_360_T:
  325. case DS_UL_90_T:
  326. case DS_UL_120_T:
  327. case DS_UL_150_T:
  328. case DS_UL_180_T:
  329. case DD_UL_180_T:
  330. case DD_UL_360_T:
  331. case DS_CNS_90_T:
  332. case DS_CNS_120_T:
  333. case DS_CNS_150_T:
  334. case DS_CNS_180_T:
  335. case DD_CNS_180_T:
  336. case DD_CNS_360_T:
  337. //300A D
  338. case DS_CE_90_D:
  339. case DS_CE_120_D:
  340. case DS_CE_150_D:
  341. case DS_CE_180_D:
  342. case DD_CE_180_D:
  343. case DD_CE_360_D:
  344. case DS_UL_90_D:
  345. case DS_UL_120_D:
  346. case DS_UL_150_D:
  347. case DS_UL_180_D:
  348. case DD_UL_180_D:
  349. case DD_UL_360_D:
  350. case DS_CNS_90_D:
  351. case DS_CNS_120_D:
  352. case DS_CNS_150_D:
  353. case DS_CNS_180_D:
  354. case DD_CNS_180_D:
  355. case DD_CNS_360_D:
  356. return RC_300A;
  357. //500A V
  358. case DD_CE_180_V:
  359. case DD_UL_180_V:
  360. case DD_CNS_180_V:
  361. case DD_CE_360_V:
  362. case DD_UL_360_V:
  363. case DD_CNS_360_V:
  364. case DO_CE_180_V:
  365. case DO_UL_180_V:
  366. case DO_CNS_180_V:
  367. case DO_CE_360_V:
  368. case DO_UL_360_V:
  369. case DO_CNS_360_V:
  370. //500A F
  371. case DD_CE_360_F:
  372. case DO_CE_360_F:
  373. //P
  374. case DD_CE_360_P:
  375. case DD_UL_360_R:
  376. case DD_CNS_360_R:
  377. return RC_500A; //rating current 500A
  378. default:
  379. return RC_0A; //rating current 200A
  380. }
  381. }
  382. static void exchangeGunTypeAndVolValue(uint8_t key, GunTypeAndVolInfo *gunAndVol)
  383. {
  384. GunTypeAndVolInfo *pGunAndVol = (GunTypeAndVolInfo *)gunAndVol;
  385. switch (key) {
  386. case GUN_TYPE_0:// : none
  387. case GUN_TYPE_1:// : IEC 62196-2 Type 1/SAE J1772 Plug
  388. case GUN_TYPE_2:// : IEC 62196-2 Type 1/SAE J1772 Socket
  389. case GUN_TYPE_3:// : IEC 62196-2 Type 2 Plug
  390. case GUN_TYPE_4:// : IEC 62196-2 Type 2 Socket
  391. case GUN_TYPE_5:// : GB/T AC Plug
  392. case GUN_TYPE_6:// : GB/T AC Socket
  393. case GUN_TYPE_7:// :CCS2 AC Plug
  394. case GUN_TYPE_8:// :Type E socket
  395. pGunAndVol->GunType = Gun_Type_AC;
  396. pGunAndVol->GunVoltage = VOL_CHADEMO;
  397. break;
  398. case GUN_TYPE_J:// : CHAdeMO
  399. case GUN_TYPE_K:
  400. pGunAndVol->GunType = Gun_Type_Chademo;
  401. pGunAndVol->GunVoltage = VOL_CHADEMO;
  402. break;
  403. case GUN_TYPE_U:// : Natural cooling CCS1 combo
  404. case GUN_TYPE_E:// : Natural cooling CCS2 combo
  405. case GUN_TYPE_V:// : Liquid cooling CCS1 combo
  406. case GUN_TYPE_F:// : Liquid cooling CCS2 combo
  407. case GUN_TYPE_T:// : Rema CCS1 300A
  408. case GUN_TYPE_D:// : Rema CCS2 300A
  409. case GUN_TYPE_M:// : CCS2 80A
  410. case GUN_TYPE_N:// : CCS1 80A
  411. case GUN_TYPE_P:// : Phoenix CCS2 500A 水冷
  412. case GUN_TYPE_R:// : Phoenix CCS1 500A 水冷
  413. pGunAndVol->GunType = Gun_Type_CCS_2;
  414. pGunAndVol->GunVoltage = VOL_CCS;
  415. break;
  416. case GUN_TYPE_G:// : GBT DC
  417. case GUN_TYPE_B:// : GBT YG PT1000
  418. case GUN_TYPE_H:// : WOER GBT 500A
  419. case GUN_TYPE_A:// : WOER GBT 400A
  420. pGunAndVol->GunType = Gun_Type_GB;
  421. pGunAndVol->GunVoltage = VOL_GBT;
  422. break;
  423. }
  424. }
  425. static int exchangePowerValue(uint8_t key)
  426. {
  427. switch (key) {
  428. case POWER_30W:
  429. return 300;
  430. case POWER_60W:
  431. return 600;
  432. case POWER_80W:
  433. return 800;
  434. case POWER_90W:
  435. return 900;
  436. case POWER_120W:
  437. return 1200;
  438. case POWER_150W:
  439. return 1500;
  440. case POWER_160W:
  441. return 1600;
  442. case POWER_180W:
  443. return 1800;
  444. case POWER_210W:
  445. return 2100;
  446. case POWER_240W:
  447. return 2400;
  448. case POWER_270W:
  449. return 2700;
  450. case POWER_300W:
  451. return 3000;
  452. case POWER_330W:
  453. return 3300;
  454. case POWER_360W:
  455. return 3600;
  456. case POWER_480W:
  457. return 4800;
  458. case POWER_720W:
  459. return 7200;
  460. default:
  461. log_error("Power is not defined, return 30kw\r\n");
  462. return 300;
  463. break;
  464. }
  465. }
  466. /**
  467. * [RatedCurrentParsing : Parsing Rating Current]
  468. * @param pModuleName [description]
  469. * @param pDestStruct [save parameter structure array]
  470. * @param parsingCount [parameter structure array count, array 0, 1 for DC Gun, 2 for AC Gun]
  471. * @return [return -1 is module name format non match.]
  472. */
  473. int RatedCurrentParsing(char *pModuleName, void *pDestStruct)
  474. {
  475. uint8_t gunTypeIndex = 0;
  476. uint8_t modelKey = 0;
  477. int reguKey = 0;
  478. int powerKey = 0;
  479. int gunTypeKey = 0;
  480. uint16_t ratingCurVal = 0;
  481. int i = 0;
  482. uint32_t ret = 0;
  483. char model[3] = {'\0'};
  484. char regulation[2] = {'\0'};
  485. char power[4] = {'\0'};
  486. char gunType[2] = {'\0'};
  487. ParsingRatedCur *pParsingInfo = NULL;
  488. RateCurInfo *pGunRateCurInfo = NULL;
  489. GunTypeAndVolInfo fGunAndVol = {0};
  490. if (pModuleName == NULL || (strlen(pModuleName) <= 0) || pDestStruct == NULL) {
  491. log_error("Failed to parse source\r\n");
  492. return FAIL;
  493. }
  494. pParsingInfo = (ParsingRatedCur *)pDestStruct;
  495. strncpy(model, &pModuleName[0], 2);
  496. model[2] = '\0';
  497. strncpy(regulation, &pModuleName[3], 1);
  498. regulation[1] = '\0';
  499. strncpy(power, &pModuleName[4], 3);
  500. power[3] = '\0';
  501. //get max power value
  502. powerKey = keyfromstring(&power[0], &powerTable[0], sizeof(powerTable) / sizeof(SymStruct));
  503. pParsingInfo->Power = exchangePowerValue(powerKey);
  504. pParsingInfo->GetGunCount = 0;
  505. for (i = 0; i < sizeof(pParsingInfo->ParsingInfo) / sizeof(RateCurInfo); i++) {
  506. pGunRateCurInfo = (RateCurInfo *)&pParsingInfo->ParsingInfo[pParsingInfo->GetGunCount];
  507. if(pModuleName[8]=='0')
  508. {
  509. if (i == 0) {
  510. gunTypeIndex = DC_ONE;
  511. } else if (i == 1) {
  512. gunTypeIndex = DC_SEC;
  513. } else if (i == 2) {
  514. gunTypeIndex = AC_ONE;
  515. }
  516. }
  517. else
  518. {
  519. if (i == 0) {
  520. gunTypeIndex = DC_ONE;
  521. } else if (i == 1) {
  522. gunTypeIndex = AC_ONE;
  523. } else if (i == 2) {
  524. gunTypeIndex = DC_SEC;
  525. }
  526. }
  527. strncpy(gunType, &pModuleName[gunTypeIndex], 1);
  528. gunType[1] = '\0';
  529. modelKey = keyfromstring(&model[0], &modelTable[0], sizeof(modelTable) / sizeof(SymStruct));
  530. reguKey = keyfromstring(&regulation[0], &regulationTable[0], sizeof(regulationTable) / sizeof(SymStruct));
  531. if ((gunTypeKey = keyfromstring(&gunType[0], &gunTypeTable[0], sizeof(gunTypeTable) / sizeof(SymStruct))) == GUN_TYPE_0) {
  532. //log_error("Rated Current Parsing the type of gun is none\r\n");
  533. continue;
  534. //return FAIL;
  535. }
  536. ret = 0;
  537. ret = ((modelKey << 24) | (reguKey << 16) | (powerKey << 8) | gunTypeKey);
  538. ratingCurVal = exchangeRatingCur(ret);
  539. if (ratingCurVal == RC_0A) {
  540. ratingCurVal = defaultRatedCurrent(modelKey, gunTypeKey, powerKey);
  541. }
  542. memset((uint8_t *)&fGunAndVol, 0, sizeof(GunTypeAndVolInfo));
  543. exchangeGunTypeAndVolValue(gunTypeKey, &fGunAndVol);
  544. pGunRateCurInfo->GunType = fGunAndVol.GunType;
  545. pGunRateCurInfo->Current = ratingCurVal;
  546. pGunRateCurInfo->Voltage = fGunAndVol.GunVoltage;
  547. pParsingInfo->GetGunCount++;
  548. //log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  549. // i,
  550. // pGunRateCurInfo->GunType,
  551. // pGunRateCurInfo->Current,
  552. // pGunRateCurInfo->Voltage,
  553. // pGunRateCurInfo->Power);
  554. }
  555. // Rated power convert
  556. pParsingInfo->ratedPower = (((pModuleName[4]-0x30)*10)+((pModuleName[5]-0x30)*1))*pow(10, (pModuleName[6]-0x30)-1)*1000;
  557. return PASS;
  558. }
  559. //------------------------------------------------------------------------------
  560. //Test function
  561. //------------------------------------------------------------------------------
  562. void TestParsingRatingCurrent(void)
  563. {
  564. uint8_t i = 0;
  565. ParsingRatedCur fParsingRateCur = {0};
  566. RatedCurrentParsing("DDYC362V0UE2AD", &fParsingRateCur);
  567. log_info("Get gun = %d\r\n", fParsingRateCur.GetGunCount);
  568. for (i = 0; i < fParsingRateCur.GetGunCount; i++) {
  569. log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d, Rated power: %d\r\n",
  570. i,
  571. fParsingRateCur.ParsingInfo[i].GunType,
  572. fParsingRateCur.ParsingInfo[i].Current,
  573. fParsingRateCur.ParsingInfo[i].Voltage,
  574. fParsingRateCur.Power,
  575. fParsingRateCur.ratedPower);
  576. }
  577. //log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  578. // 0,
  579. // fGunRateCurInfo[0].GunType,
  580. // fGunRateCurInfo[0].Current,
  581. // fGunRateCurInfo[0].Voltage,
  582. // fGunRateCurInfo[0].Power);
  583. RatedCurrentParsing("DMYE301E00D2PH", &fParsingRateCur);
  584. log_info("Get gun = %d\r\n", fParsingRateCur.GetGunCount);
  585. for (i = 0; i < fParsingRateCur.GetGunCount; i++) {
  586. log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  587. i,
  588. fParsingRateCur.ParsingInfo[i].GunType,
  589. fParsingRateCur.ParsingInfo[i].Current,
  590. fParsingRateCur.ParsingInfo[i].Voltage,
  591. fParsingRateCur.Power);
  592. }
  593. }