沙钢智慧能源系统后端代码
liriming
2 天以前 b7faef853481a67187a781b7084ad1c2d4a5b691
发电厂机组运行情况
已添加1个文件
134 ■■■■■ 文件已修改
shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunMachineStateTask.java 134 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunMachineStateTask.java
对比新文件
@@ -0,0 +1,134 @@
package com.iailab.module.shasteel.job.task;
import com.iailab.module.data.api.point.DataPointApi;
import com.iailab.module.data.api.point.dto.ApiPointValueWriteDTO;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.math.BigDecimal;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
 * @description: 发电厂机组运行情况
 * @author: lirm
 * @date: 2025/4/14
 **/
@Component("runMachineStateTask")
public class RunMachineStateTask implements ITask {
    private Logger logger = LoggerFactory.getLogger(getClass());
    @Autowired
    private DataPointApi dataPointApi;
    private static final HashMap<String, List<String>> partPoints = new HashMap<String, List<String>>() {{
        put("F0000101185", Arrays.asList("F0000100098", "F0000100099", "F0000100100", "F0000100101"));
        put("F0000101186", Arrays.asList("F0000100109", "F0000100110", "F0000100111", "F0000100112"));
        put("F0000101187", Arrays.asList("M0000100009", "M0000100023", "M0000100026", "M0000100029"));
        put("F0000101189", Arrays.asList("M0000100010", "M0000100024", "M0000100027", "M0000100030"));
        put("F0000101190", Arrays.asList("C0000101199", "C0000101200", "C0000101201", "C0000101202"));
        put("F0000101191", Arrays.asList("M0000100854", "M0000100855", "M0000100856", "M0000100857"));
        put("F0000101192", Arrays.asList("C0000101242", "C0000101243", "C0000101244", "C0000101245"));
        put("F0000101193", Arrays.asList("C0000101223", "C0000101224", "C0000101225", "C0000101226"));
        put("F0000101194", Arrays.asList("C0000101210", "C0000101211", "C0000101212", "C0000101213"));
        put("F0000101195", Arrays.asList("C0000101214", "C0000101215", "C0000101216", "C0000101217"));
        put("F0000101196", Arrays.asList("F0000100105", "F0000100106", "F0000100107", "F0000100108"));
        put("F0000101197", Arrays.asList("F0000100116", "F0000100117", "F0000100118", "F0000100119"));
        put("F0000101198", Arrays.asList("M0000100032", "M0000100035", "M0000100038", "M0000100041"));
        put("F0000101201", Arrays.asList("C0000101203", "C0000101204", "C0000101205", "C0000101206"));
        put("F0000101204", Arrays.asList("C0000101227", "C0000101228", "C0000101229", "C0000101230"));
        put("F0000101207", Arrays.asList("F0000100102", "F0000100103"));
        put("F0000101208", Arrays.asList("F0000100113", "F0000100114"));
        put("F0000101209", Arrays.asList("C0000101114", "C0000101115"));
        put("F0000101210", Arrays.asList("C0000101116", "C0000101117"));
        put("F0000101211", Arrays.asList("M0000101043", "M0000101039"));
        put("F0000101212", Arrays.asList("C0000101207", "C0000101208"));
        put("F0000101213", Arrays.asList("C0000101116", "C0000101117"));
        put("F0000101214", Arrays.asList("C0000101240", "C0000101241"));
        put("F0000101215", Arrays.asList("C0000101231", "C0000101232"));
        put("F0000101216", Arrays.asList("C0000101221", "C0000101222"));
        put("F0000101217", Arrays.asList("C0000101218", "C0000101219"));
    }};
    private static final HashMap<String, List<String>> sumPoints = new HashMap<String, List<String>>() {{
        put("F0000101218", Arrays.asList("F0000101185", "F0000101196", "F0000101207", "F0000100104"));
        put("F0000101219", Arrays.asList("F0000101186", "F0000101197", "F0000101208", "F0000100115"));
        put("F0000101220", Arrays.asList("F0000101187", "F0000101198", "F0000101209", "M0000100013"));
        put("F0000101221", Arrays.asList("F0000101188", "F0000101199", "F0000101210"));
        put("F0000101222", Arrays.asList("F0000101189", "F0000101200", "F0000101211", "M0000100014"));
        put("F0000101223", Arrays.asList("F0000101190", "F0000101201", "F0000101212", "C0000101209"));
        put("F0000101224", Arrays.asList("F0000101191", "F0000101202", "F0000101213", "M0000101003"));
        put("F0000101225", Arrays.asList("F0000101192", "F0000101203", "F0000101214", "C0000101239"));
        put("F0000101226", Arrays.asList("F0000101193", "F0000101204", "F0000101215", "C0000101233"));
        put("F0000101227", Arrays.asList("F0000101194", "F0000101205", "F0000101216"));
        put("F0000101228", Arrays.asList("F0000101195", "F0000101206", "F0000101217", "C0000101220"));
    }};
    @Override
    public void run(String params) {
        logger.info("RunMachineStateTask定时任务正在执行,参数为:{}", params);
        try {
            List<String> partPointNos = partPoints.values().stream().flatMap(List::stream).collect(Collectors.toList());
            Map<String, Object> partPointsRealValue = dataPointApi.queryPointsRealValue(partPointNos);
            for (Map.Entry<String, List<String>> entry : partPoints.entrySet()) {
                ApiPointValueWriteDTO writeDTO = new ApiPointValueWriteDTO();
                double dataValue = 0d;
                int count = 0;
                for (String pointNo : entry.getValue()) {
                    Double value = Double.valueOf(String.format("%.2f", Double.valueOf(partPointsRealValue.get(pointNo).toString())));
                    if (value > 0) {
                        dataValue += value;
                        count++;
                    }
                }
                if ("F0000101185".equals(entry.getKey()) || "F0000101186".equals(entry.getKey())
                        || "F0000101196".equals(entry.getKey()) || "F0000101197".equals(entry.getKey())
                        || "F0000101207".equals(entry.getKey()) || "F0000101208".equals(entry.getKey())) {
                    writeDTO.setPointNo(entry.getKey());
                    BigDecimal value = count == 0 ? BigDecimal.ZERO : new BigDecimal(dataValue).divide(new BigDecimal(count), 2, BigDecimal.ROUND_HALF_UP);
                    writeDTO.setValue(value);
                }else {
                    writeDTO.setPointNo(entry.getKey());
                    writeDTO.setValue(dataValue);
                }
                logger.info("写入常量点="+writeDTO.getPointNo()+",值="+writeDTO.getValue());
                dataPointApi.writePointRealValue(writeDTO);
            }
            Thread.sleep(5000);
            List<String> sumPointNos = sumPoints.values().stream().flatMap(List::stream).collect(Collectors.toList());//合计
            Map<String, Object> totalPointsRealValue = dataPointApi.queryPointsRealValue(sumPointNos);
            for (Map.Entry<String, List<String>> entry : sumPoints.entrySet()) {
                ApiPointValueWriteDTO writeDTO = new ApiPointValueWriteDTO();
                double dataValue = 0d;
                int count = 0;
                for (String pointNo : entry.getValue()) {
                    Double value = Double.valueOf(String.format("%.2f", Double.valueOf(totalPointsRealValue.get(pointNo).toString())));
                    if (value > 0) {
                        dataValue += value;
                        count++;
                    }
                }
                if ("F0000101218".equals(entry.getKey()) || "F0000101219".equals(entry.getKey())) {
                    writeDTO.setPointNo(entry.getKey());
                    BigDecimal value = count == 0 ? BigDecimal.ZERO : new BigDecimal(dataValue).divide(new BigDecimal(count), 2, BigDecimal.ROUND_HALF_UP);
                    writeDTO.setValue(value);
                }else {
                    writeDTO.setPointNo(entry.getKey());
                    writeDTO.setValue(dataValue);
                }
                logger.info("写入常量点="+writeDTO.getPointNo()+",值="+writeDTO.getValue());
                dataPointApi.writePointRealValue(writeDTO);
            }
        } catch (Exception ex) {
            logger.error("RunMachineStateTask运行异常", ex);
        }
        logger.info("RunMachineStateTask运行完成");
    }
}