无线系统实时数据功能
This commit is contained in:
@@ -8,11 +8,36 @@
|
||||
<version>1.0.0</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<name>rt-api</name>
|
||||
<artifactId>rt-api</artifactId>
|
||||
<version>1.0.0</version>
|
||||
|
||||
<name>rt-api</name>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>common-core</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>common-db</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.projectlombok</groupId>
|
||||
<artifactId>lombok</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>common-microservice</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>common-mq</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<properties>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
|
||||
@@ -0,0 +1,18 @@
|
||||
package com.njcn.rt.api;
|
||||
|
||||
import com.njcn.common.pojo.constant.ServerInfo;
|
||||
import com.njcn.common.pojo.response.HttpResult;
|
||||
import com.njcn.mq.message.AppAutoDataMessage;
|
||||
import com.njcn.rt.api.fallback.RtClientFallbackFactory;
|
||||
import org.springframework.cloud.openfeign.FeignClient;
|
||||
import org.springframework.web.bind.annotation.PostMapping;
|
||||
|
||||
/**
|
||||
* @author xy
|
||||
*/
|
||||
@FeignClient(value = ServerInfo.CS_RT_BOOT, path = "/rtData", fallbackFactory = RtClientFallbackFactory.class,contextId = "rtData")
|
||||
public interface RtFeignClient {
|
||||
|
||||
@PostMapping("/rtAnalysis")
|
||||
HttpResult<String> analysis(AppAutoDataMessage appAutoDataMessage);
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.njcn.rt.api.fallback;
|
||||
|
||||
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
|
||||
import com.njcn.common.pojo.exception.BusinessException;
|
||||
import com.njcn.common.pojo.response.HttpResult;
|
||||
import com.njcn.mq.message.AppAutoDataMessage;
|
||||
import com.njcn.rt.api.RtFeignClient;
|
||||
import feign.hystrix.FallbackFactory;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
/**
|
||||
* @author xy
|
||||
*/
|
||||
@Slf4j
|
||||
@Component
|
||||
public class RtClientFallbackFactory implements FallbackFactory<RtFeignClient> {
|
||||
@Override
|
||||
public RtFeignClient create(Throwable cause) {
|
||||
//判断抛出异常是否为解码器抛出的业务异常
|
||||
Enum<?> exceptionEnum = CommonResponseEnum.SERVICE_FALLBACK;
|
||||
if (cause.getCause() instanceof BusinessException) {
|
||||
BusinessException businessException = (BusinessException) cause.getCause();
|
||||
}
|
||||
Enum<?> finalExceptionEnum = exceptionEnum;
|
||||
return new RtFeignClient() {
|
||||
|
||||
@Override
|
||||
public HttpResult<String> analysis(AppAutoDataMessage appAutoDataMessage) {
|
||||
log.error("{}异常,降级处理,异常为:{}","实时数据解析",cause.toString());
|
||||
throw new BusinessException(finalExceptionEnum);
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package com.njcn.rt.enums;
|
||||
|
||||
import lombok.Getter;
|
||||
|
||||
/**
|
||||
* @author xuyang
|
||||
* @version 1.0.0
|
||||
* @date 2023年04月17日 10:50
|
||||
*/
|
||||
@Getter
|
||||
public enum RtResponseEnum {
|
||||
|
||||
/**
|
||||
* A1001 ~ A1099 用于实时数据模块的枚举
|
||||
* <p>
|
||||
*/
|
||||
RT_ERROR("A10001","实时数据模块错误"),
|
||||
|
||||
DATA_ARRAY_NULL("A10002","详细数据为空"),
|
||||
AUTO_DATA_NULL("A10002","上送数据为空"),
|
||||
DICT_NULL("A10002","字典数据为空"),
|
||||
LINE_NULL("A10002","监测点为空"),
|
||||
|
||||
ARRAY_DATA_NOT_MATCH("A10003","上送数据与模板匹配失败"),
|
||||
|
||||
;
|
||||
|
||||
private final String code;
|
||||
|
||||
private final String message;
|
||||
|
||||
RtResponseEnum(String code, String message) {
|
||||
this.code = code;
|
||||
this.message = message;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,200 @@
|
||||
package com.njcn.rt.pojo.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* 实时数据-基础数据
|
||||
*/
|
||||
@Data
|
||||
public class BaseRealDataSet implements Serializable {
|
||||
|
||||
@ApiModelProperty("监测点id")
|
||||
private String lineId;
|
||||
|
||||
@ApiModelProperty("数据时间")
|
||||
private String dataTime;
|
||||
|
||||
@ApiModelProperty("pt")
|
||||
private Float pt;
|
||||
|
||||
@ApiModelProperty("ct")
|
||||
private Float ct;
|
||||
|
||||
@ApiModelProperty("数据类型 Primary-一次值 Secondary-二次值")
|
||||
private String dataLevel;
|
||||
|
||||
@ApiModelProperty("频率")
|
||||
private Float freq;
|
||||
|
||||
@ApiModelProperty("频率偏差")
|
||||
private Float freqDev;
|
||||
|
||||
@ApiModelProperty("A相-电压有效值")
|
||||
private Float vRmsA;
|
||||
|
||||
@ApiModelProperty("B相-电压有效值")
|
||||
private Float vRmsB;
|
||||
|
||||
@ApiModelProperty("C相-电压有效值")
|
||||
private Float vRmsC;
|
||||
|
||||
// @ApiModelProperty("A相-相电压有效值")
|
||||
// private Float vuRmsA;
|
||||
//
|
||||
// @ApiModelProperty("B相-相电压有效值")
|
||||
// private Float vuRmsB;
|
||||
//
|
||||
// @ApiModelProperty("C相-相电压有效值")
|
||||
// private Float vuRmsC;
|
||||
//
|
||||
// @ApiModelProperty("A相-线电压有效值")
|
||||
// private Float vlRmsA;
|
||||
//
|
||||
// @ApiModelProperty("B相-线电压有效值")
|
||||
// private Float vlRmsB;
|
||||
//
|
||||
// @ApiModelProperty("C相-线电压有效值")
|
||||
// private Float vlRmsC;
|
||||
|
||||
@ApiModelProperty("A相-基波电压幅值")
|
||||
private Float v1A;
|
||||
|
||||
@ApiModelProperty("B相-基波电压幅值")
|
||||
private Float v1B;
|
||||
|
||||
@ApiModelProperty("C相-基波电压幅值")
|
||||
private Float v1C;
|
||||
|
||||
@ApiModelProperty("A相-电流有效值")
|
||||
private Float iRmsA;
|
||||
|
||||
@ApiModelProperty("B相-电流有效值")
|
||||
private Float iRmsB;
|
||||
|
||||
@ApiModelProperty("C相-电流有效值")
|
||||
private Float iRmsC;
|
||||
|
||||
@ApiModelProperty("A相-基波电流幅值")
|
||||
private Float i1A;
|
||||
|
||||
@ApiModelProperty("B相-基波电流幅值")
|
||||
private Float i1B;
|
||||
|
||||
@ApiModelProperty("C相-基波电流幅值")
|
||||
private Float i1C;
|
||||
|
||||
@ApiModelProperty("A相-电压偏差")
|
||||
private Float vDevA;
|
||||
|
||||
@ApiModelProperty("B相-电压偏差")
|
||||
private Float vDevB;
|
||||
|
||||
@ApiModelProperty("C相-电压偏差")
|
||||
private Float vDevC;
|
||||
|
||||
@ApiModelProperty("A相-基波电压相位")
|
||||
private Float v1AngA;
|
||||
|
||||
@ApiModelProperty("B相-基波电压相位")
|
||||
private Float v1AngB;
|
||||
|
||||
@ApiModelProperty("C相-基波电压相位")
|
||||
private Float v1AngC;
|
||||
|
||||
@ApiModelProperty("A相-基波电流相位")
|
||||
private Float i1AngA;
|
||||
|
||||
@ApiModelProperty("B相-基波电流相位")
|
||||
private Float i1AngB;
|
||||
|
||||
@ApiModelProperty("C相-基波电流相位")
|
||||
private Float i1AngC;
|
||||
|
||||
@ApiModelProperty("A相-电压总谐波畸变率")
|
||||
private Float vThdA;
|
||||
|
||||
@ApiModelProperty("B相-电压总谐波畸变率")
|
||||
private Float vThdB;
|
||||
|
||||
@ApiModelProperty("C相-电压总谐波畸变率")
|
||||
private Float vThdC;
|
||||
|
||||
@ApiModelProperty("A相-电流总谐波畸变率")
|
||||
private Float iThdA;
|
||||
|
||||
@ApiModelProperty("B相-电流总谐波畸变率")
|
||||
private Float iThdB;
|
||||
|
||||
@ApiModelProperty("C相-电流总谐波畸变率")
|
||||
private Float iThdC;
|
||||
|
||||
@ApiModelProperty("电压不平衡度")
|
||||
private Float vUnbalance;
|
||||
|
||||
@ApiModelProperty("电流不平衡度")
|
||||
private Float iUnbalance;
|
||||
|
||||
@ApiModelProperty("A相-有功功率")
|
||||
private Float pA;
|
||||
|
||||
@ApiModelProperty("B相-有功功率")
|
||||
private Float pB;
|
||||
|
||||
@ApiModelProperty("C相-有功功率")
|
||||
private Float pC;
|
||||
|
||||
@ApiModelProperty("A相-无功功率")
|
||||
private Float qA;
|
||||
|
||||
@ApiModelProperty("B相-无功功率")
|
||||
private Float qB;
|
||||
|
||||
@ApiModelProperty("C相-无功功率")
|
||||
private Float qC;
|
||||
|
||||
@ApiModelProperty("A相-视在功率")
|
||||
private Float sA;
|
||||
|
||||
@ApiModelProperty("B相-视在功率")
|
||||
private Float sB;
|
||||
|
||||
@ApiModelProperty("C相-视在功率")
|
||||
private Float sC;
|
||||
|
||||
@ApiModelProperty("A相-功率因数")
|
||||
private Float pfA;
|
||||
|
||||
@ApiModelProperty("B相-功率因数")
|
||||
private Float pfB;
|
||||
|
||||
@ApiModelProperty("C相-功率因数")
|
||||
private Float pfC;
|
||||
|
||||
@ApiModelProperty("A相-基波功率因数")
|
||||
private Float dpfA;
|
||||
|
||||
@ApiModelProperty("B相-基波功率因数")
|
||||
private Float dpfB;
|
||||
|
||||
@ApiModelProperty("C相-基波功率因数")
|
||||
private Float dpfC;
|
||||
|
||||
@ApiModelProperty("总-有功功率")
|
||||
private Float pTot;
|
||||
|
||||
@ApiModelProperty("总-无功功率")
|
||||
private Float qTot;
|
||||
|
||||
@ApiModelProperty("总-视在功率")
|
||||
private Float sTot;
|
||||
|
||||
@ApiModelProperty("总-功率因数")
|
||||
private Float pfTot;
|
||||
|
||||
@ApiModelProperty("总-基波功率因数")
|
||||
private Float dpfTot;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package com.njcn.rt.pojo.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* @author xy
|
||||
*/
|
||||
@Data
|
||||
public class HarmData implements Serializable {
|
||||
|
||||
@ApiModelProperty("指标名称")
|
||||
private String harmName;
|
||||
|
||||
@ApiModelProperty("相别")
|
||||
private String phase;
|
||||
|
||||
@ApiModelProperty("数据")
|
||||
private Float data;
|
||||
|
||||
@ApiModelProperty("排序")
|
||||
private Integer sort;
|
||||
}
|
||||
@@ -0,0 +1,81 @@
|
||||
package com.njcn.rt.pojo.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* 实时数据-谐波数据
|
||||
* @author xy
|
||||
*/
|
||||
@Data
|
||||
public class HarmRealDataSet implements Serializable {
|
||||
|
||||
@ApiModelProperty("监测点id")
|
||||
private String lineId;
|
||||
|
||||
@ApiModelProperty("数据时间")
|
||||
private String dataTime;
|
||||
|
||||
@ApiModelProperty("pt")
|
||||
private Float pt;
|
||||
|
||||
@ApiModelProperty("ct")
|
||||
private Float ct;
|
||||
|
||||
@ApiModelProperty("数据类型 Primary-一次值 Secondary-二次值")
|
||||
private String dataLevel;
|
||||
|
||||
private Float data1;
|
||||
private Float data2;
|
||||
private Float data3;
|
||||
private Float data4;
|
||||
private Float data5;
|
||||
private Float data6;
|
||||
private Float data7;
|
||||
private Float data8;
|
||||
private Float data9;
|
||||
private Float data10;
|
||||
private Float data11;
|
||||
private Float data12;
|
||||
private Float data13;
|
||||
private Float data14;
|
||||
private Float data15;
|
||||
private Float data16;
|
||||
private Float data17;
|
||||
private Float data18;
|
||||
private Float data19;
|
||||
private Float data20;
|
||||
private Float data21;
|
||||
private Float data22;
|
||||
private Float data23;
|
||||
private Float data24;
|
||||
private Float data25;
|
||||
private Float data26;
|
||||
private Float data27;
|
||||
private Float data28;
|
||||
private Float data29;
|
||||
private Float data30;
|
||||
private Float data31;
|
||||
private Float data32;
|
||||
private Float data33;
|
||||
private Float data34;
|
||||
private Float data35;
|
||||
private Float data36;
|
||||
private Float data37;
|
||||
private Float data38;
|
||||
private Float data39;
|
||||
private Float data40;
|
||||
private Float data41;
|
||||
private Float data42;
|
||||
private Float data43;
|
||||
private Float data44;
|
||||
private Float data45;
|
||||
private Float data46;
|
||||
private Float data47;
|
||||
private Float data48;
|
||||
private Float data49;
|
||||
private Float data50;
|
||||
|
||||
}
|
||||
@@ -40,6 +40,27 @@
|
||||
<artifactId>common-db</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>common-mq</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>rt-api</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>cs-device-api</artifactId>
|
||||
<version>${project.version}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.njcn</groupId>
|
||||
<artifactId>access-api</artifactId>
|
||||
<version>1.0.0</version>
|
||||
<scope>compile</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
|
||||
@@ -5,6 +5,7 @@ import org.mybatis.spring.annotation.MapperScan;
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
import org.springframework.cloud.openfeign.EnableFeignClients;
|
||||
import org.springframework.context.annotation.DependsOn;
|
||||
|
||||
|
||||
/**
|
||||
@@ -13,6 +14,7 @@ import org.springframework.cloud.openfeign.EnableFeignClients;
|
||||
* @date 2021年12月09日 20:59
|
||||
*/
|
||||
@Slf4j
|
||||
@DependsOn("proxyMapperRegister")
|
||||
@MapperScan("com.njcn.**.mapper")
|
||||
@EnableFeignClients(basePackages = "com.njcn")
|
||||
@SpringBootApplication(scanBasePackages = "com.njcn")
|
||||
|
||||
@@ -5,6 +5,8 @@ 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.mq.message.AppAutoDataMessage;
|
||||
import com.njcn.rt.service.IRtService;
|
||||
import com.njcn.web.controller.BaseController;
|
||||
import io.swagger.annotations.Api;
|
||||
import io.swagger.annotations.ApiImplicitParam;
|
||||
@@ -31,16 +33,17 @@ import org.springframework.web.bind.annotation.RestController;
|
||||
@AllArgsConstructor
|
||||
public class RtController extends BaseController {
|
||||
|
||||
// @OperateInfo(info = LogEnum.BUSINESS_COMMON)
|
||||
// @PostMapping("/analysis")
|
||||
// @ApiOperation("数据解析")
|
||||
// @ApiImplicitParam(name = "csDataEffectiveAddParm", value = "新增app数据有效性表参数", required = true)
|
||||
// public HttpResult<Boolean> addDataEffective(@RequestBody @Validated CsDataEffectiveAddParm csDataEffectiveAddParm){
|
||||
// String methodDescribe = getMethodDescribe("addDataEffective");
|
||||
//
|
||||
// boolean save = csDataEffectiveService.add (csDataEffectiveAddParm);
|
||||
// return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, save, methodDescribe);
|
||||
// }
|
||||
private final IRtService rtService;
|
||||
|
||||
@OperateInfo(info = LogEnum.BUSINESS_COMMON)
|
||||
@PostMapping("/rtAnalysis")
|
||||
@ApiOperation("实时数据解析")
|
||||
@ApiImplicitParam(name = "appAutoDataMessage", value = "数据实体", required = true)
|
||||
public HttpResult<String> analysis(@RequestBody @Validated AppAutoDataMessage appAutoDataMessage){
|
||||
String methodDescribe = getMethodDescribe("analysis");
|
||||
rtService.analysis(appAutoDataMessage);
|
||||
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, null, methodDescribe);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,11 @@
|
||||
package com.njcn.rt.service;
|
||||
|
||||
import com.njcn.mq.message.AppAutoDataMessage;
|
||||
|
||||
/**
|
||||
* @author xy
|
||||
*/
|
||||
public interface IRtService {
|
||||
|
||||
void analysis(AppAutoDataMessage appAutoDataMessage);
|
||||
}
|
||||
@@ -0,0 +1,275 @@
|
||||
package com.njcn.rt.service.impl;
|
||||
|
||||
import cn.hutool.core.collection.CollectionUtil;
|
||||
import com.alibaba.nacos.shaded.com.google.gson.Gson;
|
||||
import com.github.tocrhz.mqtt.publisher.MqttPublisher;
|
||||
import com.njcn.access.utils.ChannelObjectUtil;
|
||||
import com.njcn.common.pojo.exception.BusinessException;
|
||||
import com.njcn.common.utils.PubUtils;
|
||||
import com.njcn.csdevice.api.CsLineFeignClient;
|
||||
import com.njcn.csdevice.api.DataArrayFeignClient;
|
||||
import com.njcn.csdevice.api.DataSetFeignClient;
|
||||
import com.njcn.csdevice.pojo.po.CsDataArray;
|
||||
import com.njcn.csdevice.pojo.po.CsDataSet;
|
||||
import com.njcn.csdevice.pojo.po.CsLinePO;
|
||||
import com.njcn.mq.message.AppAutoDataMessage;
|
||||
import com.njcn.redis.utils.RedisUtil;
|
||||
import com.njcn.rt.enums.RtResponseEnum;
|
||||
import com.njcn.rt.pojo.dto.BaseRealDataSet;
|
||||
import com.njcn.rt.pojo.dto.HarmData;
|
||||
import com.njcn.rt.pojo.dto.HarmRealDataSet;
|
||||
import com.njcn.rt.service.IRtService;
|
||||
import com.njcn.web.utils.FloatUtils;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.time.Instant;
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.ZoneId;
|
||||
import java.time.format.DateTimeFormatter;
|
||||
import java.util.*;
|
||||
import java.util.function.BinaryOperator;
|
||||
import java.util.function.Function;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* @author xy
|
||||
*/
|
||||
@Service
|
||||
@RequiredArgsConstructor
|
||||
public class RtServiceImpl implements IRtService {
|
||||
|
||||
private final CsLineFeignClient csLineFeignClient;
|
||||
private final DataSetFeignClient dataSetFeignClient;
|
||||
private final DataArrayFeignClient dataArrayFeignClient;
|
||||
private final RedisUtil redisUtil;
|
||||
private final ChannelObjectUtil channelObjectUtil;
|
||||
private final MqttPublisher publisher;
|
||||
|
||||
@Override
|
||||
public void analysis(AppAutoDataMessage appAutoDataMessage) {
|
||||
List<CsDataArray> dataArrayList;
|
||||
//监测点id
|
||||
String lineId = appAutoDataMessage.getId() + appAutoDataMessage.getMsg().getClDid();
|
||||
//获取监测点基础信息
|
||||
CsLinePO po = csLineFeignClient.getById(lineId).getData();
|
||||
//获取数据集 dataSet
|
||||
Integer idx = appAutoDataMessage.getMsg().getDsNameIdx();
|
||||
CsDataSet dataSet = dataSetFeignClient.getDataSetByIdx(po.getDataModelId(),idx).getData();
|
||||
//根据数据集获取指标 dataArray
|
||||
//实时数据数据集不区分最大最小类型,因此数据集取平均值用于解析
|
||||
String key = "BaseRealData:" + lineId + idx;
|
||||
Object object = redisUtil.getObjectByKey(key);
|
||||
if (Objects.isNull(object)){
|
||||
dataArrayList = saveBaseRealDataSet(key,dataSet.getId());
|
||||
} else {
|
||||
dataArrayList = channelObjectUtil.objectToList(object,CsDataArray.class);
|
||||
}
|
||||
//根据dataArray解析数据
|
||||
AppAutoDataMessage.DataArray item = appAutoDataMessage.getMsg().getDataArray().get(0);
|
||||
//fixme 这边先根据数据集的名称来返回对应实体,这边感觉不太合适,后期有好方案再调整
|
||||
//基础数据
|
||||
if (Objects.equals(dataSet.getName(),"Ds$Pqd$Rt$Basic$01")) {
|
||||
BaseRealDataSet baseRealDataSet = assembleData(dataArrayList,item,po.getConType());
|
||||
baseRealDataSet.setLineId(lineId);
|
||||
baseRealDataSet.setPt(po.getPtRatio().floatValue());
|
||||
baseRealDataSet.setCt(po.getCtRatio().floatValue());
|
||||
baseRealDataSet.setDataLevel(dataSet.getDataLevel());
|
||||
long timestamp = item.getDataTimeSec() - 8*3600;
|
||||
baseRealDataSet.setDataTime(getTime(timestamp));
|
||||
publisher.send("/Web/RealData/" + lineId, new Gson().toJson(baseRealDataSet), 1, false);
|
||||
}
|
||||
//fixme 目前实时数据只有基础数据和谐波数据,后期拓展,这边需要再判断
|
||||
else {
|
||||
HarmRealDataSet harmRealDataSet = harmData(dataArrayList,item);
|
||||
harmRealDataSet.setLineId(lineId);
|
||||
harmRealDataSet.setPt(po.getPtRatio().floatValue());
|
||||
harmRealDataSet.setCt(po.getCtRatio().floatValue());
|
||||
harmRealDataSet.setDataLevel(dataSet.getDataLevel());
|
||||
long timestamp = item.getDataTimeSec() - 8*3600;
|
||||
harmRealDataSet.setDataTime(getTime(timestamp));
|
||||
publisher.send("/Web/RealData/" + lineId, new Gson().toJson(harmRealDataSet), 1, false);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 时间处理
|
||||
*/
|
||||
public String getTime(long timestamp) {
|
||||
Instant instant = Instant.ofEpochSecond(timestamp);
|
||||
LocalDateTime dateTime = LocalDateTime.ofInstant(instant, ZoneId.systemDefault());
|
||||
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
|
||||
return dateTime.format(formatter);
|
||||
}
|
||||
|
||||
/**
|
||||
* 缓存实时数据数据集
|
||||
* @param key
|
||||
* @param dataSetId
|
||||
* @return
|
||||
*/
|
||||
public List<CsDataArray> saveBaseRealDataSet(String key, String dataSetId) {
|
||||
List<CsDataArray> dataArrays = dataArrayFeignClient.getArrayBySet(dataSetId).getData();
|
||||
List<CsDataArray> dataArrayList = dataArrays.stream().filter(item->Objects.equals(item.getStatMethod(),"avg")).collect(Collectors.toList());
|
||||
redisUtil.saveByKeyWithExpire(key,dataArrayList,600L);
|
||||
return dataArrayList;
|
||||
}
|
||||
|
||||
/**
|
||||
* 数据解码
|
||||
* @return
|
||||
*/
|
||||
public Map<String,Float> getData(List<CsDataArray> dataArrayList,AppAutoDataMessage.DataArray dataArray) {
|
||||
Map<String,Float> dataMap = new LinkedHashMap<>();
|
||||
//解码
|
||||
List<Float> floats = PubUtils.byteArrayToFloatList(Base64.getDecoder().decode(dataArray.getData()));
|
||||
if (CollectionUtil.isEmpty(floats)){
|
||||
throw new BusinessException(RtResponseEnum.AUTO_DATA_NULL);
|
||||
}
|
||||
//校验模板和解码数据数量能否对应上
|
||||
if (!Objects.equals(dataArrayList.size(),floats.size())){
|
||||
throw new BusinessException(RtResponseEnum.ARRAY_DATA_NOT_MATCH);
|
||||
}
|
||||
for (int i = 0; i < dataArrayList.size(); i++) {
|
||||
dataMap.put(dataArrayList.get(i).getName() + dataArrayList.get(i).getPhase(),floats.get(i));
|
||||
}
|
||||
return dataMap;
|
||||
}
|
||||
|
||||
public BaseRealDataSet assembleData(List<CsDataArray> dataArrayList,AppAutoDataMessage.DataArray dataArray,Integer conType) {
|
||||
Map<String,Float> dataMap = getData(dataArrayList,dataArray);
|
||||
return channelData(dataMap,conType);
|
||||
}
|
||||
|
||||
public BaseRealDataSet channelData(Map<String,Float> map,Integer conType) {
|
||||
BaseRealDataSet baseRealDataSet = new BaseRealDataSet();
|
||||
//频率
|
||||
baseRealDataSet.setFreq(FloatUtils.get2Float(map.get("Pq_FreqM")));
|
||||
//频率偏差
|
||||
baseRealDataSet.setFreqDev(FloatUtils.get2Float(map.get("Pq_FreqDevM")));
|
||||
//判断监测点的接线方式,不同接线方式电压有效值取值不同
|
||||
//星型-相电压 角形、V型-线电压
|
||||
//电压有效值
|
||||
if (conType == 0) {
|
||||
baseRealDataSet.setVRmsA(FloatUtils.get2Float(map.get("Pq_RmsUA")));
|
||||
baseRealDataSet.setVRmsB(FloatUtils.get2Float(map.get("Pq_RmsUB")));
|
||||
baseRealDataSet.setVRmsC(FloatUtils.get2Float(map.get("Pq_RmsUC")));
|
||||
} else {
|
||||
baseRealDataSet.setVRmsA(FloatUtils.get2Float(map.get("Pq_RmsLUAB")));
|
||||
baseRealDataSet.setVRmsB(FloatUtils.get2Float(map.get("Pq_RmsLUBC")));
|
||||
baseRealDataSet.setVRmsC(FloatUtils.get2Float(map.get("Pq_RmsLUCA")));
|
||||
}
|
||||
//基波电压幅值
|
||||
baseRealDataSet.setV1A(FloatUtils.get2Float(map.get("Pq_RmsFundUA")));
|
||||
baseRealDataSet.setV1B(FloatUtils.get2Float(map.get("Pq_RmsFundUB")));
|
||||
baseRealDataSet.setV1C(FloatUtils.get2Float(map.get("Pq_RmsFundUC")));
|
||||
//电流有效值
|
||||
baseRealDataSet.setIRmsA(FloatUtils.get2Float(map.get("Pq_RmsIA")));
|
||||
baseRealDataSet.setIRmsB(FloatUtils.get2Float(map.get("Pq_RmsIB")));
|
||||
baseRealDataSet.setIRmsC(FloatUtils.get2Float(map.get("Pq_RmsIC")));
|
||||
//基波电流幅值
|
||||
baseRealDataSet.setI1A(FloatUtils.get2Float(map.get("Pq_RmsFundIA")));
|
||||
baseRealDataSet.setI1B(FloatUtils.get2Float(map.get("Pq_RmsFundIB")));
|
||||
baseRealDataSet.setI1C(FloatUtils.get2Float(map.get("Pq_RmsFundIC")));
|
||||
//电压偏差
|
||||
baseRealDataSet.setVDevA(FloatUtils.get2Float(map.get("Pq_UDevA")));
|
||||
baseRealDataSet.setVDevB(FloatUtils.get2Float(map.get("Pq_UDevB")));
|
||||
baseRealDataSet.setVDevC(FloatUtils.get2Float(map.get("Pq_UDevC")));
|
||||
//基波电压相位
|
||||
baseRealDataSet.setV1AngA(FloatUtils.get2Float(map.get("Pq_FundUAngA")));
|
||||
baseRealDataSet.setV1AngB(FloatUtils.get2Float(map.get("Pq_FundUAngB")));
|
||||
baseRealDataSet.setV1AngC(FloatUtils.get2Float(map.get("Pq_FundUAngC")));
|
||||
//基波电流相位
|
||||
baseRealDataSet.setI1AngA(FloatUtils.get2Float(map.get("Pq_FundIAngA")));
|
||||
baseRealDataSet.setI1AngB(FloatUtils.get2Float(map.get("Pq_FundIAngB")));
|
||||
baseRealDataSet.setI1AngC(FloatUtils.get2Float(map.get("Pq_FundIAngC")));
|
||||
//电压总谐波畸变率
|
||||
baseRealDataSet.setVThdA(FloatUtils.get2Float(map.get("Pq_ThdUA")));
|
||||
baseRealDataSet.setVThdB(FloatUtils.get2Float(map.get("Pq_ThdUB")));
|
||||
baseRealDataSet.setVThdC(FloatUtils.get2Float(map.get("Pq_ThdUC")));
|
||||
//电流总谐波畸变率
|
||||
baseRealDataSet.setIThdA(FloatUtils.get2Float(map.get("Pq_ThdIA")));
|
||||
baseRealDataSet.setIThdB(FloatUtils.get2Float(map.get("Pq_ThdIB")));
|
||||
baseRealDataSet.setIThdC(FloatUtils.get2Float(map.get("Pq_ThdIC")));
|
||||
//电压不平衡度
|
||||
baseRealDataSet.setVUnbalance(FloatUtils.get2Float(map.get("Pq_UnbalNegUM")));
|
||||
//电流不平衡度
|
||||
baseRealDataSet.setIUnbalance(FloatUtils.get2Float(map.get("Pq_UnbalNegIM")));
|
||||
//有功功率
|
||||
baseRealDataSet.setPA(FloatUtils.get2Float(map.get("Pq_PA")));
|
||||
baseRealDataSet.setPB(FloatUtils.get2Float(map.get("Pq_PB")));
|
||||
baseRealDataSet.setPC(FloatUtils.get2Float(map.get("Pq_PC")));
|
||||
baseRealDataSet.setPTot(FloatUtils.get2Float(map.get("Pq_TotPM")));
|
||||
//无功功率
|
||||
baseRealDataSet.setQA(FloatUtils.get2Float(map.get("Pq_QA")));
|
||||
baseRealDataSet.setQB(FloatUtils.get2Float(map.get("Pq_QB")));
|
||||
baseRealDataSet.setQC(FloatUtils.get2Float(map.get("Pq_QC")));
|
||||
baseRealDataSet.setQTot(FloatUtils.get2Float(map.get("Pq_TotQM")));
|
||||
//视在功率
|
||||
baseRealDataSet.setSA(FloatUtils.get2Float(map.get("Pq_SA")));
|
||||
baseRealDataSet.setSB(FloatUtils.get2Float(map.get("Pq_SB")));
|
||||
baseRealDataSet.setSC(FloatUtils.get2Float(map.get("Pq_SC")));
|
||||
baseRealDataSet.setSTot(FloatUtils.get2Float(map.get("Pq_TotSM")));
|
||||
//功率因数
|
||||
baseRealDataSet.setPfA(FloatUtils.get2Float(map.get("Pq_PFA")));
|
||||
baseRealDataSet.setPfB(FloatUtils.get2Float(map.get("Pq_PFB")));
|
||||
baseRealDataSet.setPfC(FloatUtils.get2Float(map.get("Pq_PFC")));
|
||||
baseRealDataSet.setPfTot(FloatUtils.get2Float(map.get("Pq_TotPFM")));
|
||||
//基波功率因数
|
||||
baseRealDataSet.setDpfA(FloatUtils.get2Float(map.get("Pq_DPFA")));
|
||||
baseRealDataSet.setDpfB(FloatUtils.get2Float(map.get("Pq_DPFB")));
|
||||
baseRealDataSet.setDpfC(FloatUtils.get2Float(map.get("Pq_DPFC")));
|
||||
baseRealDataSet.setDpfTot(FloatUtils.get2Float(map.get("Pq_TotDPFM")));
|
||||
return baseRealDataSet;
|
||||
}
|
||||
|
||||
public HarmRealDataSet harmData(List<CsDataArray> dataArrayList, AppAutoDataMessage.DataArray dataArray) {
|
||||
HarmRealDataSet harmRealDataSet = new HarmRealDataSet();
|
||||
List<HarmData> harmDataList = new ArrayList<>();
|
||||
//解码
|
||||
List<Float> floats = PubUtils.byteArrayToFloatList(Base64.getDecoder().decode(dataArray.getData()));
|
||||
if (CollectionUtil.isEmpty(floats)){
|
||||
throw new BusinessException(RtResponseEnum.AUTO_DATA_NULL);
|
||||
}
|
||||
//校验模板和解码数据数量能否对应上
|
||||
if (!Objects.equals(dataArrayList.size(),floats.size())){
|
||||
throw new BusinessException(RtResponseEnum.ARRAY_DATA_NOT_MATCH);
|
||||
}
|
||||
for (int i = 0; i < dataArrayList.size(); i++) {
|
||||
HarmData harmData = new HarmData();
|
||||
harmData.setHarmName(dataArrayList.get(i).getName());
|
||||
harmData.setPhase(dataArrayList.get(i).getPhase());
|
||||
harmData.setSort(dataArrayList.get(i).getSort());
|
||||
harmData.setData(floats.get(i));
|
||||
harmDataList.add(harmData);
|
||||
}
|
||||
//根据名称分组,然后在不同相别的数据中取最大值
|
||||
List<HarmData> maxDataList = new ArrayList<>(harmDataList.stream()
|
||||
.collect(Collectors.toMap(
|
||||
HarmData::getHarmName,
|
||||
Function.identity(),
|
||||
BinaryOperator.maxBy(Comparator.comparingDouble(HarmData::getData))
|
||||
))
|
||||
.values());
|
||||
//通过反射将数据赋值
|
||||
Class<?> clazz = HarmRealDataSet.class;
|
||||
maxDataList.forEach(item->{
|
||||
if (Objects.equals(item.getHarmName(),"Pq_RmsFundI") || Objects.equals(item.getHarmName(),"Pq_RmsFundU")) {
|
||||
harmRealDataSet.setData1(FloatUtils.get2Float(item.getData()));
|
||||
} else {
|
||||
String numberStr = item.getHarmName().substring(item.getHarmName().lastIndexOf('_') + 1);
|
||||
String fieldName = "data" + numberStr;
|
||||
try {
|
||||
Field field = clazz.getDeclaredField(fieldName);
|
||||
field.setAccessible(true);
|
||||
field.set(harmRealDataSet,FloatUtils.get2Float(item.getData()));
|
||||
} catch (Exception e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
});
|
||||
return harmRealDataSet;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user