| | |
| | | if (StringUtils.isNotBlank(entity.getCurCos())) { |
| | | points.add(entity.getCurCos()); |
| | | } |
| | | log.info("points=" + points); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | log.info("pointsRealValue=" + pointsRealValue); |
| | | if (pointsRealValue.get(entity.getCurA()) != null) { |
| | | powerNetFactorDTO.setCurA(new BigDecimal(pointsRealValue.get(entity.getCurA()).toString())); |
| | | } |
| | |
| | | } |
| | | } catch (Exception ex) { |
| | | log.info(entity.getNodeName() + "获取当前值异常" + ex.getMessage()); |
| | | ex.printStackTrace(); |
| | | } |
| | | |
| | | try { |
| | |
| | | } |
| | | } catch (Exception ex) { |
| | | log.info(entity.getNodeName() + "获取预测值异常," + ex.getMessage()); |
| | | ex.printStackTrace(); |
| | | } |
| | | |
| | | // 设置电流状态 |
| | | powerNetFactorDTO.setStatus(0); |
| | | if (powerNetFactorDTO.getCurA() != null) { |
| | | BigDecimal curA = powerNetFactorDTO.getCurA(); |
| | | if (entity.getLimitL() != null && curA.compareTo(entity.getLimitL()) < 0) { |
| | | powerNetFactorDTO.setStatus(1); |
| | | } else if (entity.getLimitH() != null && curA.compareTo(entity.getLimitH()) > 0) { |
| | | powerNetFactorDTO.setStatus(1); |
| | | } else { |
| | | powerNetFactorDTO.setStatus(0); |
| | | } |
| | | } |
| | | |
| | | // 设置功率因数状态 |
| | | powerNetFactorDTO.setQstatus(0); |
| | | if (cosFlag && powerNetFactorDTO.getCurCos() != null) { |
| | | BigDecimal curCos = powerNetFactorDTO.getCurCos(); |
| | | if (entity.getCosLimitL() != null && curCos.compareTo(entity.getCosLimitL()) < 0) { |
| | | powerNetFactorDTO.setQStatus(1); |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } else if (entity.getCosLimitH() != null && curCos.compareTo(entity.getCosLimitH()) > 0) { |
| | | powerNetFactorDTO.setQStatus(1); |
| | | } else { |
| | | powerNetFactorDTO.setQStatus(0); |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } |
| | | } |
| | | |
| | | // 设置有功预警状态 |
| | | powerNetFactorDTO.setPstatus(0); |
| | | if (powerNetFactorDTO.getCurP() != null) { |
| | | BigDecimal curP = powerNetFactorDTO.getCurP(); |
| | | if (entity.getPLimitL() != null && curP.compareTo(entity.getPLimitL()) < 0) { |
| | | powerNetFactorDTO.setPStatus(1); |
| | | powerNetFactorDTO.setPstatus(1); |
| | | } else if (entity.getPLimitH() != null && curP.compareTo(entity.getPLimitH()) > 0) { |
| | | powerNetFactorDTO.setPStatus(1); |
| | | } else { |
| | | powerNetFactorDTO.setPStatus(0); |
| | | powerNetFactorDTO.setPstatus(1); |
| | | } |
| | | } |
| | | |
| | | // 设置无功预警状态 |
| | | powerNetFactorDTO.setQstatus(0); |
| | | if (powerNetFactorDTO.getCurQ() != null) { |
| | | BigDecimal curQ = powerNetFactorDTO.getCurQ(); |
| | | if (entity.getQLimitL() != null && curQ.compareTo(entity.getQLimitL()) < 0) { |
| | | powerNetFactorDTO.setQStatus(1); |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } else if (entity.getQLimitH() != null && curQ.compareTo(entity.getQLimitH()) > 0) { |
| | | powerNetFactorDTO.setQStatus(1); |
| | | } else { |
| | | powerNetFactorDTO.setQStatus(0); |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } |
| | | } |
| | | result.add(powerNetFactorDTO); |
| | | } |
| | | return success(result); |
| | | } |
| | |
| | | } |
| | | |
| | | @PostMapping("/demand-query/list") |
| | | @Operation(summary = "负荷移植-功率因数查询") |
| | | public CommonResult<List<PowerNetDropdownDTO>> getDemandDropdownList(@RequestBody PowerDemandQueryDTO queryDto) { |
| | | List<PowerNetDropdownDTO> result = new ArrayList<>(); |
| | | @Operation(summary = "负荷移植-需量值查询") |
| | | public CommonResult<List<PowerDemandQueryRespDTO>> getDemandDropdownList(@RequestBody PowerDemandQueryDTO queryDto) { |
| | | List<PowerDemandQueryRespDTO> result = new ArrayList<>(); |
| | | if (StringUtils.isBlank(queryDto.getCode())) { |
| | | log.info("code isBlank"); |
| | | return success(result); |
| | | } |
| | | log.info("code=" + queryDto.getCode()); |
| | | if (StringUtils.isBlank(queryDto.getNodeCode())) { |
| | |
| | | log.info("PowerDemandEntity is null"); |
| | | return success(result); |
| | | } |
| | | Calendar calendar = Calendar.getInstance(); |
| | | calendar.set(Calendar.MILLISECOND, 0); |
| | | calendar.set(Calendar.SECOND, 0); |
| | | Date startTime = queryDto.getStartTime(); |
| | | Date endTime = queryDto.getEndTime(); |
| | | if (endTime == null) { |
| | | endTime = calendar.getTime(); |
| | | } |
| | | if (startTime == null) { |
| | | calendar.add(Calendar.DAY_OF_YEAR, -1); |
| | | startTime = calendar.getTime(); |
| | | } |
| | | |
| | | Map<String, Object> params0 = new HashMap<>(); |
| | | params0.put("groupName", entity.getName()); |
| | | List<PowerNetDropdownEntity> list = powerNetDropdownService.list(params0); |
| | | List<String> points = list.stream().map(item -> { |
| | | return item.getCurCos(); |
| | | }).collect(Collectors.toList()); |
| | | if (queryDto.getCurCos() == null) { |
| | | List<PowerNetDropdownEntity> dropdownList = powerNetDropdownService.list(params0); |
| | | List<String> pointNos = new ArrayList<>(); |
| | | for (PowerNetDropdownEntity netDropdown : dropdownList) { |
| | | if (StringUtils.isNotBlank(netDropdown.getExt1())) { |
| | | pointNos.add(netDropdown.getExt1()); |
| | | } |
| | | } |
| | | if (StringUtils.isBlank(queryDto.getNodeCode()) || queryDto.getCurDemand() == null) { |
| | | log.info("查询当前值"); |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | if (!CollectionUtils.isEmpty(pointNos)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(pointNos); |
| | | } |
| | | for (PowerNetDropdownEntity netDropdown : list) { |
| | | PowerNetDropdownDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerNetDropdownDTO.class); |
| | | BigDecimal curCos = BigDecimal.ZERO; |
| | | if (pointsRealValue.get(netDropdown.getCurCos()) != null) { |
| | | curCos = new BigDecimal(pointsRealValue.get(netDropdown.getCurCos()).toString()); |
| | | for (PowerNetDropdownEntity netDropdown : dropdownList) { |
| | | PowerDemandQueryRespDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerDemandQueryRespDTO.class); |
| | | BigDecimal demand = null; |
| | | if (pointsRealValue.get(netDropdown.getExt1()) != null) { |
| | | demand = new BigDecimal(pointsRealValue.get(netDropdown.getExt1()).toString()); |
| | | } |
| | | dto.setCurCos(curCos); |
| | | dto.setCurDemand(demand); |
| | | dto.setDataTime(calendar.getTime()); |
| | | result.add(dto); |
| | | } |
| | | } else { |
| | |
| | | return success(result); |
| | | } |
| | | ApiPointsValueQueryDTO valueQueryDTO = new ApiPointsValueQueryDTO(); |
| | | valueQueryDTO.setPointNos(points); |
| | | Calendar calendar = Calendar.getInstance(); |
| | | calendar.set(Calendar.MILLISECOND, 0); |
| | | calendar.set(Calendar.SECOND, 0); |
| | | Date startTime = queryDto.getStartTime(); |
| | | Date endTime = queryDto.getEndTime(); |
| | | if (endTime == null) { |
| | | endTime = calendar.getTime(); |
| | | } |
| | | if (startTime == null) { |
| | | calendar.add(Calendar.DAY_OF_YEAR, -1); |
| | | startTime = calendar.getTime(); |
| | | } |
| | | valueQueryDTO.setPointNos(pointNos); |
| | | valueQueryDTO.setStart(startTime); |
| | | valueQueryDTO.setEnd(endTime); |
| | | Map<String, List<Map<String, Object>>> pointsHisValues = dataPointApi.queryPointsHistoryValue(valueQueryDTO); |
| | |
| | | ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO(); |
| | | pointValueQueryDTO.setStart(startTime); |
| | | pointValueQueryDTO.setEnd(endTime); |
| | | pointValueQueryDTO.setPointNo(powerNetDropdownEntity.getCurCos()); |
| | | pointValueQueryDTO.setPointNo(powerNetDropdownEntity.getExt1()); |
| | | List<ApiPointValueDTO> hisValue = dataPointApi.queryPointHistoryValue(pointValueQueryDTO); |
| | | if (CollectionUtils.isEmpty(hisValue)) { |
| | | log.info("hisValue is null"); |
| | |
| | | ApiPointValueDTO curValue = null; |
| | | Collections.reverse(hisValue); |
| | | for (ApiPointValueDTO valueDTO : hisValue) { |
| | | curValue = valueDTO; |
| | | if ((queryDto.getCurCos().doubleValue() - valueDTO.getV()) <= 0.0001) { |
| | | if ((queryDto.getCurDemand().doubleValue() - valueDTO.getV()) <= 0.0001) { |
| | | curValue = valueDTO; |
| | | log.info("curValue is find"); |
| | | break; |
| | | } |
| | | } |
| | | if (curValue == null) { |
| | | log.info("curValue is null"); |
| | | for (PowerNetDropdownEntity netDropdown : dropdownList){ |
| | | PowerDemandQueryRespDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerDemandQueryRespDTO.class); |
| | | if (dto.getNodeCode().equals(nodeCode)) { |
| | | dto.setCurDemand(queryDto.getCurDemand()); |
| | | } |
| | | result.add(dto); |
| | | } |
| | | return success(result); |
| | | } |
| | | log.info("curValue=" + curValue); |
| | | for (PowerNetDropdownEntity netDropdown : list) { |
| | | PowerNetDropdownDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerNetDropdownDTO.class); |
| | | for (PowerNetDropdownEntity netDropdown : dropdownList) { |
| | | PowerDemandQueryRespDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerDemandQueryRespDTO.class); |
| | | if (!CollectionUtils.isEmpty(pointsHisValues.get(netDropdown.getExt1()))) { |
| | | Map<String, BigDecimal> pointValueMap = new HashMap<>(); |
| | | pointsHisValues.get(netDropdown.getExt1()).forEach(item -> { |
| | | pointValueMap.put(item.get("time").toString(), DecimalUtil.toBigDecimal(item.get("value"))); |
| | | |
| | | if (CollectionUtils.isEmpty(pointsHisValues.get(netDropdown.getCurCos()))) { |
| | | continue; |
| | | }); |
| | | dto.setCurDemand(pointValueMap.get(DateUtils.format(curValue.getT(),DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND))); |
| | | dto.setDataTime(curValue.getT()); |
| | | } |
| | | Map<String, BigDecimal> pointValueMap = new HashMap<>(); |
| | | pointsHisValues.get(netDropdown.getCurCos()).forEach(item -> { |
| | | pointValueMap.put(item.get("time").toString(), DecimalUtil.toBigDecimal(item.get("value"))); |
| | | |
| | | }); |
| | | dto.setCurCos(pointValueMap.get(DateUtils.format(curValue.getT(),DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND))); |
| | | result.add(dto); |
| | | } |
| | | } |
| | |
| | | apiPointValueQueryDTO1.setStart(start1); |
| | | apiPointValueQueryDTO1.setEnd(new Date()); |
| | | apiPointValueQueryDTO1.setPointNo(pointNo); |
| | | List<ApiPointValueDTO> monthChartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO); |
| | | List<Double> monthValues = new ArrayList<>(); |
| | | if (CollectionUtils.isEmpty(monthChartData)) { |
| | | monthValues = monthChartData.stream().map(item -> item.getV()).collect(Collectors.toList()); |
| | | List<ApiPointValueDTO> monthChartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO1); |
| | | if (!CollectionUtils.isEmpty(monthChartData)) { |
| | | List<Double> monthValues = monthChartData.stream().map(item -> item.getV()).collect(Collectors.toList()); |
| | | powerHistoryDTO.setMax(monthValues.stream().max(Double::compareTo).get()); |
| | | powerHistoryDTO.setMin(monthValues.stream().min(Double::compareTo).get()); |
| | | } |
| | |
| | | } |
| | | |
| | | for (String code : dto.getCodeList()) { |
| | | PowerDemandEntity powerDemand = powerDemandService.getByCode(code); |
| | | if (powerDemand == null) { |
| | | PowerNetFactorQuery powerNetFactorQuery = new PowerNetFactorQuery(); |
| | | PowerDemandEntity powerDemandEntity = powerDemandService.getByCode(code); |
| | | PowerNetDropdownEntity powerNetDropdownEntity = powerNetDropdownService.getByNodeCode(code); |
| | | if (powerDemandEntity != null) { |
| | | powerNetFactorQuery.setCurP(powerDemandEntity.getActivePower()); |
| | | powerNetFactorQuery.setCurDem(powerDemandEntity.getCurDemand()); |
| | | } else if (powerNetDropdownEntity != null) { |
| | | powerNetFactorQuery.setCurP(powerNetDropdownEntity.getCurP()); |
| | | powerNetFactorQuery.setCurDem(powerNetDropdownEntity.getExt1()); |
| | | } else { |
| | | log.info("未找到code对应的数据: {}", dto.getCode()); |
| | | return success(new LinkedHashMap<>()); |
| | | continue; |
| | | } |
| | | |
| | | String queryType = dto.getQueryType().toUpperCase(); |
| | | String pointNo; |
| | | switch (queryType.toUpperCase()) { |
| | | case "D": |
| | | pointNo = powerDemand.getCurDemand(); |
| | | pointNo = powerNetFactorQuery.getCurDem(); |
| | | break; |
| | | case "P": |
| | | pointNo = powerDemand.getActivePower(); |
| | | pointNo = powerNetFactorQuery.getCurP(); |
| | | break; |
| | | default: |
| | | throw new IllegalArgumentException("不支持的queryType: " + queryType); |