监测点指标告警日统计算法

This commit is contained in:
2023-05-09 18:26:18 +08:00
parent ba0de03a93
commit d2f53a9872
8 changed files with 340 additions and 61 deletions

View File

@@ -0,0 +1,22 @@
package com.njcn.prepare.harmonic.pojo.dto;
import com.njcn.prepare.harmonic.pojo.mysql.po.line.RMpTargetDiffDPO;
import lombok.Data;
/**
* 类的介绍:
*
* @author xuyang
* @version 1.0.0
* @createTime 2023/5/9 10:00
*/
@Data
public class RMpTargetWarnDDTO extends RMpTargetDiffDPO {
private Integer isEffective;
private Integer isHarmonic;
private Integer isEvent;
}

View File

@@ -39,12 +39,9 @@ public class RMpTargetWarnDController extends BaseController {
private final RMpTargetWarnDService rMpTargetWarnDService;
/**
* @author xuyang
*/
@OperateInfo(info = LogEnum.BUSINESS_COMMON,operateType = OperateType.ADD)
@PostMapping("/alarmDay")
@ApiOperation("监测点指标告警日统计")
@ApiOperation("监测点指标告警日统计(新)")
@ApiImplicitParam(name = "lineParam", value = "算法通用查询参数", required = true)
public HttpResult<Boolean> alarmDay(@RequestBody @Validated LineParam lineParam) {
String methodDescribe = getMethodDescribe("alarmDay");

View File

@@ -3,6 +3,7 @@ package com.njcn.prepare.harmonic.mapper.mysql.day;
import com.github.jeffreyning.mybatisplus.base.MppBaseMapper;
import com.njcn.harmonic.pojo.po.day.RStatDataVDPO;
import com.njcn.prepare.harmonic.pojo.dto.AlarmDetailDayDTO;
import com.njcn.prepare.harmonic.pojo.dto.RMpTargetWarnDDTO;
import com.njcn.prepare.harmonic.pojo.mysql.po.line.RMpTargetDiffDPO;
import org.apache.ibatis.annotations.Param;
@@ -22,4 +23,5 @@ public interface RStatDataVDMapper extends MppBaseMapper<RStatDataVDPO> {
*/
List<AlarmDetailDayDTO> getAvgDayData(@Param("startTime") String time, @Param("endTime") String endTime);
List<RMpTargetWarnDDTO> getTargetWarnD(@Param("time") String time);
}

View File

@@ -45,7 +45,7 @@
`time`,
line_id
) B
on A.time = B.time and A.lineId = B.lineId
on A.lineId = B.lineId
left join
(
select
@@ -61,7 +61,7 @@
`time`,
line_id
) C
on A.time = C.time and A.lineId = C.lineId
on A.lineId = C.lineId
left join
(
select
@@ -74,7 +74,7 @@
where
data_date = #{time}
) D
on A.time = D.dataDate and A.lineId = D.lineId
on A.lineId = D.lineId
</select>
<select id="getAvgDayData" resultType="com.njcn.prepare.harmonic.pojo.dto.AlarmDetailDayDTO">
@@ -125,9 +125,7 @@
`time` between #{startTime} and #{endTime} and value_type = 'MAX'
group by `time`,line_id
) B
on
A.time = B.time
and A.lineId = B.lineId
on A.lineId = B.lineId
left join
(
select
@@ -140,9 +138,7 @@
`time` between #{startTime} and #{endTime} and value_type = 'MAX'
group by `time`,line_id
) C
on
A.time = C.time
and A.lineId = C.lineId
on A.lineId = C.lineId
left join
(
select
@@ -155,9 +151,124 @@
where
data_date between #{startTime} and #{endTime}
) D
on
A.time = D.dataDate and A.lineId = D.lineId
on A.lineId = D.lineId
) Y
group by Y.lineId
</select>
<select id="getTargetWarnD" resultType="com.njcn.prepare.harmonic.pojo.dto.RMpTargetWarnDDTO">
select
A.time,
A.lineId,
coalesce(A.vUnbalance, 0) vUnbalance,
coalesce(A.v, 0) vHarmonic,
coalesce(B.vlDev, 0) vlDev,
coalesce(B.freqDev, 0) freqDev,
coalesce(C.plt, 0) plt,
coalesce(D.sagTimes, 0) sagTimes,
coalesce(D.interruptTimes, 0) interruptTimes,
case when (E.rate > 0.95 and E.isUnusual = 1) then 1 else 0 end isEffective,
coalesce(F.isHarmonic, 0) isHarmonic,
case when (G.swellTimes > 0 or G.sagTimes > 0 or G.interruptTimes > 0) then 1 else 0 end isEvent
from
(
select
`time`,
line_id lineId,
max(v_unbalance) vUnbalance,
max(greatest(v_thd, v_1, v_2, v_3, v_4, v_5, v_6, v_7, v_8, v_9, v_10, v_11, v_12, v_13, v_14, v_15, v_16, v_17, v_18, v_19, v_20, v_21, v_22, v_23, v_24, v_25, v_26, v_27, v_28, v_29, v_30, v_31, v_32, v_33, v_34, v_35, v_36, v_37, v_38, v_39, v_40, v_41, v_42, v_43, v_44, v_45, v_46, v_47, v_48, v_49, v_50)) v
from
r_stat_data_v_d t0
where
`time` = #{time} and value_type = 'CP95'
group by
`time`,
line_id
) A
left join
(
select
`time`,
line_id lineId,
max(abs(vl_dev)) vlDev,
max(abs(freq_dev)) freqDev
from
r_stat_data_v_d t0
where
`time` = #{time} and value_type = 'MAX'
group by
`time`,
line_id
) B
on
A.lineId = B.lineId
left join
(
select
`time` ,
line_id lineId,
max(plt) plt
from
r_stat_data_plt_d
where
`time` = #{time} and value_type = 'MAX'
group by
`time`,
line_id
) C
on
A.lineId = C.lineId
left join
(
select
measurement_point_id lineId,
data_date dataDate,
sag_times sagTimes,
interrupt_times interruptTimes
from
r_mp_event_detail_d
where
data_date = #{time}
) D
on
A.lineId = D.lineId
left join
(
select
data_date dataDate,
measurement_point_id lineId,
data_integrity_rate rate,
is_unusual isUnusual
from
r_operating_monitor_d
where
data_date = #{time}
) E
on A.lineId = E.lineId
left join
(
select
measurement_point_id lineId,
is_harmonic isHarmonic
from
r_mp_part_harmonic_detail_d
where
data_date = #{time}
) F
on A.lineId = F.lineId
left join
(
select
measurement_point_id lineId,
swell_times swellTimes,
sag_times sagTimes,
interrupt_times interruptTimes
from
r_mp_event_detail_d
where
data_date = #{time}
) G
on A.lineId = G.lineId
</select>
</mapper>

View File

@@ -3,22 +3,24 @@ package com.njcn.prepare.harmonic.service.mysql.Impl.area;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.github.jeffreyning.mybatisplus.service.MppServiceImpl;
import com.njcn.device.pq.api.LineFeignClient;
import com.njcn.harmonic.pojo.po.RMpTargetWarnDPO;
import com.njcn.prepare.harmonic.mapper.mysql.area.RMpTargetWarnDMapper;
import com.njcn.prepare.harmonic.mapper.mysql.day.RStatDataVDMapper;
import com.njcn.prepare.harmonic.pojo.dto.AlarmDetailDayDTO;
import com.njcn.prepare.harmonic.pojo.dto.RMpTargetWarnDDTO;
import com.njcn.prepare.harmonic.pojo.mysql.po.line.RMpTargetDiffDPO;
import com.njcn.prepare.harmonic.pojo.param.LineParam;
import com.njcn.prepare.harmonic.service.mysql.area.RMpTargetWarnDService;
import com.njcn.prepare.harmonic.service.mysql.line.AlarmDetailService;
import com.njcn.prepare.harmonic.utils.PublicUtil;
import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import java.util.List;
import java.util.Objects;
import java.util.*;
import java.util.stream.Collectors;
/**
@@ -32,6 +34,7 @@ import java.util.stream.Collectors;
@Service
@DS("master")
@AllArgsConstructor
@Slf4j
public class RMpTargetWarnDServiceImpl extends MppServiceImpl<RMpTargetWarnDMapper, RMpTargetWarnDPO> implements RMpTargetWarnDService {
@@ -42,6 +45,8 @@ public class RMpTargetWarnDServiceImpl extends MppServiceImpl<RMpTargetWarnDMapp
private final RStatDataVDMapper rStatDataVDMapper;
private final LineFeignClient lineFeignClient;
/**
* @param monitorIdList
* @param dataDate
@@ -69,51 +74,186 @@ public class RMpTargetWarnDServiceImpl extends MppServiceImpl<RMpTargetWarnDMapp
@Override
public void alarmDay(LineParam lineParam) {
List<AlarmDetailDayDTO> rlList,uclList;
//本年的rm值
List<AlarmDetailDayDTO> rmList = alarmDetailService.getAvgDiffData(lineParam);
//本年的CL值
List<AlarmDetailDayDTO> clList = rStatDataVDMapper.getAvgDayData(lineParam.getDataDate(), PublicUtil.getLastYearDay(lineParam.getDataDate()));
//本年的RL值
if (!CollectionUtils.isEmpty(rmList)){
rlList = rmList.stream().map(item->{
AlarmDetailDayDTO alarmDetailDayDTO = new AlarmDetailDayDTO();
alarmDetailDayDTO.setLineId(item.getLineId());
alarmDetailDayDTO.setVlDev(item.getVlDev()*3.3);
alarmDetailDayDTO.setFreqDev(item.getFreqDev()*3.3);
alarmDetailDayDTO.setVUnbalance(item.getVUnbalance()*3.3);
alarmDetailDayDTO.setVHarmonic(item.getVHarmonic()*3.3);
alarmDetailDayDTO.setSagTimes(item.getSagTimes()*3.3);
alarmDetailDayDTO.setInterruptTimes(item.getInterruptTimes()*3.3);
return alarmDetailDayDTO;
}).collect(Collectors.toList());
List<RMpTargetWarnDPO> list = new ArrayList<>();
//月处理
if (lineParam.getType() == 3){
int year = Integer.parseInt(lineParam.getDataDate().split("-")[0]);
int month = Integer.parseInt(lineParam.getDataDate().split("-")[1]);
List<String> dayList = PublicUtil.getDayByMonth(year,month);
for (String item : dayList) {
log.info(item+"-->开始执行");
List<RMpTargetWarnDPO> day = getData(item);
if (!CollectionUtils.isEmpty(day)){
list.addAll(day);
}
}
}
//本年的UCL值
if (!CollectionUtils.isEmpty(rmList) && !CollectionUtils.isEmpty(clList)){
uclList = rmList.stream().map(map->clList.stream().filter(m-> Objects.equals(m.getLineId(),map.getLineId())).findFirst().map(m->{
AlarmDetailDayDTO alarmDetailDayDTO = new AlarmDetailDayDTO();
alarmDetailDayDTO.setLineId(map.getLineId());
alarmDetailDayDTO.setVlDev(m.getVlDev()+map.getVlDev()*3);
alarmDetailDayDTO.setFreqDev(m.getFreqDev()+map.getFreqDev()*3);
alarmDetailDayDTO.setVUnbalance(m.getVUnbalance()+map.getVUnbalance()*3);
alarmDetailDayDTO.setVHarmonic(m.getVHarmonic()+map.getVHarmonic()*3);
alarmDetailDayDTO.setSagTimes(m.getSagTimes()+map.getSagTimes()*3);
alarmDetailDayDTO.setInterruptTimes(m.getInterruptTimes()+map.getInterruptTimes()*3);
return alarmDetailDayDTO;
}).orElse(null)).filter(Objects::nonNull).collect(Collectors.toList());
//日处理
else {
list = getData(lineParam.getDataDate());
}
if (!CollectionUtils.isEmpty(list)){
this.saveOrUpdateBatchByMultiId(list,50);
}
String yesterday = PublicUtil.getYesterday(lineParam.getDataDate());
List<RMpTargetDiffDPO> todayList = rStatDataVDMapper.getDayData(lineParam.getDataDate());
List<RMpTargetDiffDPO> yesterdayList = rStatDataVDMapper.getDayData(yesterday);
List<RMpTargetDiffDPO> theDayBeforeYesterday = rStatDataVDMapper.getDayData(PublicUtil.getYesterday(yesterday));
List<RMpTargetDiffDPO> threeDaysAgo = rStatDataVDMapper.getDayData(PublicUtil.getYesterday(PublicUtil.getYesterday(yesterday)));
}
@Override
public void alarmMonth(LineParam lineParam) {
}
public List<RMpTargetWarnDPO> getData(String time){
List<RMpTargetWarnDPO> result = new ArrayList<>();
List<AlarmDetailDayDTO> rlList = new ArrayList<>(),uclList = new ArrayList<>();
//基础数据
String yesterday = PublicUtil.getYesterday(time);
List<RMpTargetWarnDDTO> todayList = rStatDataVDMapper.getTargetWarnD(time + " 00:00:00");
List<RMpTargetWarnDDTO> yesterdayList = rStatDataVDMapper.getTargetWarnD(yesterday + " 00:00:00");
List<RMpTargetWarnDDTO> theDayBeforeYesterday = rStatDataVDMapper.getTargetWarnD(PublicUtil.getYesterday(yesterday) + " 00:00:00");
List<RMpTargetWarnDDTO> threeDaysAgo = rStatDataVDMapper.getTargetWarnD(PublicUtil.getYesterday(PublicUtil.getYesterday(yesterday)) + " 00:00:00");
if (!CollectionUtils.isEmpty(todayList)){
Map<String,List<RMpTargetWarnDDTO>> map2 = new HashMap<>(),map3 = new HashMap<>(),map4 = new HashMap<>();
//本年的rm值
List<AlarmDetailDayDTO> rmList = alarmDetailService.getAvgDiffData(time);
//本年的CL值
List<AlarmDetailDayDTO> clList = rStatDataVDMapper.getAvgDayData(PublicUtil.getLastYearDay(time),time);
//本年的RL值
if (!CollectionUtils.isEmpty(rmList)){
rlList = rmList.stream().map(item->{
AlarmDetailDayDTO alarmDetailDayDTO = new AlarmDetailDayDTO();
alarmDetailDayDTO.setLineId(item.getLineId());
alarmDetailDayDTO.setVlDev(item.getVlDev()*3.3);
alarmDetailDayDTO.setFreqDev(item.getFreqDev()*3.3);
alarmDetailDayDTO.setVUnbalance(item.getVUnbalance()*3.3);
alarmDetailDayDTO.setVHarmonic(item.getVHarmonic()*3.3);
alarmDetailDayDTO.setPlt(item.getPlt()*3.3);
alarmDetailDayDTO.setSagTimes(item.getSagTimes()*3.3);
alarmDetailDayDTO.setInterruptTimes(item.getInterruptTimes()*3.3);
return alarmDetailDayDTO;
}).collect(Collectors.toList());
}
//本年的UCL值
if (!CollectionUtils.isEmpty(rmList) && !CollectionUtils.isEmpty(clList)){
uclList = rmList.stream().map(map->clList.stream().filter(m-> Objects.equals(m.getLineId(),map.getLineId())).findFirst().map(m->{
AlarmDetailDayDTO alarmDetailDayDTO = new AlarmDetailDayDTO();
alarmDetailDayDTO.setLineId(map.getLineId());
alarmDetailDayDTO.setVlDev(m.getVlDev()+map.getVlDev()*3);
alarmDetailDayDTO.setFreqDev(m.getFreqDev()+map.getFreqDev()*3);
alarmDetailDayDTO.setVUnbalance(m.getVUnbalance()+map.getVUnbalance()*3);
alarmDetailDayDTO.setVHarmonic(m.getVHarmonic()+map.getVHarmonic()*3);
alarmDetailDayDTO.setPlt(m.getPlt()+map.getPlt()*3);
alarmDetailDayDTO.setSagTimes(m.getSagTimes()+map.getSagTimes()*3);
alarmDetailDayDTO.setInterruptTimes(m.getInterruptTimes()+map.getInterruptTimes()*3);
return alarmDetailDayDTO;
}).orElse(null)).filter(Objects::nonNull).collect(Collectors.toList());
}
//数据处理
Map<String,List<RMpTargetWarnDDTO>> map1 = todayList.stream().collect(Collectors.groupingBy(RMpTargetWarnDDTO::getLineId));
if (!CollectionUtils.isEmpty(yesterdayList)){
map2 = yesterdayList.stream().collect(Collectors.groupingBy(RMpTargetWarnDDTO::getLineId));
}
if (!CollectionUtils.isEmpty(theDayBeforeYesterday)){
map3 = theDayBeforeYesterday.stream().collect(Collectors.groupingBy(RMpTargetWarnDDTO::getLineId));
}
if (!CollectionUtils.isEmpty(threeDaysAgo)){
map4 = threeDaysAgo.stream().collect(Collectors.groupingBy(RMpTargetWarnDDTO::getLineId));
}
Map<String,List<AlarmDetailDayDTO>> map5 = rlList.stream().collect(Collectors.groupingBy(AlarmDetailDayDTO::getLineId));
Map<String,List<AlarmDetailDayDTO>> map6 = uclList.stream().collect(Collectors.groupingBy(AlarmDetailDayDTO::getLineId));
for (Map.Entry<String, List<RMpTargetWarnDDTO>> entry : map1.entrySet()) {
RMpTargetWarnDPO rMpTargetWarnDpo = new RMpTargetWarnDPO();
rMpTargetWarnDpo.setDataDate(entry.getValue().get(0).getTime());
rMpTargetWarnDpo.setMeasurementPointId(entry.getValue().get(0).getLineId());
rMpTargetWarnDpo.setIsEffective(entry.getValue().get(0).getIsEffective());
rMpTargetWarnDpo.setIsHarmonic(entry.getValue().get(0).getIsHarmonic());
rMpTargetWarnDpo.setIsEvent(entry.getValue().get(0).getIsEvent());
rMpTargetWarnDpo.setIsWarn(0);
rMpTargetWarnDpo.setIsVDevWarn(0);
rMpTargetWarnDpo.setIsFreqWarn(0);
rMpTargetWarnDpo.setIsUnbalanceWarn(0);
rMpTargetWarnDpo.setIsVWarn(0);
rMpTargetWarnDpo.setIsFlickerWarn(0);
rMpTargetWarnDpo.setIsSagWarn(0);
rMpTargetWarnDpo.setIsInterruptWarn(0);
//情况1--》
if (!CollectionUtils.isEmpty(map2.get(entry.getKey())) && !CollectionUtils.isEmpty(map6.get(entry.getKey()))){
//电压偏差告警
if (entry.getValue().get(0).getVlDev() > map6.get(entry.getKey()).get(0).getVlDev() && entry.getValue().get(0).getVlDev() > map2.get(entry.getKey()).get(0).getVlDev()){
rMpTargetWarnDpo.setIsVDevWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//频率偏差告警
if (entry.getValue().get(0).getFreqDev() > map6.get(entry.getKey()).get(0).getFreqDev() && entry.getValue().get(0).getFreqDev() > map2.get(entry.getKey()).get(0).getFreqDev()){
rMpTargetWarnDpo.setIsFreqWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//三相电压不平衡告警
if (entry.getValue().get(0).getVUnbalance() > map6.get(entry.getKey()).get(0).getVUnbalance() && entry.getValue().get(0).getVUnbalance() > map2.get(entry.getKey()).get(0).getVUnbalance()){
rMpTargetWarnDpo.setIsUnbalanceWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//谐波电压告警
if (entry.getValue().get(0).getVHarmonic() > map6.get(entry.getKey()).get(0).getVHarmonic() && entry.getValue().get(0).getVHarmonic() > map2.get(entry.getKey()).get(0).getVHarmonic()){
rMpTargetWarnDpo.setIsHarmonic(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//长时电压闪变告警
if (entry.getValue().get(0).getPlt() > map6.get(entry.getKey()).get(0).getPlt() && entry.getValue().get(0).getPlt() > map2.get(entry.getKey()).get(0).getPlt()){
rMpTargetWarnDpo.setIsFlickerWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//电压暂降告警
if (entry.getValue().get(0).getSagTimes() > map6.get(entry.getKey()).get(0).getSagTimes() && entry.getValue().get(0).getSagTimes() > map2.get(entry.getKey()).get(0).getSagTimes()){
rMpTargetWarnDpo.setIsSagWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//电压短时中断告警
if (entry.getValue().get(0).getInterruptTimes() > map6.get(entry.getKey()).get(0).getInterruptTimes() && entry.getValue().get(0).getInterruptTimes() > map2.get(entry.getKey()).get(0).getInterruptTimes()){
rMpTargetWarnDpo.setIsInterruptWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
}
//情况2--》
if (!CollectionUtils.isEmpty(map2.get(entry.getKey())) && !CollectionUtils.isEmpty(map3.get(entry.getKey())) && !CollectionUtils.isEmpty(map4.get(entry.getKey())) && !CollectionUtils.isEmpty(map5.get(entry.getKey()))){
//电压偏差告警
if (entry.getValue().get(0).getVlDev() > map2.get(entry.getKey()).get(0).getVlDev() && map2.get(entry.getKey()).get(0).getVlDev() > map3.get(entry.getKey()).get(0).getVlDev() && map3.get(entry.getKey()).get(0).getVlDev() > map4.get(entry.getKey()).get(0).getVlDev() && map4.get(entry.getKey()).get(0).getVlDev() > map5.get(entry.getKey()).get(0).getVlDev()){
rMpTargetWarnDpo.setIsVDevWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//频率偏差告警
if (entry.getValue().get(0).getFreqDev() > map2.get(entry.getKey()).get(0).getFreqDev() && map2.get(entry.getKey()).get(0).getFreqDev() > map3.get(entry.getKey()).get(0).getFreqDev() && map3.get(entry.getKey()).get(0).getFreqDev() > map4.get(entry.getKey()).get(0).getFreqDev() && map4.get(entry.getKey()).get(0).getFreqDev() > map5.get(entry.getKey()).get(0).getFreqDev()){
rMpTargetWarnDpo.setIsFreqWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//三相电压不平衡告警
if (entry.getValue().get(0).getVUnbalance() > map2.get(entry.getKey()).get(0).getVUnbalance() && map2.get(entry.getKey()).get(0).getVUnbalance() > map3.get(entry.getKey()).get(0).getVUnbalance() && map3.get(entry.getKey()).get(0).getVUnbalance() > map4.get(entry.getKey()).get(0).getVUnbalance() && map4.get(entry.getKey()).get(0).getVUnbalance() > map5.get(entry.getKey()).get(0).getVUnbalance()){
rMpTargetWarnDpo.setIsUnbalanceWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//谐波电压告警
if (entry.getValue().get(0).getVHarmonic() > map2.get(entry.getKey()).get(0).getVHarmonic() && map2.get(entry.getKey()).get(0).getVHarmonic() > map3.get(entry.getKey()).get(0).getVHarmonic() && map3.get(entry.getKey()).get(0).getVHarmonic() > map4.get(entry.getKey()).get(0).getVHarmonic() && map4.get(entry.getKey()).get(0).getVHarmonic() > map5.get(entry.getKey()).get(0).getVHarmonic()){
rMpTargetWarnDpo.setIsHarmonic(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//长时电压闪变告警
if (entry.getValue().get(0).getPlt() > map2.get(entry.getKey()).get(0).getPlt() && map2.get(entry.getKey()).get(0).getPlt() > map3.get(entry.getKey()).get(0).getPlt() && map3.get(entry.getKey()).get(0).getPlt() > map4.get(entry.getKey()).get(0).getPlt() && map4.get(entry.getKey()).get(0).getPlt() > map5.get(entry.getKey()).get(0).getPlt()){
rMpTargetWarnDpo.setIsFlickerWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//电压暂降告警
if (entry.getValue().get(0).getSagTimes() > map2.get(entry.getKey()).get(0).getSagTimes() && map2.get(entry.getKey()).get(0).getSagTimes() > map3.get(entry.getKey()).get(0).getSagTimes() && map3.get(entry.getKey()).get(0).getSagTimes() > map4.get(entry.getKey()).get(0).getSagTimes() && map4.get(entry.getKey()).get(0).getSagTimes() > map5.get(entry.getKey()).get(0).getSagTimes()){
rMpTargetWarnDpo.setIsSagWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
//电压短时中断告警
if (entry.getValue().get(0).getInterruptTimes() > map2.get(entry.getKey()).get(0).getInterruptTimes() && map2.get(entry.getKey()).get(0).getInterruptTimes() > map3.get(entry.getKey()).get(0).getInterruptTimes() && map3.get(entry.getKey()).get(0).getInterruptTimes() > map4.get(entry.getKey()).get(0).getInterruptTimes() && map4.get(entry.getKey()).get(0).getInterruptTimes() > map5.get(entry.getKey()).get(0).getInterruptTimes()){
rMpTargetWarnDpo.setIsInterruptWarn(1);
rMpTargetWarnDpo.setIsWarn(1);
}
}
result.add(rMpTargetWarnDpo);
}
}
return result;
}
}

View File

@@ -140,11 +140,10 @@ public class AlarmDetailServiceImpl extends MppServiceImpl<AlarmMapper, RMpTarge
}
@Override
public List<AlarmDetailDayDTO> getAvgDiffData(LineParam lineParam) {
String startTime = lineParam.getDataDate();
String endTime = PublicUtil.getLastYearDay(startTime);
public List<AlarmDetailDayDTO> getAvgDiffData(String time) {
String endTime = PublicUtil.getLastYearDay(time);
//计算本年的rm值
return this.baseMapper.getAvgDiffData(startTime,endTime);
return this.baseMapper.getAvgDiffData(endTime,time);
}
/**

View File

@@ -26,7 +26,15 @@ public interface RMpTargetWarnDService extends IMppService<RMpTargetWarnDPO> {
*/
Integer queryHarmonicMeasurementAccrued(List<String> monitorIdList, String dataDate);
/**
* @Description: 监测点指标告警日统计
* @author: xuyang
*/
void alarmDay(LineParam lineParam);
/**
* @Description: 监测点指标告警月统计
* @author: xuyang
*/
void alarmMonth(LineParam lineParam);
}

View File

@@ -24,5 +24,5 @@ public interface AlarmDetailService {
void targetDiff(LineParam lineParam);
List<AlarmDetailDayDTO> getAvgDiffData(LineParam lineParam);
List<AlarmDetailDayDTO> getAvgDiffData(String time);
}