Module_RatedCurrent.c 16 KB

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