Module_RatedCurrent.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  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 <sys/timeb.h>
  8. #include "Module_RatedCurrent.h"
  9. //------------------------------------------------------------------------------
  10. #define PASS (1)
  11. #define FAIL (-1)
  12. #define log_info(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  13. #define log_warn(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  14. #define log_error(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  15. //------------------------------------------------------------------------------
  16. static SymStruct modelTable[] = {
  17. { "AC", MODEL_AC },
  18. { "AW", MODEL_AW },
  19. { "AP", MODEL_AP },
  20. { "DW", MODEL_DW },
  21. { "DS", MODEL_DS },
  22. { "DM", MODEL_DM },
  23. { "DR", MODEL_DR },
  24. //{ "DM", MODEL_DM },
  25. { "DD", MODEL_DD },
  26. { "DO", MODEL_DO },
  27. };
  28. static SymStruct regulationTable[] = {
  29. {"E", REG_CE},
  30. {"U", REG_UL},
  31. {"G", REG_GB},
  32. {"C", REG_CNS},
  33. {"J", REG_JARI},
  34. {"T", REG_TR25},
  35. {"K", REG_KC},
  36. {"B", REG_B},
  37. {"Z", REG_Z},
  38. {"M", REG_M},
  39. {"P", REG_P},
  40. {"I", REG_I},
  41. {"F", REG_F},
  42. {"L", REG_L},
  43. };
  44. static SymStruct powerTable[] = {
  45. {"30", POWER_30W},
  46. {"60", POWER_60W},
  47. {"90", POWER_90W},
  48. {"12", POWER_120W},
  49. {"15", POWER_150W},
  50. {"18", POWER_180W},
  51. {"24", POWER_240W},
  52. {"36", POWER_360W},
  53. {"48", POWER_480W},
  54. {"72", POWER_720W},
  55. };
  56. static SymStruct gunTypeTable[] = {
  57. {"0", GUN_TYPE_0},
  58. {"1", GUN_TYPE_1},
  59. {"2", GUN_TYPE_2},
  60. {"3", GUN_TYPE_3},
  61. {"4", GUN_TYPE_4},
  62. {"5", GUN_TYPE_5},
  63. {"6", GUN_TYPE_6},
  64. {"7", GUN_TYPE_7},
  65. {"8", GUN_TYPE_8},
  66. {"J", GUN_TYPE_J},
  67. {"U", GUN_TYPE_U},
  68. {"V", GUN_TYPE_V},
  69. {"E", GUN_TYPE_E},
  70. {"F", GUN_TYPE_F},
  71. {"G", GUN_TYPE_G},
  72. };
  73. //------------------------------------------------------------------------------
  74. static int StoreLogMsg(const char *fmt, ...)
  75. {
  76. char Buf[4096 + 256] = {0};
  77. char buffer[4096] = {0};
  78. int rc = 0;
  79. va_list args;
  80. struct timeb SeqEndTime;
  81. struct tm *tm;
  82. va_start(args, fmt);
  83. rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  84. va_end(args);
  85. ftime(&SeqEndTime);
  86. SeqEndTime.time = time(NULL);
  87. tm = localtime(&SeqEndTime.time);
  88. //if (ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag == YES) {
  89. // sprintf(Buf, "%02d:%02d:%02d:%03d - %s",
  90. // tm->tm_hour, tm->tm_min, tm->tm_sec, SeqEndTime.millitm, buffer);
  91. // printf("%s \n", Buf);
  92. //} else {
  93. sprintf(Buf, "echo \"%04d-%02d-%02d %02d:%02d:%02d:%03d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  94. tm->tm_year + 1900,
  95. tm->tm_mon + 1,
  96. tm->tm_mday,
  97. tm->tm_hour,
  98. tm->tm_min,
  99. tm->tm_sec,
  100. SeqEndTime.millitm,
  101. buffer,
  102. tm->tm_year + 1900,
  103. tm->tm_mon + 1);
  104. system(Buf);
  105. //}
  106. return rc;
  107. }
  108. static int keyfromstring(char *key, SymStruct *table, int tableCount)
  109. {
  110. int i = 0;
  111. //int loop = sizeof(table) / sizeof(SymStruct);
  112. SymStruct *sym = NULL;
  113. for (i = 0; i < tableCount; i++) {
  114. sym = (SymStruct *)&table[i];
  115. if (strcmp(sym->key, key) == 0) {
  116. //printf("val = %x\r\n", sym->val);
  117. return sym->val;
  118. }
  119. }
  120. return BADKEY;
  121. }
  122. //------------------------------------------------------------------------------
  123. static uint16_t exchangeRatingCur(uint32_t key)
  124. {
  125. switch (key) {
  126. //60A J
  127. case DW_CE_30_J:
  128. case DM_CE_30_J:
  129. case DW_CE_30_E:
  130. case DM_CE_30_E:
  131. return RC_60A; //rating current 60A
  132. //65A U
  133. case DW_UL_30_U:
  134. case DM_UL_30_U:
  135. case DW_CNS_30_U:
  136. case DM_CNS_30_U:
  137. return RC_65A;
  138. //80A J
  139. case DW_UL_30_J:
  140. case DM_UL_30_J:
  141. case DW_CNS_30_J:
  142. case DM_CNS_30_J:
  143. //80A G
  144. case DM_CNS_30_G:
  145. case DS_UL_30_G:
  146. //80A M
  147. case DW_CE_30_M:
  148. case DM_CE_30_M:
  149. //80A N
  150. case DW_UL_30_N:
  151. case DM_UL_30_N:
  152. case DW_CNS_30_N:
  153. case DM_CNS_30_N:
  154. return RC_80A; //rating current 80A
  155. //125A J
  156. case DS_CE_60_J:
  157. case DS_CE_90_J:
  158. case DS_CE_120_J:
  159. case DS_CE_150_J:
  160. case DS_CE_180_J:
  161. case DS_UL_60_J:
  162. case DS_UL_90_J:
  163. case DS_UL_120_J:
  164. case DS_UL_150_J:
  165. case DS_UL_180_J:
  166. case DS_CNS_60_J:
  167. case DS_CNS_90_J:
  168. case DS_CNS_120_J:
  169. case DS_CNS_150_J:
  170. case DS_CNS_180_J:
  171. //125A U
  172. case DS_UL_60_U:
  173. case DS_CNS_60_U:
  174. //125A E
  175. case DS_CE_60_E:
  176. return RC_125A; //rating current 125A
  177. //200A U
  178. case DS_UL_90_U:
  179. case DS_UL_120_U:
  180. case DS_UL_150_U:
  181. case DS_UL_180_U:
  182. case DD_UL_360_U:
  183. case DS_CNS_90_U:
  184. case DS_CNS_120_U:
  185. case DS_CNS_150_U:
  186. case DS_CNS_180_U:
  187. case DD_CNS_360_U:
  188. //200A E
  189. case DS_CE_90_E:
  190. case DS_CE_120_E:
  191. case DS_CE_150_E:
  192. case DS_CE_180_E:
  193. //200A K
  194. case DS_CE_90_K:
  195. case DS_CE_120_K:
  196. case DS_CE_150_K:
  197. case DS_CE_180_K:
  198. case DD_CE_360_K:
  199. case DS_UL_90_K:
  200. case DS_UL_120_K:
  201. case DS_UL_150_K:
  202. case DS_UL_180_K:
  203. case DD_UL_360_K:
  204. return RC_200A; //rating current 200A
  205. //250A G
  206. case DS_CNS_120_G:
  207. return RC_250A;
  208. //300A T
  209. case DS_CE_90_T:
  210. case DS_CE_120_T:
  211. case DS_CE_150_T:
  212. case DS_CE_180_T:
  213. case DD_CE_360_T:
  214. case DS_UL_90_T:
  215. case DS_UL_120_T:
  216. case DS_UL_150_T:
  217. case DS_UL_180_T:
  218. case DD_UL_360_T:
  219. case DS_CNS_90_T:
  220. case DS_CNS_120_T:
  221. case DS_CNS_150_T:
  222. case DS_CNS_180_T:
  223. case DD_CNS_360_T:
  224. //300A D
  225. case DS_CE_90_D:
  226. case DS_CE_120_D:
  227. case DS_CE_150_D:
  228. case DS_CE_180_D:
  229. case DD_CE_360_D:
  230. case DS_UL_90_D:
  231. case DS_UL_120_D:
  232. case DS_UL_150_D:
  233. case DS_UL_180_D:
  234. case DD_UL_360_D:
  235. case DS_CNS_90_D:
  236. case DS_CNS_120_D:
  237. case DS_CNS_150_D:
  238. case DS_CNS_180_D:
  239. case DD_CNS_360_D:
  240. return RC_300A;
  241. //500A V
  242. case DD_UL_360_V:
  243. case DD_CNS_360_V:
  244. case DO_UL_360_V:
  245. case DO_CNS_360_V:
  246. //500A F
  247. case DD_CE_360_F:
  248. case DO_CE_360_F:
  249. //P
  250. case DD_CE_360_P:
  251. case DD_UL_360_R:
  252. case DD_CNS_360_R:
  253. return RC_500A; //rating current 500A
  254. default:
  255. return RC_0A; //rating current 200A
  256. }
  257. }
  258. static void exchangeGunTypeAndVolValue(uint8_t key, GunTypeAndVolInfo *gunAndVol)
  259. {
  260. GunTypeAndVolInfo *pGunAndVol = (GunTypeAndVolInfo *)gunAndVol;
  261. switch (key) {
  262. case GUN_TYPE_0:// : none
  263. case GUN_TYPE_1:// : IEC 62196-2 Type 1/SAE J1772 Plug
  264. case GUN_TYPE_2:// : IEC 62196-2 Type 1/SAE J1772 Socket
  265. case GUN_TYPE_3:// : IEC 62196-2 Type 2 Plug
  266. case GUN_TYPE_4:// : IEC 62196-2 Type 2 Socket
  267. case GUN_TYPE_5:// : GB/T AC Plug
  268. case GUN_TYPE_6:// : GB/T AC Socket
  269. case GUN_TYPE_7:// :CCS2 AC Plug
  270. pGunAndVol->GunType = Gun_Type_AC;
  271. pGunAndVol->GunVoltage = VOL_CHADEMO;
  272. break;
  273. case GUN_TYPE_8:// :Type E socket
  274. break;
  275. case GUN_TYPE_J:// : CHAdeMO
  276. pGunAndVol->GunType = Gun_Type_Chademo;
  277. pGunAndVol->GunVoltage = VOL_CHADEMO;
  278. break;
  279. case GUN_TYPE_U:// : Natural cooling CCS1 combo
  280. case GUN_TYPE_V:// : Liquid cooling CCS1 combo
  281. case GUN_TYPE_E:// : Natural cooling CCS2 combo
  282. case GUN_TYPE_F:// : Liquid cooling CCS2 combo
  283. pGunAndVol->GunType = Gun_Type_CCS_2;
  284. pGunAndVol->GunVoltage = VOL_CCS;
  285. break;
  286. case GUN_TYPE_G:// : GBT DC
  287. pGunAndVol->GunType = Gun_Type_GB;
  288. pGunAndVol->GunVoltage = VOL_GBT;
  289. break;
  290. }
  291. }
  292. static int exchangePowerValue(uint8_t key)
  293. {
  294. switch (key) {
  295. case POWER_30W:
  296. return 300;
  297. case POWER_60W:
  298. return 600;
  299. case POWER_90W:
  300. return 900;
  301. case POWER_120W:
  302. return 1200;
  303. case POWER_150W:
  304. return 1500;
  305. case POWER_180W:
  306. return 1800;
  307. case POWER_240W:
  308. return 2400;
  309. case POWER_360W:
  310. return 3600;
  311. case POWER_480W:
  312. return 4800;
  313. case POWER_720W:
  314. return 7200;
  315. default:
  316. return 600;
  317. break;
  318. }
  319. }
  320. /**
  321. * [RatedCurrentParsing : Parsing Rating Current]
  322. * @param pModuleName [description]
  323. * @param pDestStruct [save parameter structure array]
  324. * @param parsingCount [parameter structure array count, array 0, 1 for DC Gun, 2 for AC Gun]
  325. * @return [return -1 is module name format non match.]
  326. */
  327. int RatedCurrentParsing(char *pModuleName, void *pDestStruct)
  328. {
  329. uint8_t gunTypeIndex = 0;
  330. uint8_t modelKey = 0;
  331. uint8_t reguKey = 0;
  332. uint8_t powerKey = 0;
  333. uint8_t gunTypeKey = 0;
  334. uint16_t powerVal = 0;
  335. uint16_t ratingCurVal = 0;
  336. int i = 0;
  337. uint32_t ret = 0;
  338. char model[2] = {'\0'};
  339. char regulation[1] = {'\0'};
  340. char power[2] = {'\0'};
  341. char gunType[1] = {'\0'};
  342. ParsingRatedCur *pParsingInfo = NULL;
  343. GunRateCurInfo *pGunRateCurInfo = NULL;
  344. GunTypeAndVolInfo fGunAndVol = {0};
  345. if (pModuleName == NULL || pDestStruct == NULL) {
  346. log_error("Failed to parse source data\r\n");
  347. return FAIL;
  348. }
  349. pParsingInfo = (ParsingRatedCur *)pDestStruct;
  350. strncpy(model, &pModuleName[0], 2);
  351. model[2] = '\0';
  352. strncpy(regulation, &pModuleName[3], 1);
  353. regulation[1] = '\0';
  354. strncpy(power, &pModuleName[4], 2);
  355. power[2] = '\0';
  356. pParsingInfo->GetGunCount = 0;
  357. for (i = 0; i < sizeof(pParsingInfo->ParsingInfo) / sizeof(GunRateCurInfo); i++) {
  358. pGunRateCurInfo = (GunRateCurInfo *)&pParsingInfo->ParsingInfo[pParsingInfo->GetGunCount];
  359. if (i == 0) {
  360. gunTypeIndex = DC_ONE;
  361. } else if (i == 1) {
  362. gunTypeIndex = AC_ONE;
  363. } else if (i == 2) {
  364. gunTypeIndex = DC_SEC;
  365. }
  366. strncpy(gunType, &pModuleName[gunTypeIndex], 1);
  367. gunType[1] = '\0';
  368. modelKey = keyfromstring(&model[0], &modelTable[0], sizeof(modelTable) / sizeof(SymStruct));
  369. reguKey = keyfromstring(&regulation[0], &regulationTable[0], sizeof(regulationTable) / sizeof(SymStruct));
  370. powerKey = keyfromstring(&power[0], &powerTable[0], sizeof(powerTable) / sizeof(SymStruct));
  371. if ((gunTypeKey = keyfromstring(&gunType[0], &gunTypeTable[0], sizeof(gunTypeTable) / sizeof(SymStruct))) == GUN_TYPE_0) {
  372. log_error("The type of gun is none\r\n");
  373. continue;
  374. }
  375. ret = 0;
  376. ret = ((modelKey << 24) | (reguKey << 16) | (powerKey << 8) | gunTypeKey);
  377. ratingCurVal = exchangeRatingCur(ret);
  378. if (ratingCurVal == RC_0A) {
  379. log_error("Model name format none match\r\n");
  380. continue;
  381. //return FAIL;
  382. }
  383. memset((uint8_t *)&fGunAndVol, 0, sizeof(GunTypeAndVolInfo));
  384. exchangeGunTypeAndVolValue(gunTypeKey, &fGunAndVol);
  385. powerVal = exchangePowerValue(powerKey);
  386. pGunRateCurInfo->GunType = fGunAndVol.GunType;
  387. pGunRateCurInfo->Current = ratingCurVal;
  388. pGunRateCurInfo->Voltage = fGunAndVol.GunVoltage;
  389. pGunRateCurInfo->Power = powerVal;
  390. pParsingInfo->GetGunCount++;
  391. //log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  392. // i,
  393. // pGunRateCurInfo->GunType,
  394. // pGunRateCurInfo->Current,
  395. // pGunRateCurInfo->Voltage,
  396. // pGunRateCurInfo->Power);
  397. }
  398. return PASS;
  399. }
  400. //------------------------------------------------------------------------------
  401. //Test function
  402. //------------------------------------------------------------------------------
  403. void TestParsingRatingCurrent(void)
  404. {
  405. uint8_t i = 0;
  406. ParsingRatedCur fParsingRateCur = {0};
  407. RatedCurrentParsing("DDYC362V0UE2AD", &fParsingRateCur);
  408. log_info("Get gun = %d\r\n", fParsingRateCur.GetGunCount);
  409. for (i = 0; i < fParsingRateCur.GetGunCount; i++) {
  410. log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  411. i,
  412. fParsingRateCur.ParsingInfo[i].GunType,
  413. fParsingRateCur.ParsingInfo[i].Current,
  414. fParsingRateCur.ParsingInfo[i].Voltage,
  415. fParsingRateCur.ParsingInfo[i].Power);
  416. }
  417. //log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  418. // 0,
  419. // fGunRateCurInfo[0].GunType,
  420. // fGunRateCurInfo[0].Current,
  421. // fGunRateCurInfo[0].Voltage,
  422. // fGunRateCurInfo[0].Power);
  423. RatedCurrentParsing("DMYE301E00D2PH", &fParsingRateCur);
  424. log_info("Get gun = %d\r\n", fParsingRateCur.GetGunCount);
  425. for (i = 0; i < fParsingRateCur.GetGunCount; i++) {
  426. log_info("%d GunType = %d, Rating current = %d, Vol = %d, Power = %d\r\n",
  427. i,
  428. fParsingRateCur.ParsingInfo[i].GunType,
  429. fParsingRateCur.ParsingInfo[i].Current,
  430. fParsingRateCur.ParsingInfo[i].Voltage,
  431. fParsingRateCur.ParsingInfo[i].Power);
  432. }
  433. }