鞍钢鲅鱼圈能源管控系统后端代码
liriming
2025-06-11 8d9525154e9500069a5b2f934a0871b52cd1f15b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package com.iailab.module.ansteel.job.task;
 
import com.iailab.module.data.api.point.DataPointApi;
import com.iailab.module.data.api.point.dto.ApiPointValueDTO;
import com.iailab.module.data.api.point.dto.ApiPointValueQueryDTO;
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;
import com.iailab.module.model.api.mdk.dto.MdkScheduleReqDTO;
import com.iailab.module.model.api.mdk.dto.MdkScheduleRespDTO;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.CollectionUtils;
 
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Map;
 
/**
 * 有功优化模型
 * 30 0/1 * * * ?
 * <p>
 * 实时检测望铁1#+望铁2#有功功率,当望铁1#+望铁2#连续5分钟上网(望铁1#+望铁2#有功功率>=0)触发模型
 * M0000101267+M0000101265
 * {'status_code': 100, 'result': {'reason': '135机组发电出力增加35.43%、CCPP发电出力增加12.10%、1#LF炉处于未生产状态:建议发电减少14MW'}}
 *
 * @author PanZhibao
 * @Description
 * @createTime 2025年06月11日
 */
@Component("runOnPowerOptimTask")
public class RunOnPowerOptimTask implements ITask {
 
    private Logger logger = LoggerFactory.getLogger(getClass());
 
    @Autowired
    private DataPointApi dataPointApi;
 
    @Autowired
    private MdkApi mdkApi;
 
    @Autowired
    private McsApi mcsApi;
 
    private final static String POINT_NO = "C0000201107";
 
    @Override
    public void run(String params) {
        logger.info("RunOnPowerOptimTask定时任务正在执行,参数为:{}", params);
        try {
            Calendar calendar = Calendar.getInstance();
            calendar.set(Calendar.MILLISECOND, 0);
            calendar.set(Calendar.SECOND, 0);
            Date endTime = calendar.getTime();
            calendar.add(Calendar.MINUTE, -5);
            Date startTime = calendar.getTime();
 
            ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO();
            pointValueQueryDTO.setPointNo(POINT_NO);
            pointValueQueryDTO.setStart(startTime);
            pointValueQueryDTO.setEnd(endTime);
            List<ApiPointValueDTO> valueList = dataPointApi.queryPointHistoryValue(pointValueQueryDTO);
            boolean flag = true;
            if (CollectionUtils.isEmpty(valueList)) {
                flag = false;
            }
            for (ApiPointValueDTO apiPointValueDTO : valueList) {
                if (apiPointValueDTO.getV() < 0) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                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();
                    this.saveScheduleSuggest("有功优化", entry.getValue(), "YGYH", calendar.getTime());
                }
            }
 
        } catch (Exception ex) {
            logger.error("RunOnPowerOptimTask运行异常", ex);
        }
        logger.info("RunOnPowerOptimTask运行完成");
    }
 
    private void saveScheduleSuggest(String title, Object content, String scheduleObj, Date scheduleTime) {
        if (content == null || StringUtils.isBlank(content.toString()) || "0".equals(content.toString())) {
            logger.info(title + "content为空");
            return;
        }
        ScheduleSuggestRespDTO suggest = new ScheduleSuggestRespDTO();
        suggest.setTitle(title);
        suggest.setContent(content.toString());
        suggest.setScheduleObj(scheduleObj);
        suggest.setScheduleTime(scheduleTime);
        suggest.setSort(0);
        mcsApi.createScheduleSuggest(suggest);
    }
}