|
@@ -1,6 +1,9 @@
|
|
|
package com.gyee.power.fitting.dispersionanalysis;
|
|
|
|
|
|
import cn.hutool.core.collection.CollUtil;
|
|
|
+import cn.hutool.core.date.DateField;
|
|
|
+import cn.hutool.core.date.DateRange;
|
|
|
+import cn.hutool.core.date.DateTime;
|
|
|
import cn.hutool.core.date.DateUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.gyee.power.fitting.common.feign.RemoteServiceBuilder;
|
|
@@ -40,116 +43,132 @@ public class CalculateTask {
|
|
|
Map<String, ProBasicEquipmentPoint> mxztMap = proBasicEquipmentPointService.getEquipmentMapByUniformcode("MXZT");
|
|
|
//获取最新更新时间
|
|
|
QueryWrapper<StateCause> scWrapper = new QueryWrapper<>();
|
|
|
- scWrapper.select("equipment_id,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()));
|
|
|
- }
|
|
|
+ scWrapper.select("equipment_id,last_row(end_time) end_time");
|
|
|
+ StateCause sc = stateCauseService.getOne(scWrapper);
|
|
|
+ DateRange dateRange = getDateRange(sc);
|
|
|
+ if (dateRange == null) return;
|
|
|
|
|
|
- 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() - 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 doubleValue0 = remove != null ? (int) remove.getDoubleValue() : 7;
|
|
|
- int doubleValue1;
|
|
|
- for (TsDoubleData data : datas8) {
|
|
|
- ts1 = data.getTs();
|
|
|
- doubleValue1 = (int) data.getDoubleValue();
|
|
|
- if (doubleValue1 == doubleValue0) continue;
|
|
|
-
|
|
|
- //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));
|
|
|
+ long starttime, endtime;
|
|
|
+ for (DateTime time : dateRange) {
|
|
|
+ starttime = time.getTime();
|
|
|
+ endtime = DateUtil.endOfDay(time).getTime();
|
|
|
+
|
|
|
+ String equipmentId, tbName;
|
|
|
+ for (ProBasicEquipment equipment : equipmentList) {
|
|
|
+ equipmentId = equipment.getId();
|
|
|
+
|
|
|
+ tbName = equipmentId + "_SC_CI08";
|
|
|
+ List<TsDoubleData> datas8 = getDatas(sbztMap.get(equipmentId).getNemCode(), starttime, endtime);
|
|
|
+
|
|
|
+ if (CollUtil.isNotEmpty(datas8)) {
|
|
|
+
|
|
|
+ long ts0 = endtime;
|
|
|
+ long ts1;
|
|
|
+ int doubleValue0 = (int) datas8.get(0).getDoubleValue();
|
|
|
+ int doubleValue1 = 0;
|
|
|
+ for (TsDoubleData data : datas8) {
|
|
|
+ ts1 = data.getTs();
|
|
|
+ doubleValue1 = (int) data.getDoubleValue();
|
|
|
+ if (doubleValue1 == doubleValue0) continue;
|
|
|
+
|
|
|
+ //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));
|
|
|
+ }
|
|
|
+ ts0 = ts1;
|
|
|
+ doubleValue0 = doubleValue1;
|
|
|
}
|
|
|
- if (ts1 <= starttime) break;
|
|
|
- ts0 = ts1;
|
|
|
- doubleValue0 = doubleValue1;
|
|
|
-
|
|
|
+ if (ts0 > starttime) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, doubleValue1, starttime, ts0, ts0 - starttime));
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ System.out.println(equipmentId+":8种状态:"+sbztMap.get(equipmentId).getNemCode());
|
|
|
}
|
|
|
- }
|
|
|
-
|
|
|
- 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 doubleValue0 = remove != null ? (int) remove.getDoubleValue() : 7;
|
|
|
- int doubleValue1;
|
|
|
- for (TsDoubleData data : datas14) {
|
|
|
- ts1 = data.getTs();
|
|
|
- doubleValue1 = (int) data.getDoubleValue();
|
|
|
- if (doubleValue1 == doubleValue0) continue;
|
|
|
-
|
|
|
- //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));
|
|
|
+ tbName = equipmentId + "_SC_CI14";
|
|
|
+ List<TsDoubleData> datas14 = getDatas(mxztMap.get(equipmentId).getNemCode(), starttime, endtime);
|
|
|
+
|
|
|
+ if (CollUtil.isNotEmpty(datas14)) {
|
|
|
+
|
|
|
+ long ts0 = endtime;
|
|
|
+ long ts1;
|
|
|
+ int doubleValue0 = (int) datas14.get(0).getDoubleValue();
|
|
|
+ int doubleValue1 = 0;
|
|
|
+ for (TsDoubleData data : datas14) {
|
|
|
+ ts1 = data.getTs();
|
|
|
+ doubleValue1 = (int) data.getDoubleValue();
|
|
|
+ if (doubleValue1 == doubleValue0) continue;
|
|
|
+
|
|
|
+ //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));
|
|
|
+ }
|
|
|
+ ts0 = ts1;
|
|
|
+ doubleValue0 = doubleValue1;
|
|
|
}
|
|
|
- if (ts1 <= starttime) break;
|
|
|
- ts0 = ts1;
|
|
|
- doubleValue0 = doubleValue1;
|
|
|
+ if (ts0 > starttime) {
|
|
|
+ stateCauseList.add(new StateCause(tbName, doubleValue1, starttime, ts0, ts0 - starttime));
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ System.out.println(equipmentId+":14种状态:"+sbztMap.get(equipmentId).getNemCode());
|
|
|
}
|
|
|
+
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
int i = stateCauseService.saveBatch(stateCauseList);
|
|
|
- System.out.println("计算完成"+i);
|
|
|
+ System.out.println("计算完成" + i);
|
|
|
+ }
|
|
|
+
|
|
|
+ private DateRange getDateRange(StateCause sc) {
|
|
|
+ DateTime startTime;
|
|
|
+ DateTime endTime = DateUtil.beginOfDay(DateUtil.yesterday());
|
|
|
+ if (sc == null) {
|
|
|
+ startTime = endTime;
|
|
|
+ } else {
|
|
|
+ startTime = DateUtil.offsetDay(DateUtil.beginOfDay(DateUtil.date(sc.getEndTime())), 1);
|
|
|
+ if (startTime.isAfter(endTime)) return null;
|
|
|
+ }
|
|
|
+ return DateUtil.range(startTime, endTime, DateField.DAY_OF_YEAR);
|
|
|
}
|
|
|
|
|
|
private List<TsDoubleData> getDatas(String nemCode, long starttime, long endtime) {
|