From 879d5ece755fd279d0593509461eb1c10446002e Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期四, 12 六月 2025 18:22:10 +0800 Subject: [PATCH] 负荷移植 --- ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunOffPowerOptimTask.java | 68 ++++++++++++++++++++++++---------- 1 files changed, 48 insertions(+), 20 deletions(-) diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunOffPowerOptimTask.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunOffPowerOptimTask.java index 59edf62..d082036 100644 --- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunOffPowerOptimTask.java +++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunOffPowerOptimTask.java @@ -1,5 +1,6 @@ package com.iailab.module.ansteel.job.task; +import com.alibaba.fastjson.JSONObject; import com.iailab.module.model.api.mcs.McsApi; import com.iailab.module.model.api.mcs.dto.ScheduleSuggestRespDTO; import com.iailab.module.model.api.mdk.MdkApi; @@ -44,29 +45,63 @@ MdkScheduleReqDTO dto = new MdkScheduleReqDTO(); dto.setScheduleTime(calendar.getTime()); dto.setScheduleCode(params); - MdkScheduleRespDTO mdkScheduleRespDTO = mdkApi.doSchedule(dto); - logger.info(params + "调度方案执行完成," + mdkScheduleRespDTO); - Map<String, Object> result = mdkScheduleRespDTO.getResult(); - for (Map.Entry<String, Object> entry : result.entrySet()) { - String key = entry.getKey(); - if (key.contains("advice") || - key.contains("off_power_up_flag") || - key.contains("cos")) { - this.saveScheduleSuggest("无功优化", key, entry.getValue(), "WGYH", calendar.getTime()); + /*MdkScheduleRespDTO mdkScheduleRespDTO = mdkApi.doSchedule(dto); + logger.info(params + "调度方案执行完成," + mdkScheduleRespDTO);*/ + // Map<String, Object> result = mdkScheduleRespDTO.getResult(); + String fakeDate = "{\n" + + "\t\"off_power_up_flag\": \"无功上网\",\n" + + "\t\"wangtie_cos_flag\": \"功率因数达标预计0.93\",\n" + + "\t\"advice1\": \"退运 钢铁变#5电容器, 容量: 20.0 MVAR, 电压等级: 220.0kV\",\n" + + "\t\"advice2\": \"退运 钢铁变#6电容器, 容量: 20.0 MVAR, 电压等级: 220.0kV\",\n" + + "\t\"advice3\": \"退运 钢铁变#8电容器, 容量: 20.0 MVAR, 电压等级: 220.0kV\",\n" + + "\t\"advice4\": \"退运 钢铁变#9电容器, 容量: 20.0 MVAR, 电压等级: 220.0kV\",\n" + + "\t\"advice5\": \"退运 钢铁变#10电容器, 容量: 20.0 MVAR, 电压等级: 220.0kV\",\n" + + "\t\"advice6\": \"投运 原料场1ER电容器, 容量: 2.7 MVAR, 电压等级: 10.0kV\",\n" + + "\t\"advice7\": \"投运 备煤筛焦综合电气室Ⅰ段电容补偿, 容量: 1.8 MVAR, 电压等级: 10.0kV\",\n" + + "\t\"advice8\": \"投运 备煤筛焦综合电气室Ⅱ段电容补偿, 容量: 1.8 MVAR, 电压等级: 10.0kV\",\n" + + "\t\"advice9\": \"投运 煤气净化综合电气室Ⅰ段电容补偿, 容量: 1.8 MVAR, 电压等级: 10.0kV\",\n" + + "\t\"advice10\": \"投运 煤气净化综合电气室Ⅱ段电容补偿, 容量: 1.8 MVAR, 电压等级: 10.0kV\",\n" + + "\t\"advice11\": \"CCPP功率因数建议:0.98\",\n" + + "\t\"advice12\": \"135机组功率因数建议:0.97\",\n" + + "\t\"advice13\": \"1#TRT功率因数建议:0.98\",\n" + + "\t\"back_wugong\": 98.96\n" + + "}"; + Map<String, Object> result = JSONObject.parseObject(fakeDate); + if (result.containsKey("off_power_up_flag")) { + this.saveScheduleSuggest("无功上网标记", "off_power_up_flag", result.get("off_power_up_flag"), "WGYH", calendar.getTime(), 0); + } + int adviceCount = 0; + for (int i = 1; i < 100; i++) { + String key = "advice" + i; + if (result.containsKey(key)) { + adviceCount ++; } } - if (mdkApi.scheduleModelOut(mdkScheduleRespDTO)) { + for (int i = 1; i < (adviceCount - 2); i++) { + String key = "advice" + i; + if (result.containsKey(key)) { + this.saveScheduleSuggest("投退建议", key, result.get(key), "WGYH", calendar.getTime(), i); + } + } + for (int i = (adviceCount - 2); i < (adviceCount + 1); i++) { + String key = "advice" + i; + if (result.containsKey(key)) { + this.saveScheduleSuggest("功率因数建议", key, result.get(key), "WGYH", calendar.getTime(), i); + } + } + + /*if (mdkApi.scheduleModelOut(mdkScheduleRespDTO)) { logger.info("调度方案结果下发成功"); } else { logger.error("调度方案结果下发失败"); - } + }*/ } catch (Exception ex) { logger.error("runOffPowerOptimTask运行异常", ex); } logger.info("runOffPowerOptimTask运行完成"); } - private void saveScheduleSuggest(String title, String key, Object content, String scheduleObj, Date scheduleTime) { + private void saveScheduleSuggest(String title, String key, Object content, String scheduleObj, Date scheduleTime, int sort) { if (content == null || StringUtils.isBlank(content.toString()) || "0".equals(content.toString())) { logger.info(title + "content为空"); return; @@ -76,14 +111,7 @@ suggest.setContent(content.toString()); suggest.setScheduleObj(scheduleObj); suggest.setScheduleTime(scheduleTime); - suggest.setSort(0); - if(key.contains("off_power_up_flag")){ - suggest.setScheduleType("off"); - }else if(key.contains("cos")) { - suggest.setScheduleType("cos"); - }else if(key.contains("advice")) { - suggest.setScheduleType("advice"); - } + suggest.setSort(sort); mcsApi.createScheduleSuggest(suggest); } } \ No newline at end of file -- Gitblit v1.9.3