Module_RatedCurrent.c 17 KB

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