超高压谐波溯源功能

This commit is contained in:
2024-01-05 16:16:59 +08:00
parent e094d93c4e
commit e67ade979a
6 changed files with 182 additions and 1 deletions

View File

@@ -0,0 +1,28 @@
package com.njcn.harmonic.pojo.vo;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
/**
* 类的介绍:
*
* @author xuyang
* @version 1.0.0
* @createTime 2024/1/5 14:45
*/
@Data
public class TraceVO {
@ApiModelProperty("谐波电流次数")
private Integer harmonicTimes;
@ApiModelProperty("A相谐波电流方向(数值小于0-流出、大于0-流入、等于0-无方向)")
private Double harmonicA;
@ApiModelProperty("B相谐波电流方向(数值小于0-流出、大于0-流入、等于0-无方向)")
private Double harmonicB;
@ApiModelProperty("C相谐波电流方向(数值小于0-流出、大于0-流入、等于0-无方向)")
private Double harmonicC;
}

View File

@@ -0,0 +1,56 @@
package com.njcn.harmonic.controller;
import com.njcn.common.pojo.annotation.OperateInfo;
import com.njcn.common.pojo.enums.common.LogEnum;
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
import com.njcn.common.pojo.response.HttpResult;
import com.njcn.common.utils.HttpResultUtil;
import com.njcn.harmonic.pojo.vo.TraceVO;
import com.njcn.harmonic.service.IHarmonicTraceService;
import com.njcn.web.controller.BaseController;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/**
* 类的介绍:谐波电流溯源(谐波源定位)
*
* @author xuyang
* @version 1.0.0
* @createTime 2024/1/5 14:37
*/
@Validated
@Slf4j
@RestController
@RequestMapping("/harmonicCurrent")
@Api(tags = "谐波源定位")
@AllArgsConstructor
public class HarmonicTraceController extends BaseController {
private final IHarmonicTraceService harmonicTraceService;
@OperateInfo(info = LogEnum.BUSINESS_COMMON)
@PostMapping("/trace")
@ApiOperation("谐波电流溯源")
@ApiImplicitParams({
@ApiImplicitParam(name = "lineId", value = "监测点id", required = true),
@ApiImplicitParam(name = "time", value = "时间", required = true)
})
public HttpResult<List<TraceVO>> getTraceData(@RequestParam("lineId") String lineId,@RequestParam("time") String time) {
String methodDescribe = getMethodDescribe("getTraceData");
List<TraceVO> list = harmonicTraceService.getTraceData(lineId,time);
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, list, methodDescribe);
}
}

View File

@@ -52,7 +52,7 @@ public class NormLimitController extends BaseController {
@ApiOperation("告警数据统计") @ApiOperation("告警数据统计")
@ApiImplicitParam(name = "historyHarmOverLimitParam", value = "异常数据统计参数", required = true) @ApiImplicitParam(name = "historyHarmOverLimitParam", value = "异常数据统计参数", required = true)
public HttpResult<List<HistoryHarmOverLimitVO>> getHistoryData(@RequestBody @Validated HistoryHarmOverLimitParam historyHarmOverLimitParam) { public HttpResult<List<HistoryHarmOverLimitVO>> getHistoryData(@RequestBody @Validated HistoryHarmOverLimitParam historyHarmOverLimitParam) {
String methodDescribe = getMethodDescribe("getHistoryTableData"); String methodDescribe = getMethodDescribe("getHistoryData");
List<HistoryHarmOverLimitVO> list = normLimitService.getHistoryData(historyHarmOverLimitParam,1); List<HistoryHarmOverLimitVO> list = normLimitService.getHistoryData(historyHarmOverLimitParam,1);
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, list, methodDescribe); return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, list, methodDescribe);
} }

View File

@@ -0,0 +1,7 @@
package com.njcn.harmonic.mapper;
import com.github.jeffreyning.mybatisplus.base.MppBaseMapper;
import com.njcn.harmonic.pojo.po.day.RStatDataHarmpowerPDPO;
public interface RStatDataHarmpowerPDMapper extends MppBaseMapper<RStatDataHarmpowerPDPO> {
}

View File

@@ -0,0 +1,20 @@
package com.njcn.harmonic.service;
import com.njcn.harmonic.pojo.vo.TraceVO;
import java.util.List;
/**
* @author xuyang
*/
public interface IHarmonicTraceService {
/**
* 根据监测点id实现谐波电流溯源
* @param lineId 监测点id
* @param time 时间
* @return 谐波电流各次数方向
*/
List<TraceVO> getTraceData(String lineId,String time);
}

View File

@@ -0,0 +1,70 @@
package com.njcn.harmonic.service.impl;
import cn.hutool.core.collection.CollectionUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.njcn.harmonic.mapper.RStatDataHarmpowerPDMapper;
import com.njcn.harmonic.pojo.po.day.RStatDataHarmpowerPDPO;
import com.njcn.harmonic.pojo.vo.TraceVO;
import com.njcn.harmonic.service.IHarmonicTraceService;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
* 类的介绍:
*
* @author xuyang
* @version 1.0.0
* @createTime 2024/1/5 14:43
*/
@Service
@AllArgsConstructor
public class HarmonicTraceServiceImpl implements IHarmonicTraceService {
private final RStatDataHarmpowerPDMapper rStatDataHarmpowerPDMapper;
@Override
public List<TraceVO> getTraceData(String lineId, String time) {
List<TraceVO> result = new ArrayList<>();
LambdaQueryWrapper<RStatDataHarmpowerPDPO> lambdaQueryWrapper = new LambdaQueryWrapper<>();
lambdaQueryWrapper.eq(RStatDataHarmpowerPDPO::getTime, time)
.eq(RStatDataHarmpowerPDPO::getLineId, lineId)
.eq(RStatDataHarmpowerPDPO::getValueType, "AVG")
.in(RStatDataHarmpowerPDPO::getPhaseType, Arrays.asList("A","B","C"));
List<RStatDataHarmpowerPDPO> list = rStatDataHarmpowerPDMapper.selectList(lambdaQueryWrapper);
if (CollectionUtil.isNotEmpty(list)){
Map<String,List<RStatDataHarmpowerPDPO>> map = list.stream().collect(Collectors.groupingBy(RStatDataHarmpowerPDPO::getPhaseType));
List<Double> aList = getDataByPhaseType(map,"A");
List<Double> bList = getDataByPhaseType(map,"B");
List<Double> cList = getDataByPhaseType(map,"C");
for (int i = 0; i < 49; i++) {
TraceVO traceVO = new TraceVO();
traceVO.setHarmonicTimes(i+2);
traceVO.setHarmonicA(aList.get(i));
traceVO.setHarmonicB(bList.get(i));
traceVO.setHarmonicC(cList.get(i));
result.add(traceVO);
}
}
return result;
}
public List<Double> getDataByPhaseType(Map<String,List<RStatDataHarmpowerPDPO>> map, String phaseType) {
RStatDataHarmpowerPDPO po = map.get(phaseType).get(0);
return Arrays.asList(po.getP2(),po.getP3(),po.getP4(),po.getP5(),po.getP6(),po.getP7(),po.getP8(),po.getP9()
,po.getP10(),po.getP11(),po.getP12(),po.getP13(),po.getP14(),po.getP15(),po.getP16(),po.getP17(),po.getP18(),po.getP19()
,po.getP20(),po.getP21(),po.getP22(),po.getP23(),po.getP24(),po.getP25(),po.getP26(),po.getP27(),po.getP28(),po.getP29()
,po.getP30(),po.getP31(),po.getP32(),po.getP33(),po.getP34(),po.getP35(),po.getP36(),po.getP37(),po.getP38(),po.getP39()
,po.getP40(),po.getP41(),po.getP42(),po.getP43(),po.getP44(),po.getP45(),po.getP46(),po.getP47(),po.getP48(),po.getP49()
,po.getP50());
}
}