|
@@ -0,0 +1,187 @@
|
|
|
+package com.gyee.power.fitting.dispersionanalysis;
|
|
|
+
|
|
|
+import cn.hutool.core.collection.CollUtil;
|
|
|
+import cn.hutool.core.date.DateUtil;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.gyee.power.fitting.common.feign.RemoteServiceBuilder;
|
|
|
+import com.gyee.power.fitting.model.ProBasicEquipment;
|
|
|
+import com.gyee.power.fitting.model.ProBasicEquipmentPoint;
|
|
|
+import com.gyee.power.fitting.model.StateCause;
|
|
|
+import com.gyee.power.fitting.model.custom.TsDoubleData;
|
|
|
+import com.gyee.power.fitting.service.IStateCauseService;
|
|
|
+import com.gyee.power.fitting.service.ProBasicEquipmentPointService;
|
|
|
+import com.gyee.power.fitting.service.ProBasicEquipmentService;
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.springframework.scheduling.annotation.Scheduled;
|
|
|
+import org.springframework.stereotype.Component;
|
|
|
+
|
|
|
+import javax.annotation.Resource;
|
|
|
+import java.util.*;
|
|
|
+import java.util.function.Function;
|
|
|
+import java.util.stream.Collectors;
|
|
|
+
|
|
|
+@Slf4j
|
|
|
+@Component
|
|
|
+public class CalculateTask {
|
|
|
+ @Resource
|
|
|
+ private IStateCauseService stateCauseService;
|
|
|
+ @Resource
|
|
|
+ private ProBasicEquipmentService proBasicEquipmentService;
|
|
|
+ @Resource
|
|
|
+ private ProBasicEquipmentPointService proBasicEquipmentPointService;
|
|
|
+ @Resource
|
|
|
+ private RemoteServiceBuilder remoteService;
|
|
|
+
|
|
|
+ //秒 分 时 日 月 周
|
|
|
+ @Scheduled(cron = "0 06 15 * * ?")
|
|
|
+ public void doTask() {
|
|
|
+ List<ProBasicEquipment> equipmentList = proBasicEquipmentService.getCacheList();
|
|
|
+ Map<String, ProBasicEquipmentPoint> sbztMap = proBasicEquipmentPointService.getEquipmentMapByUniformcode("SBZT");
|
|
|
+ Map<String, ProBasicEquipmentPoint> mxztMap = proBasicEquipmentPointService.getEquipmentMapByUniformcode("MXZT");
|
|
|
+ //获取最新更新时间
|
|
|
+ QueryWrapper<StateCause> scWrapper = new QueryWrapper<>();
|
|
|
+ scWrapper.select("last_row(end_time) end_time").groupBy("equipment_id");
|
|
|
+ List<StateCause> scList = stateCauseService.list(scWrapper);
|
|
|
+ Map<String, StateCause> stateCauseMap;
|
|
|
+ if (scList.isEmpty()) {
|
|
|
+ stateCauseMap = new HashMap<>();
|
|
|
+ } else {
|
|
|
+ stateCauseMap = scList.stream().collect(Collectors.toMap(StateCause::getEquipmentId, Function.identity()));
|
|
|
+ }
|
|
|
+
|
|
|
+ String equipmentId, tbName;
|
|
|
+ long starttime, endtime = DateUtil.date().getTime();
|
|
|
+ List<StateCause> stateCauseList = new ArrayList<>();
|
|
|
+
|
|
|
+ for (ProBasicEquipment equipment : equipmentList) {
|
|
|
+ equipmentId = equipment.getId();
|
|
|
+ StateCause stateCause = stateCauseMap.get(equipmentId);
|
|
|
+ if (stateCause == null) {
|
|
|
+ starttime = DateUtil.yesterday().getTime();
|
|
|
+ } else {
|
|
|
+ starttime = stateCause.getEndTime() != null ? stateCause.getEndTime().getTime() - 6000 : DateUtil.yesterday().getTime();
|
|
|
+ }
|
|
|
+ List<TsDoubleData> datas8 = getDatas(sbztMap.get(equipmentId).getNemCode(), starttime, endtime);
|
|
|
+
|
|
|
+ tbName = equipmentId + "_SC_CI08";
|
|
|
+ if (CollUtil.isNotEmpty(datas8)) {
|
|
|
+ TsDoubleData remove = datas8.remove(0);
|
|
|
+ long ts0 = remove != null ? remove.getTs() : starttime;
|
|
|
+ long ts1;
|
|
|
+ int doubleValue1;
|
|
|
+ for (TsDoubleData data : datas8) {
|
|
|
+ ts1 = data.getTs();
|
|
|
+ doubleValue1 = (int) data.getDoubleValue();
|
|
|
+
|
|
|
+ //0待机, 1运行, 2故障, 3检修, 4限电, 5受累, 6离线
|
|
|
+ if (doubleValue1 == 1) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 1, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 2) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 2, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 3) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 3, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 4) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 4, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 5) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 5, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 6) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 6, ts1, ts0, ts0 - ts1));
|
|
|
+ } else {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 0, ts1, ts0, ts0 - ts1));
|
|
|
+ }
|
|
|
+ if (ts1 <= starttime) break;
|
|
|
+ ts0 = ts1;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ List<TsDoubleData> datas14 = getDatas(mxztMap.get(equipmentId).getNemCode(), starttime, endtime);
|
|
|
+
|
|
|
+ tbName = equipmentId + "_SC_CI14";
|
|
|
+ if (CollUtil.isNotEmpty(datas14)) {
|
|
|
+ TsDoubleData remove = datas14.remove(0);
|
|
|
+ long ts0 = remove != null ? remove.getTs() : starttime;
|
|
|
+ long ts1;
|
|
|
+ int doubleValue1;
|
|
|
+ for (TsDoubleData data : datas14) {
|
|
|
+ ts1 = data.getTs();
|
|
|
+ doubleValue1 = (int) data.getDoubleValue();
|
|
|
+
|
|
|
+ //0待机, 1手动停机, 2正常发电, 3发电降出力, 4故障, 5故障受累, 6检修, 7检修受累, 8限电降出力, 9限电停机, 10电网受累, 11环境受累, 12通讯中断, 13设备离线
|
|
|
+ if (doubleValue1 == 1) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 1, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 2) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 2, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 3) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 3, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 4) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 4, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 5) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 5, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 6) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 6, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 7) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 7, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 8) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 8, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 9) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 9, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 10) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 10, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 11) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 11, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 12) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 12, ts1, ts0, ts0 - ts1));
|
|
|
+ } else if (doubleValue1 == 13) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 13, ts1, ts0, ts0 - ts1));
|
|
|
+ } else {
|
|
|
+ stateCauseList.add(new StateCause(tbName, 0, ts1, ts0, ts0 - ts1));
|
|
|
+ }
|
|
|
+ if (ts1 <= starttime) break;
|
|
|
+ ts0 = ts1;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ stateCauseService.saveBatch(stateCauseList);
|
|
|
+ }
|
|
|
+
|
|
|
+ private List<TsDoubleData> getDatas(String nemCode, long starttime, long endtime) {
|
|
|
+ List<TsDoubleData> rawValuesByKey;
|
|
|
+ if (nemCode.startsWith("GF")) {
|
|
|
+ rawValuesByKey = remoteService.adaptergf().getRawValuesByKey(nemCode, starttime, endtime);
|
|
|
+ } else {
|
|
|
+ rawValuesByKey = remoteService.adapterfd().getRawValuesByKey(nemCode, starttime, endtime);
|
|
|
+ }
|
|
|
+ rawValuesByKey.sort(Comparator.comparing(TsDoubleData::getTs).reversed());
|
|
|
+ return rawValuesByKey;
|
|
|
+ }
|
|
|
+
|
|
|
+ //秒 分 时 日 月 周
|
|
|
+ //@Scheduled(cron = "0 06 15 * * ?")
|
|
|
+ public void creatStables() {
|
|
|
+ List<ProBasicEquipment> equipmentList = proBasicEquipmentService.getCacheList();
|
|
|
+
|
|
|
+ String equipmentId, tbName;
|
|
|
+ List<StateCause> stateCauseList = new ArrayList<>();
|
|
|
+
|
|
|
+ for (ProBasicEquipment equipment : equipmentList) {
|
|
|
+ equipmentId = equipment.getId();
|
|
|
+
|
|
|
+ tbName = equipmentId + "_SC_CI08";
|
|
|
+ StateCause sc1 = new StateCause();
|
|
|
+ sc1.setEquipmentId(equipmentId);
|
|
|
+ sc1.setTbname(tbName);
|
|
|
+ sc1.setStationId(equipment.getWindpowerstationId());
|
|
|
+ sc1.setStateType("8种状态");
|
|
|
+ stateCauseList.add(sc1);
|
|
|
+
|
|
|
+ tbName = equipmentId + "_SC_CI14";
|
|
|
+ StateCause sc2 = new StateCause();
|
|
|
+ sc2.setEquipmentId(equipmentId);
|
|
|
+ sc2.setTbname(tbName);
|
|
|
+ sc2.setStationId(equipment.getWindpowerstationId());
|
|
|
+ sc2.setStateType("14种状态");
|
|
|
+ stateCauseList.add(sc2);
|
|
|
+ }
|
|
|
+ stateCauseService.creatTablesBatch(stateCauseList);
|
|
|
+ }
|
|
|
+}
|