| | |
| | | package com.iailab.module.ansteel.api.controller.admin; |
| | | |
| | | import cn.hutool.core.util.NumberUtil; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.iailab.framework.common.exception.enums.GlobalErrorCodeConstants; |
| | | import com.iailab.framework.common.pojo.CommonResult; |
| | | import com.iailab.framework.common.pojo.PageResult; |
| | | import com.iailab.framework.common.util.date.DateUtils; |
| | | import com.iailab.framework.common.util.object.BeanUtils; |
| | | import com.iailab.framework.common.util.object.ConvertUtils; |
| | | import com.iailab.module.ansteel.api.dto.*; |
| | | import com.iailab.module.ansteel.api.vo.PowerCapacitorHisPageReqVO; |
| | | import com.iailab.module.ansteel.api.vo.PowerMaxDemandMainPageReqVO; |
| | | import com.iailab.module.ansteel.common.utils.DecimalUtil; |
| | | import com.iailab.module.ansteel.power.entity.*; |
| | | import com.iailab.module.ansteel.power.service.*; |
| | | import com.iailab.module.data.api.point.DataPointApi; |
| | |
| | | import org.springframework.util.CollectionUtils; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.math.BigDecimal; |
| | | import java.text.ParseException; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | import static com.iailab.framework.common.pojo.CommonResult.error; |
| | | import static com.iailab.framework.common.pojo.CommonResult.success; |
| | | |
| | | /** |
| | |
| | | @Autowired |
| | | private PowerAdjustedFactorService powerAdjustedFactorService; |
| | | |
| | | @Resource |
| | | @Autowired |
| | | private DataPointApi dataPointApi; |
| | | |
| | | @Resource |
| | | @Autowired |
| | | private McsApi mcsApi; |
| | | |
| | | @Autowired |
| | | private PowerCapacitorHisService powerCapacitorHisService; |
| | | |
| | | @Autowired |
| | | private PowerCapacitorDetService powerCapacitorDetService; |
| | | |
| | | @Autowired |
| | | private PowerNetDropdownService powerNetDropdownService; |
| | | |
| | | @Autowired |
| | | private PowerVoltageStatusService powerVoltageStatusService; |
| | | |
| | | @Autowired |
| | | private PowerMaxdemandMainService powerMaxDemandMainService; |
| | | |
| | | @Autowired |
| | | private PowerMaxdemandDetService powerMaxdemandDetService; |
| | | |
| | | @Autowired |
| | | private PowerPriceMainService powerPriceMainService; |
| | | |
| | | public static final String VALUE = "value"; |
| | | |
| | | public static final String TIME = "time"; |
| | | |
| | | @GetMapping("/net-factor/list") |
| | | @Operation(summary = "功率因数-电网拓扑") |
| | | public CommonResult<List<PowerNetFactorDTO>> getPowerNetFactorList(@RequestParam Map<String, Object> params) { |
| | | log.info("功率因数电网拓扑"); |
| | | List<PowerNetFactorDTO> result = new ArrayList<>(); |
| | | List<PowerNetFactorEntity> list = powerNetFactorService.list(params); |
| | | List<PowerNetFactorDTO> result = ConvertUtils.sourceToTarget(list, PowerNetFactorDTO.class); |
| | | if (CollectionUtils.isEmpty(result)) { |
| | | if (CollectionUtils.isEmpty(list)) { |
| | | log.info("list is empty"); |
| | | return success(result); |
| | | } |
| | | Calendar calendar = Calendar.getInstance(); |
| | |
| | | calendar.set(Calendar.MINUTE, 0); |
| | | calendar.set(Calendar.HOUR_OF_DAY, 0); |
| | | |
| | | for (PowerNetFactorDTO dto : result) { |
| | | for (PowerNetFactorEntity entity : list) { |
| | | PowerNetFactorDTO powerNetFactorDTO = new PowerNetFactorDTO(); |
| | | powerNetFactorDTO.setId(entity.getId()); |
| | | powerNetFactorDTO.setGroupName(entity.getGroupName()); |
| | | powerNetFactorDTO.setNodeCode(entity.getNodeCode()); |
| | | powerNetFactorDTO.setNodeName(entity.getNodeName()); |
| | | boolean cosFlag = false; |
| | | try { |
| | | List<String> points = new ArrayList<>(); |
| | | if (StringUtils.isNotBlank(dto.getCurP())) { |
| | | points.add(dto.getCurP()); |
| | | if (StringUtils.isNotBlank(entity.getCurA())) { |
| | | points.add(entity.getCurA()); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getCurQ())) { |
| | | points.add(dto.getCurQ()); |
| | | if (StringUtils.isNotBlank(entity.getCurP())) { |
| | | points.add(entity.getCurP()); |
| | | } |
| | | if (StringUtils.isNotBlank(entity.getCurQ())) { |
| | | points.add(entity.getCurQ()); |
| | | } |
| | | if (StringUtils.isNotBlank(entity.getCurCos())) { |
| | | points.add(entity.getCurCos()); |
| | | } |
| | | log.info("points=" + points); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | if (pointsRealValue.get(dto.getCurP()) != null) { |
| | | dto.setCurP(pointsRealValue.get(dto.getCurP()).toString()); |
| | | log.info("pointsRealValue=" + pointsRealValue); |
| | | if (pointsRealValue.get(entity.getCurA()) != null) { |
| | | powerNetFactorDTO.setCurA(new BigDecimal(pointsRealValue.get(entity.getCurA()).toString())); |
| | | } |
| | | if (pointsRealValue.get(dto.getCurQ()) != null) { |
| | | dto.setCurQ(pointsRealValue.get(dto.getCurQ()).toString()); |
| | | if (pointsRealValue.get(entity.getCurP()) != null) { |
| | | powerNetFactorDTO.setCurP(new BigDecimal(pointsRealValue.get(entity.getCurP()).toString())); |
| | | } |
| | | if (pointsRealValue.get(dto.getCurCos()) != null) { |
| | | dto.setCurCos(pointsRealValue.get(dto.getCurCos()).toString()); |
| | | if (pointsRealValue.get(entity.getCurQ()) != null) { |
| | | powerNetFactorDTO.setCurQ(new BigDecimal(pointsRealValue.get(entity.getCurQ()).toString())); |
| | | } |
| | | if (pointsRealValue.get(entity.getCurCos()) != null) { |
| | | powerNetFactorDTO.setCurCos(new BigDecimal(pointsRealValue.get(entity.getCurCos()).toString())); |
| | | cosFlag = true; |
| | | } |
| | | } |
| | | } catch (Exception ex) { |
| | | log.info(dto.getNodeName() + "获取当前值异常" + ex.getMessage()); |
| | | log.info(entity.getNodeName() + "获取当前值异常" + ex.getMessage()); |
| | | ex.printStackTrace(); |
| | | } |
| | | |
| | | try { |
| | | PredictLastValueReqVO reqVO = new PredictLastValueReqVO(); |
| | | reqVO.setPredictTime(calendar.getTime()); |
| | | List<String[]> itemNos = new ArrayList<>(); |
| | | if (StringUtils.isNotBlank(dto.getPreP())) { |
| | | itemNos.add(dto.getPreP().split(",")); |
| | | if (StringUtils.isNotBlank(entity.getPreP())) { |
| | | itemNos.add(entity.getPreP().split(",")); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getPreQ())) { |
| | | itemNos.add(dto.getPreQ().split(",")); |
| | | if (StringUtils.isNotBlank(entity.getPreQ())) { |
| | | itemNos.add(entity.getPreQ().split(",")); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getPreCos())) { |
| | | itemNos.add(dto.getPreCos().split(",")); |
| | | if (StringUtils.isNotBlank(entity.getPreCos())) { |
| | | itemNos.add(entity.getPreCos().split(",")); |
| | | } |
| | | if (!CollectionUtils.isEmpty(itemNos)) { |
| | | reqVO.setItemNos(itemNos); |
| | | log.info("reqVO=" + JSONObject.toJSONString(reqVO)); |
| | | Map<String, BigDecimal> preValues = mcsApi.getPredictValueByTime(reqVO); |
| | | if (StringUtils.isNotBlank(dto.getPreP()) && preValues.get(dto.getPreP()) != null) { |
| | | dto.setPreP(preValues.get(dto.getPreP()).toString()); |
| | | if (StringUtils.isNotBlank(entity.getPreP()) && preValues.get(entity.getPreP()) != null) { |
| | | powerNetFactorDTO.setPreP(new BigDecimal(preValues.get(entity.getPreP()).toString())); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getPreQ()) && preValues.get(dto.getPreQ()) != null) { |
| | | dto.setPreQ(preValues.get(dto.getPreQ()).toString()); |
| | | if (StringUtils.isNotBlank(entity.getPreQ()) && preValues.get(entity.getPreQ()) != null) { |
| | | powerNetFactorDTO.setPreQ(new BigDecimal(preValues.get(entity.getPreQ()).toString())); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getPreCos()) && preValues.get(dto.getPreCos()) != null) { |
| | | dto.setPreCos(preValues.get(dto.getPreCos()).toString()); |
| | | if (StringUtils.isNotBlank(entity.getPreCos()) && preValues.get(entity.getPreCos()) != null) { |
| | | powerNetFactorDTO.setPreCos(new BigDecimal(preValues.get(entity.getPreCos()).toString())); |
| | | } |
| | | } |
| | | } catch (Exception ex) { |
| | | log.info(dto.getNodeName() + "获取预测值异常," + ex.getMessage()); |
| | | log.info(entity.getNodeName() + "获取预测值异常," + ex.getMessage()); |
| | | ex.printStackTrace(); |
| | | } |
| | | |
| | | // 设置状态 |
| | | if (cosFlag && StringUtils.isNotBlank(dto.getCurCos()) && NumberUtil.isNumber(dto.getCurCos())) { |
| | | BigDecimal curCos = new BigDecimal(dto.getCurCos()); |
| | | if (dto.getLimitL() != null && dto.getLimitH() != null && |
| | | curCos.compareTo(dto.getLimitL()) < 0 || curCos.compareTo(dto.getLimitH()) > 0) { |
| | | dto.setStatus(1); |
| | | } else { |
| | | dto.setStatus(0); |
| | | // 设置电流状态 |
| | | 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); |
| | | } |
| | | } |
| | | |
| | | // 设置功率因数状态 |
| | | powerNetFactorDTO.setQstatus(0); |
| | | if (cosFlag && powerNetFactorDTO.getCurCos() != null) { |
| | | BigDecimal curCos = powerNetFactorDTO.getCurCos(); |
| | | if (entity.getCosLimitL() != null && curCos.compareTo(entity.getCosLimitL()) < 0) { |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } else if (entity.getCosLimitH() != null && curCos.compareTo(entity.getCosLimitH()) > 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); |
| | | } else if (entity.getPLimitH() != null && curP.compareTo(entity.getPLimitH()) > 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); |
| | | } else if (entity.getQLimitH() != null && curQ.compareTo(entity.getQLimitH()) > 0) { |
| | | powerNetFactorDTO.setQstatus(1); |
| | | } |
| | | } |
| | | result.add(powerNetFactorDTO); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/net-factor-dropdown/list") |
| | | @Operation(summary = "功率因数-电网拓扑下拉列表") |
| | | public CommonResult<List<PowerNetFactorDropdownDTO>> getPowerNetFactorDropdownList(@RequestParam String nodeName) { |
| | | List<PowerNetFactorEntity> list = powerNetFactorService.listDropdown(nodeName); |
| | | List<PowerNetFactorDropdownDTO> result = ConvertUtils.sourceToTarget(list, PowerNetFactorDropdownDTO.class); |
| | | public CommonResult<List<PowerNetDropdownDTO>> getPowerNetFactorDropdownList(@RequestParam String nodeCode) { |
| | | log.info("nodeCode=" + nodeCode); |
| | | List<PowerNetDropdownDTO> result = new ArrayList<>(); |
| | | PowerNetFactorEntity entity = powerNetFactorService.getByNodeCode(nodeCode); |
| | | if (entity == null) { |
| | | return success(result); |
| | | } |
| | | List<PowerNetDropdownEntity> list = new ArrayList<>(); |
| | | Map<String, Object> params = new HashMap<>(); |
| | | if ("望铁关口".equals(entity.getGroupName())) { |
| | | params.put("groupName", entity.getGroupName()); |
| | | params.put("neNodeName", entity.getNodeName()); |
| | | } else { |
| | | params.put("groupName", entity.getNodeName()); |
| | | } |
| | | list = powerNetDropdownService.list(params); |
| | | List<String> points = list.stream().map(item -> { |
| | | return item.getCurCos(); |
| | | }).collect(Collectors.toList()); |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | 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()); |
| | | } |
| | | dto.setCurCos(curCos); |
| | | result.add(dto); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | |
| | | if (CollectionUtils.isEmpty(dtoList)) { |
| | | return success(result); |
| | | } |
| | | for (PowerNetFactorDTO dto : dtoList) { |
| | | for (PowerNetFactorEntity entity : list) { |
| | | List<String> points = new ArrayList<>(); |
| | | String message = ""; |
| | | if (StringUtils.isNotBlank(dto.getCurQ())) { |
| | | points.add(dto.getCurQ()); |
| | | if (StringUtils.isNotBlank(entity.getCurQ())) { |
| | | points.add(entity.getCurQ()); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getCurCos())) { |
| | | points.add(dto.getCurCos()); |
| | | if (StringUtils.isNotBlank(entity.getCurCos())) { |
| | | points.add(entity.getCurCos()); |
| | | } |
| | | if (CollectionUtils.isEmpty(points)) { |
| | | continue; |
| | | } |
| | | |
| | | Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | if (pointsRealValue.get(dto.getCurQ()) != null) { |
| | | BigDecimal curQ = new BigDecimal(pointsRealValue.get(dto.getCurQ()).toString()); |
| | | if (curQ.compareTo(BigDecimal.ZERO) == dto.getCurFlag()) { |
| | | message = dto.getNodeName() + "发生无功返送;"; |
| | | if (pointsRealValue.get(entity.getCurQ()) != null) { |
| | | BigDecimal curQ = new BigDecimal(pointsRealValue.get(entity.getCurQ()).toString()); |
| | | if (curQ.compareTo(BigDecimal.ZERO) == entity.getCurFlag()) { |
| | | message = entity.getNodeName() + "发生无功返送;"; |
| | | } |
| | | } |
| | | if (pointsRealValue.get(dto.getCurCos()) != null) { |
| | | BigDecimal curCos = new BigDecimal(pointsRealValue.get(dto.getCurCos()).toString()); |
| | | if (curCos.compareTo(dto.getLimitH()) > 0) { |
| | | message += dto.getNodeName() + "功率因数超上限"; |
| | | } else if (curCos.compareTo(dto.getLimitL()) < 0) { |
| | | message += dto.getNodeName() + "功率因数超下限"; |
| | | if (pointsRealValue.get(entity.getCurCos()) != null) { |
| | | BigDecimal curCos = new BigDecimal(pointsRealValue.get(entity.getCurCos()).toString()); |
| | | if (entity.getLimitH() != null && curCos.compareTo(entity.getLimitH()) > 0) { |
| | | message += entity.getNodeName() + "功率因数超上限"; |
| | | } else if (entity.getLimitL() != null && curCos.compareTo(entity.getLimitL()) < 0) { |
| | | message += entity.getNodeName() + "功率因数超下限"; |
| | | } |
| | | } |
| | | if (!message.isEmpty()) { |
| | |
| | | @GetMapping("/gen-status/list") |
| | | @Operation(summary = "功率因数-发电机组实时状态") |
| | | public CommonResult<List<PowerGenStatusDTO>> getPowerGenStatusList(@RequestParam Map<String, Object> params) { |
| | | List<PowerGenStatusDTO> result = new ArrayList<>(); |
| | | List<PowerGenStatusEntity> list = powerGenStatusDaoService.list(params); |
| | | List<PowerGenStatusDTO> result = ConvertUtils.sourceToTarget(list, PowerGenStatusDTO.class); |
| | | if (CollectionUtils.isEmpty(result)) { |
| | | if (CollectionUtils.isEmpty(list)) { |
| | | return success(result); |
| | | } |
| | | for (PowerGenStatusDTO dto : result) { |
| | | for (PowerGenStatusEntity entity : list) { |
| | | PowerGenStatusDTO dto = new PowerGenStatusDTO(); |
| | | dto.setId(entity.getId()); |
| | | dto.setName(entity.getName()); |
| | | dto.setSort(entity.getSort()); |
| | | |
| | | List<String> points = new ArrayList<>(); |
| | | if (StringUtils.isNotBlank(dto.getCurP())) { |
| | | points.add(dto.getCurP()); |
| | | if (StringUtils.isNotBlank(entity.getCurP())) { |
| | | points.add(entity.getCurP()); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getCurQ())) { |
| | | points.add(dto.getCurQ()); |
| | | if (StringUtils.isNotBlank(entity.getCurQ())) { |
| | | points.add(entity.getCurQ()); |
| | | } |
| | | if (StringUtils.isNotBlank(entity.getCurCos())) { |
| | | points.add(entity.getCurCos()); |
| | | } |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | if (pointsRealValue.get(dto.getCurP()) != null) { |
| | | dto.setCurP(pointsRealValue.get(dto.getCurP()).toString()); |
| | | if (pointsRealValue.get(entity.getCurP()) != null) { |
| | | dto.setCurP(new BigDecimal(pointsRealValue.get(entity.getCurP()).toString())); |
| | | } |
| | | if (pointsRealValue.get(dto.getCurQ()) != null) { |
| | | dto.setCurQ(pointsRealValue.get(dto.getCurQ()).toString()); |
| | | if (pointsRealValue.get(entity.getCurQ()) != null) { |
| | | dto.setCurQ(new BigDecimal(pointsRealValue.get(entity.getCurQ()).toString())); |
| | | } |
| | | if (pointsRealValue.get(entity.getCurCos()) != null) { |
| | | dto.setCurCos(new BigDecimal(pointsRealValue.get(entity.getCurCos()).toString())); |
| | | } |
| | | } |
| | | |
| | | result.add(dto); |
| | | } |
| | | |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/gen-status/history") |
| | | @Operation(summary = "功率因数-发电机组功率历史") |
| | | public CommonResult<PowerHistoryDTO> getPowerGenStatusHistory(@RequestBody PowerGenStatusHisReqDTO dto) { |
| | | log.info("请求参数: {}", JSONObject.toJSONString(dto)); |
| | | |
| | | // 参数校验 |
| | | if (StringUtils.isBlank(dto.getId())) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST, "id不能为空"); |
| | | } |
| | | if (StringUtils.isBlank(dto.getQueryType())) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST, "queryType不能为空"); |
| | | } |
| | | log.info("id={}", dto.getId()); |
| | | PowerGenStatusEntity powerGenStatus = powerGenStatusDaoService.getById(dto.getId()); |
| | | if (powerGenStatus == null) { |
| | | log.info("未找到code对应的数据: {}", dto.getId()); |
| | | return success(new PowerHistoryDTO()); |
| | | } |
| | | |
| | | String queryType = dto.getQueryType().toUpperCase(); |
| | | log.info("queryType={}", queryType); |
| | | String pointNo; |
| | | switch (queryType.toUpperCase()) { |
| | | case "P": |
| | | pointNo = powerGenStatus.getCurP(); |
| | | break; |
| | | case "Q": |
| | | pointNo = powerGenStatus.getCurQ(); |
| | | break; |
| | | case "COS": |
| | | pointNo = powerGenStatus.getCurCos(); |
| | | break; |
| | | default: |
| | | throw new IllegalArgumentException("不支持的queryType: " + queryType); |
| | | } |
| | | log.info("开始查询,pointNo={}", pointNo); |
| | | |
| | | // 默认查最近24小时 |
| | | Date end = Optional.ofNullable(dto.getEndTime()).orElseGet(() -> { |
| | | Calendar cal = Calendar.getInstance(); |
| | | cal.set(Calendar.MILLISECOND, 0); |
| | | cal.set(Calendar.SECOND, 0); |
| | | return cal.getTime(); |
| | | }); |
| | | |
| | | Date start = Optional.ofNullable(dto.getStartTime()).orElseGet(() -> { |
| | | Calendar cal = Calendar.getInstance(); |
| | | cal.setTime(end); |
| | | cal.add(Calendar.MINUTE, -1440); // 24小时前 |
| | | return cal.getTime(); |
| | | }); |
| | | |
| | | // 查询历史数据 |
| | | ApiPointValueQueryDTO query = new ApiPointValueQueryDTO(); |
| | | query.setPointNo(pointNo); |
| | | query.setStart(start); |
| | | query.setEnd(end); |
| | | |
| | | log.info("开始查询发电机组功率历史数据,测点: {}", pointNo); |
| | | List<ApiPointValueDTO> chartData = dataPointApi.queryPointHistoryValue(query); |
| | | |
| | | // 构建返回结果 |
| | | PowerHistoryDTO result = new PowerHistoryDTO(); |
| | | result.setCategories(DateUtils.getTimeScale(start, end, 60)); |
| | | result.setDataList(chartData.stream() |
| | | .map(pv -> new Object[]{ |
| | | DateUtils.format(pv.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND), |
| | | pv.getV() |
| | | }) |
| | | .collect(Collectors.toList())); |
| | | |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/capacitor-status/list") |
| | | @Operation(summary = "功率因数-电容器投运状态") |
| | | @Operation(summary = "功率因数-电容器投退状态") |
| | | public CommonResult<List<PowerCapacitorStatusDTO>> getPowerCapacitorStatusList(@RequestParam Map<String, Object> params) { |
| | | List<PowerCapacitorStatusDTO> result = new ArrayList<>(); |
| | | List<PowerCapacitorStatusEntity> list = powerCapacitorStatusService.list(params); |
| | | return success(ConvertUtils.sourceToTarget(list, PowerCapacitorStatusDTO.class)); |
| | | for (PowerCapacitorStatusEntity entity : list) { |
| | | PowerCapacitorStatusDTO dto = new PowerCapacitorStatusDTO(); |
| | | dto.setId(entity.getId()); |
| | | dto.setName(entity.getName()); |
| | | dto.setRemark(entity.getRemark()); |
| | | dto.setMainCount(DecimalUtil.toBigDecimal(entity.getMainCount()).intValue()); |
| | | dto.setChildCount(DecimalUtil.toBigDecimal(entity.getChildCount()).intValue()); |
| | | int onCount = 0; |
| | | Map<String, Object> params1 = new HashMap<>(); |
| | | params1.put("statusId", entity.getId()); |
| | | List<PowerCapacitorDetEntity> detList = powerCapacitorDetService.list(params1); |
| | | if (CollectionUtils.isEmpty(detList)) { |
| | | dto.setOnCount(onCount); |
| | | continue; |
| | | } |
| | | List<String> points = new ArrayList<>(); |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | for (PowerCapacitorDetEntity det : detList) { |
| | | if (StringUtils.isNotBlank(det.getPointNo())) { |
| | | points.add(det.getPointNo()); |
| | | } |
| | | } |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | for (PowerCapacitorDetEntity det : detList) { |
| | | if (StringUtils.isBlank(det.getId())) { |
| | | continue; |
| | | } |
| | | Object obj = pointsRealValue.get(det.getPointNo()); |
| | | if (obj == null) { |
| | | continue; |
| | | } |
| | | BigDecimal pv = new BigDecimal(obj.toString()); |
| | | if (pv.compareTo(BigDecimal.ZERO) <= 0) { |
| | | continue; |
| | | } |
| | | onCount ++; |
| | | } |
| | | dto.setOnCount(onCount); |
| | | String remark = String.format("共%d台,在投%d台", DecimalUtil.toBigDecimal(entity.getMainCount()).intValue(), onCount); |
| | | dto.setRemark(remark); |
| | | result.add(dto); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/capacitor-det/list") |
| | | @Operation(summary = "功率因数-电容器投退指示灯") |
| | | public CommonResult<List<PowerCapacitorDetDTO>> getPowerCapacitorDetList(@RequestParam Map<String, Object> params) { |
| | | List<PowerCapacitorDetEntity> list = powerCapacitorDetService.list(params); |
| | | log.info("list.size=" + list.size()); |
| | | List<String> points = new ArrayList<>(); |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | for (PowerCapacitorDetEntity det : list) { |
| | | if (StringUtils.isNotBlank(det.getPointNo())) { |
| | | points.add(det.getPointNo()); |
| | | } |
| | | } |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | |
| | | List<PowerCapacitorDetDTO> result = new ArrayList<>(); |
| | | for (PowerCapacitorDetEntity entity : list) { |
| | | PowerCapacitorDetDTO dto = ConvertUtils.sourceToTarget(entity, PowerCapacitorDetDTO.class); |
| | | result.add(dto); |
| | | dto.setStatus(0); |
| | | if (!pointsRealValue.containsKey(entity.getPointNo()) || pointsRealValue.get(entity.getPointNo()) == null) { |
| | | continue; |
| | | } |
| | | BigDecimal val = new BigDecimal(pointsRealValue.get(entity.getPointNo()).toString()); |
| | | if (val.compareTo(BigDecimal.ZERO) >= 0.1) { |
| | | dto.setStatus(1); |
| | | } |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/capacitor-his/list") |
| | | @Operation(summary = "功率因数-电容器投退历史") |
| | | public CommonResult<List<PowerCapacitorHisDTO>> getPowerCapacitorHisList(@RequestParam Map<String, Object> params) { |
| | | String statusId = (String) params.get("statusId"); |
| | | if (StringUtils.isBlank(statusId)) { |
| | | return success(new ArrayList<>()); |
| | | } |
| | | |
| | | List<PowerCapacitorDetEntity> detList = powerCapacitorDetService.list(statusId); |
| | | List<String> detIds = detList.stream().map(PowerCapacitorDetEntity::getId).collect(Collectors.toList()); |
| | | List<PowerCapacitorHisEntity> list = powerCapacitorHisService.list(detIds); |
| | | return success(ConvertUtils.sourceToTarget(list, PowerCapacitorHisDTO.class)); |
| | | } |
| | | |
| | | @PostMapping("/capacitor-his/page") |
| | | @Operation(summary = "功率因数-电容器投退历史(分页)") |
| | | public CommonResult<PageResult<PowerCapacitorHisDTO>> getPowerCapacitorHisPage(@RequestBody PowerCapacitorHisPageReqVO reqVO) { |
| | | if (StringUtils.isBlank(reqVO.getStatusId())) { |
| | | return error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | |
| | | List<PowerCapacitorDetEntity> detList = powerCapacitorDetService.list(reqVO.getStatusId()); |
| | | List<String> detIds = detList.stream().map(PowerCapacitorDetEntity::getId).collect(Collectors.toList()); |
| | | reqVO.setDetIdList(detIds); |
| | | |
| | | PageResult<PowerCapacitorHisEntity> data = powerCapacitorHisService.page(reqVO); |
| | | return success(BeanUtils.toBean(data, PowerCapacitorHisDTO.class)); |
| | | } |
| | | |
| | | @GetMapping("/control-main/list") |
| | | @Operation(summary = "功率因数-管控变电站列表") |
| | | @Operation(summary = "功率因数-管控变电站列表(已废弃)") |
| | | public CommonResult<List<PowerControlMainDTO>> getPowerControlMainList(@RequestParam Map<String, Object> params) { |
| | | List<PowerControlMainEntity> list = powerControlMainService.list(params); |
| | | return success(ConvertUtils.sourceToTarget(list, PowerControlMainDTO.class)); |
| | | } |
| | | |
| | | @PostMapping("/control-main/update") |
| | | @Operation(summary = "功率因数-管控变电站修改上下限") |
| | | @Operation(summary = "功率因数-管控变电站修改上下限(已废弃)") |
| | | public CommonResult<Boolean> updatePowerControlMain(@RequestBody PowerControlMainDTO dto) { |
| | | if (StringUtils.isBlank(dto.getId())) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | |
| | | } |
| | | |
| | | @GetMapping("/control-det/list") |
| | | @Operation(summary = "功率因数-管控功率因数详情") |
| | | @Operation(summary = "功率因数-管控功率因数详情(已废弃)") |
| | | public CommonResult<List<PowerControlDetDTO>> getPowerControlDetList(@RequestParam Map<String, Object> params) { |
| | | List<PowerControlDetDTO> result = new ArrayList<>(); |
| | | String name = (String) params.get("name"); |
| | |
| | | result = ConvertUtils.sourceToTarget(list, PowerControlDetDTO.class); |
| | | |
| | | result.forEach(item -> { |
| | | // 设置随机数据,0.8左右 |
| | | Random rand = new Random(); |
| | | int min = 700; |
| | | int max = 900; |
| | | int randomNumber = rand.nextInt(max - min + 1) + min; |
| | | BigDecimal rv = new BigDecimal(randomNumber * 0.001).setScale(4, BigDecimal.ROUND_HALF_UP); |
| | | /*BigDecimal rv = new BigDecimal(randomNumber * 0.001).setScale(4, BigDecimal.ROUND_HALF_UP); |
| | | item.setValue(rv); |
| | | if (item.getLimitL() != null && rv.compareTo(item.getLimitL()) < 0) { |
| | | item.setStatus(1); |
| | | } else { |
| | | item.setStatus(0); |
| | | } |
| | | }*/ |
| | | }); |
| | | return success(result); |
| | | } |
| | |
| | | @GetMapping("/demand/list") |
| | | @Operation(summary = "负荷移植-月最大需量,实测需量,有功功率") |
| | | public CommonResult<List<PowerDemandDTO>> getPowerDemandList(@RequestParam Map<String, Object> params) { |
| | | log.info("负荷移植-月最大需量,实测需量,有功功率"); |
| | | List<PowerDemandDTO> result = new ArrayList<>(); |
| | | List<PowerDemandEntity> list = powerDemandService.list(params); |
| | | List<PowerDemandDTO> result = ConvertUtils.sourceToTarget(list, PowerDemandDTO.class); |
| | | if (CollectionUtils.isEmpty(result)) { |
| | | if (CollectionUtils.isEmpty(list)) { |
| | | log.info("list.size=" + list.size()); |
| | | return success(result); |
| | | } |
| | | for (PowerDemandDTO dto : result) { |
| | | Calendar calendar = Calendar.getInstance(); |
| | | calendar.set(Calendar.HOUR_OF_DAY, 0); |
| | | calendar.set(Calendar.MINUTE, 0); |
| | | calendar.set(Calendar.SECOND, 0); |
| | | calendar.set(Calendar.MILLISECOND, 0); |
| | | calendar.set(Calendar.DAY_OF_MONTH, 1); |
| | | Date start = calendar.getTime(); |
| | | Date end = new Date(); |
| | | |
| | | for (PowerDemandEntity entity : list) { |
| | | PowerDemandDTO demandDTO = new PowerDemandDTO(); |
| | | demandDTO.setId(entity.getId()); |
| | | demandDTO.setCode(entity.getCode()); |
| | | demandDTO.setName(entity.getName()); |
| | | |
| | | List<String> points = new ArrayList<>(); |
| | | if (StringUtils.isNotBlank(dto.getCurDemand())) { |
| | | points.add(dto.getCurDemand()); |
| | | if (StringUtils.isNotBlank(entity.getCurDemand())) { |
| | | points.add(entity.getCurDemand()); |
| | | } |
| | | if (StringUtils.isNotBlank(dto.getActivePower())) { |
| | | points.add(dto.getActivePower()); |
| | | if (StringUtils.isNotBlank(entity.getActivePower())) { |
| | | points.add(entity.getActivePower()); |
| | | } |
| | | |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | |
| | | Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | |
| | | if (pointsRealValue.get(dto.getCurDemand()) != null) { |
| | | dto.setCurDemand(pointsRealValue.get(dto.getCurDemand()).toString()); |
| | | if (pointsRealValue.get(entity.getCurDemand()) != null) { |
| | | demandDTO.setCurDemand(new BigDecimal(pointsRealValue.get(entity.getCurDemand()).toString())); |
| | | } |
| | | if (pointsRealValue.get(dto.getActivePower()) != null) { |
| | | dto.setActivePower(pointsRealValue.get(dto.getActivePower()).toString()); |
| | | if (pointsRealValue.get(entity.getActivePower()) != null) { |
| | | demandDTO.setActivePower(new BigDecimal(pointsRealValue.get(entity.getActivePower()).toString())); |
| | | } |
| | | } |
| | | |
| | | if (!StringUtils.isEmpty(dto.getMaxDemand())) { |
| | | Calendar calendar = Calendar.getInstance(); |
| | | calendar.set(Calendar.DAY_OF_MONTH, 1); |
| | | calendar.set(Calendar.HOUR_OF_DAY, 0); |
| | | calendar.set(Calendar.MINUTE, 0); |
| | | calendar.set(Calendar.SECOND, 0); |
| | | calendar.set(Calendar.MILLISECOND, 0); |
| | | Date start = calendar.getTime(); |
| | | ApiPointValueQueryDTO apiPointValueQueryDTO = new ApiPointValueQueryDTO(); |
| | | if (!StringUtils.isEmpty(entity.getMaxDemand())) { |
| | | /*ApiPointValueQueryDTO apiPointValueQueryDTO = new ApiPointValueQueryDTO(); |
| | | apiPointValueQueryDTO.setStart(start); |
| | | apiPointValueQueryDTO.setEnd(new Date()); |
| | | apiPointValueQueryDTO.setPointNo(dto.getMaxDemand()); |
| | | |
| | | List<ApiPointValueDTO> monthValues = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO); |
| | | double max = 0; |
| | | for (int i = 0; i < monthValues.size() - 1; i++) { |
| | | if (max < monthValues.get(i).getV()) { |
| | | max = monthValues.get(i).getV(); |
| | | } |
| | | apiPointValueQueryDTO.setEnd(end); |
| | | apiPointValueQueryDTO.setPointNo(entity.getMaxDemand()); |
| | | Map<String, Object> maxValue = dataPointApi.queryPointMaxTimeValue(apiPointValueQueryDTO); |
| | | if (maxValue != null) { |
| | | demandDTO.setMaxDemand(new BigDecimal(maxValue.get(VALUE).toString())); |
| | | demandDTO.setOccurTime(DateUtils.parse( maxValue.get(TIME).toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)); |
| | | }*/ |
| | | PowerMaxdemandMainEntity maxdemandMainEntity = powerMaxDemandMainService.getMonthMax(entity.getCode(), start); |
| | | if (maxdemandMainEntity != null) { |
| | | demandDTO.setMaxDemand(maxdemandMainEntity.getMaxDemand()); |
| | | demandDTO.setOccurTime(maxdemandMainEntity.getOccurTime()); |
| | | } |
| | | dto.setMaxDemand(String.valueOf(max)); |
| | | } |
| | | result.add(demandDTO); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/demand-dropdown/list") |
| | | @Operation(summary = "负荷移植-功率因数下拉列表") |
| | | public CommonResult<List<PowerNetDropdownDTO>> getDemandDropdownList(@RequestParam String code) { |
| | | if (StringUtils.isBlank(code)) { |
| | | log.info("code isBlank"); |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | log.info("code=" + code); |
| | | |
| | | List<PowerNetDropdownDTO> result = new ArrayList<>(); |
| | | PowerDemandEntity entity = powerDemandService.getByCode(code); |
| | | if (entity == null) { |
| | | log.info("PowerDemandEntity is null"); |
| | | return success(result); |
| | | } |
| | | 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()); |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | 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()); |
| | | } |
| | | dto.setCurCos(curCos); |
| | | result.add(dto); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/demand-query/list") |
| | | @Operation(summary = "负荷移植-需量值查询") |
| | | public CommonResult<List<PowerDemandQueryRespDTO>> getDemandQueryList(@RequestBody PowerDemandQueryDTO queryDto) { |
| | | List<PowerDemandQueryRespDTO> result = new ArrayList<>(); |
| | | if (StringUtils.isBlank(queryDto.getCode())) { |
| | | log.info("code isBlank"); |
| | | return success(result); |
| | | } |
| | | PowerDemandEntity entity = powerDemandService.getByCode(queryDto.getCode()); |
| | | if (entity == null) { |
| | | 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> dropdownList = powerNetDropdownService.list(params0); |
| | | List<String> pointNos = new ArrayList<>(); |
| | | Map<String, String> demandPointMap = new HashMap<>(); |
| | | for (PowerNetDropdownEntity netDropdown : dropdownList) { |
| | | demandPointMap.put(netDropdown.getNodeCode(), netDropdown.getExt1()); |
| | | if (StringUtils.isNotBlank(netDropdown.getExt1())) { |
| | | pointNos.add(netDropdown.getExt1()); |
| | | } |
| | | } |
| | | for(PowerNetDropdownEntity netDropdown : dropdownList) { |
| | | PowerDemandQueryRespDTO dto = ConvertUtils.sourceToTarget(netDropdown, PowerDemandQueryRespDTO.class); |
| | | dto.setCurDemand(null); |
| | | result.add(dto); |
| | | } |
| | | if (queryDto.getCurDemand() == null) { |
| | | log.info("查询值为空,显示空白"); |
| | | return success(result); |
| | | } |
| | | ApiPointValueQueryDTO queryCodeValue = new ApiPointValueQueryDTO(); |
| | | queryCodeValue.setStart(startTime); |
| | | queryCodeValue.setEnd(endTime); |
| | | queryCodeValue.setPointNo(entity.getCurDemand()); |
| | | List<ApiPointValueDTO> codeValueList = dataPointApi.queryPointHistoryValue(queryCodeValue); |
| | | if (CollectionUtils.isEmpty(codeValueList)) { |
| | | return success(result); |
| | | } |
| | | ApiPointValueDTO curValue = new ApiPointValueDTO(); |
| | | for (ApiPointValueDTO valueDTO : codeValueList) { |
| | | if (Math.abs(queryDto.getCurDemand().doubleValue() - valueDTO.getV()) <= 0.0001) { |
| | | log.info("curValue is find"); |
| | | curValue = valueDTO; |
| | | break; |
| | | } |
| | | } |
| | | log.info("curValue={}", curValue); |
| | | if (curValue.getT() == null) { |
| | | log.info("curValue is not find"); |
| | | return success(result); |
| | | } |
| | | |
| | | Calendar calendar1 = Calendar.getInstance(); |
| | | calendar1.setTime(curValue.getT()); |
| | | ApiPointsValueQueryDTO valueQueryDTO = new ApiPointsValueQueryDTO(); |
| | | valueQueryDTO.setPointNos(pointNos); |
| | | valueQueryDTO.setEnd(calendar1.getTime()); |
| | | calendar1.add(Calendar.MINUTE, -1); |
| | | valueQueryDTO.setStart(calendar1.getTime()); |
| | | Map<String, List<Map<String, Object>>> pointsHisValues = dataPointApi.queryPointsHistoryValue(valueQueryDTO); |
| | | if (CollectionUtils.isEmpty(pointsHisValues)) { |
| | | log.info("pointsHisValues is null"); |
| | | return success(result); |
| | | } |
| | | for(PowerDemandQueryRespDTO respDTO : result) { |
| | | if (StringUtils.isBlank(demandPointMap.get(respDTO.getNodeCode()))) { |
| | | continue; |
| | | } |
| | | List<Map<String, Object>> hisList = pointsHisValues.get(demandPointMap.get(respDTO.getNodeCode())); |
| | | if (CollectionUtils.isEmpty(hisList)) { |
| | | continue; |
| | | } |
| | | Map<String, Object> valueMap = hisList.get(hisList.size() - 1); |
| | | respDTO.setDataTime(DateUtils.parse(valueMap.get("time").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)); |
| | | respDTO.setCurDemand( DecimalUtil.toBigDecimal(valueMap.get("value"))); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/net-factor/history") |
| | | @Operation(summary = "功率因数-根据nodeName获取最近1440min历史数据,月最大,最小值") |
| | | @Operation(summary = "功率因数-电网拓扑功率历史") |
| | | public CommonResult<PowerHistoryDTO> getPowerHistoryData(@RequestBody PowerNetFactorHisReqDTO dto) { |
| | | log.info("PowerNetFactorHisReqDTO=" + JSONObject.toJSONString(dto)); |
| | | PowerHistoryDTO result = new PowerHistoryDTO(); |
| | | String nodeCode = dto.getNodeCode(); |
| | | if (StringUtils.isBlank(nodeCode)) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | |
| | | if (StringUtils.isBlank(queryType)) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | PowerNetFactorEntity powerNetFactor = powerNetFactorService.getByNodeCode(nodeCode); |
| | | PowerHistoryDTO result = new PowerHistoryDTO(); |
| | | if (powerNetFactor == null) { |
| | | PowerNetFactorQuery powerNetFactorQuery = null; |
| | | PowerNetFactorEntity powerNetFactorEntity = powerNetFactorService.getByNodeCode(nodeCode); |
| | | PowerNetDropdownEntity powerNetDropdownEntity = powerNetDropdownService.getByNodeCode(nodeCode); |
| | | if (powerNetFactorEntity != null) { |
| | | powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetFactorEntity, PowerNetFactorQuery.class); |
| | | } else if (powerNetDropdownEntity != null) { |
| | | powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetDropdownEntity, PowerNetFactorQuery.class); |
| | | } |
| | | if (powerNetFactorQuery == null) { |
| | | log.info("powerNetFactor is null"); |
| | | return success(result); |
| | | } |
| | | log.info("开始查询,"); |
| | | |
| | | ApiPointValueQueryDTO apiPointValueQueryDTO = new ApiPointValueQueryDTO(); |
| | | String pointNo = ""; |
| | | switch (queryType.toUpperCase()) { |
| | | case "P": |
| | | pointNo = powerNetFactor.getCurP(); |
| | | pointNo = powerNetFactorQuery.getCurP(); |
| | | break; |
| | | case "Q": |
| | | pointNo = powerNetFactor.getCurQ(); |
| | | pointNo = powerNetFactorQuery.getCurQ(); |
| | | break; |
| | | case "COS": |
| | | pointNo = powerNetFactor.getCurCos(); |
| | | pointNo = powerNetFactorQuery.getCurCos(); |
| | | break; |
| | | default: |
| | | break; |
| | |
| | | calendar0.set(Calendar.SECOND, 0); |
| | | Date end = dto.getEndTime() == null ? calendar0.getTime() : dto.getEndTime(); |
| | | calendar0.add(Calendar.MINUTE, -1440); |
| | | Date start = dto.getStartTime() == null ? calendar0.getTime() : dto.getStartTime(); |
| | | Date start = dto.getStartTime() == null ? calendar0.getTime() : dto.getStartTime(); |
| | | apiPointValueQueryDTO.setEnd(end); |
| | | apiPointValueQueryDTO.setStart(start); |
| | | List<ApiPointValueDTO> chartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO); |
| | |
| | | start = calendar.getTime(); |
| | | apiPointValueQueryDTO.setStart(start); |
| | | apiPointValueQueryDTO.setEnd(new Date()); |
| | | 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()); |
| | | result.setMax(monthValues.stream().max(Double::compareTo).get()); |
| | | result.setMin(monthValues.stream().min(Double::compareTo).get()); |
| | | Map<String, Object> maxV = dataPointApi.queryPointMaxValueRange(apiPointValueQueryDTO); |
| | | Map<String, Object> minV = dataPointApi.queryPointMaxValueRange(apiPointValueQueryDTO); |
| | | if (maxV != null && maxV.containsKey(pointNo)) { |
| | | result.setMax(new BigDecimal(maxV.get(pointNo).toString())); |
| | | } |
| | | if (minV != null && minV.containsKey(pointNo)) { |
| | | result.setMin(new BigDecimal(minV.get(pointNo).toString())); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | private double getMin(List<List<Object>> dataList) { |
| | | double result = Double.parseDouble(dataList.get(0).get(1).toString()); |
| | | for (int i = 0; i < dataList.size() - 1; i++) { |
| | | if (result > Double.parseDouble(dataList.get(i).get(1).toString())) { |
| | | result = Double.parseDouble(dataList.get(i).get(1).toString()); |
| | | } |
| | | @PostMapping("/net-factor/history-list") |
| | | @Operation(summary = "功率因数-电网拓扑功率历史(多code)") |
| | | public CommonResult<LinkedHashMap<String, PowerHistoryDTO>> getPowerHistoryList(@RequestBody PowerNetFactorHisReqDTO dto) { |
| | | log.info("PowerNetFactorHisReqDTO=" + JSONObject.toJSONString(dto)); |
| | | LinkedHashMap<String, PowerHistoryDTO> result = new LinkedHashMap<>(); |
| | | List<String> nodeCodeList = dto.getNodeCodeList(); |
| | | if (CollectionUtils.isEmpty(nodeCodeList)) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | return result; |
| | | } |
| | | String queryType = dto.getQueryType(); |
| | | if (StringUtils.isBlank(queryType)) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | Calendar calendar0 = Calendar.getInstance(); |
| | | calendar0.set(Calendar.MILLISECOND, 0); |
| | | calendar0.set(Calendar.SECOND, 0); |
| | | Date end0 = dto.getEndTime() == null ? calendar0.getTime() : dto.getEndTime(); |
| | | calendar0.set(Calendar.MINUTE, 0); |
| | | calendar0.set(Calendar.HOUR_OF_DAY, 0); |
| | | Date start0 = dto.getStartTime() == null ? calendar0.getTime() : dto.getStartTime(); |
| | | |
| | | private double getMax(List<List<Object>> dataList) { |
| | | double result = 0; |
| | | for (int i = 0; i < dataList.size() - 1; i++) { |
| | | if (result < Double.parseDouble(dataList.get(i).get(1).toString())) { |
| | | result = Double.parseDouble(dataList.get(i).get(1).toString()); |
| | | |
| | | List<String> categories = DateUtils.getTimeScale(start0, end0, 60); |
| | | for (String nodeCode : nodeCodeList) { |
| | | PowerHistoryDTO powerHistoryDTO = new PowerHistoryDTO(); |
| | | PowerNetFactorQuery powerNetFactorQuery = null; |
| | | PowerNetFactorEntity powerNetFactorEntity = powerNetFactorService.getByNodeCode(nodeCode); |
| | | PowerNetDropdownEntity powerNetDropdownEntity = powerNetDropdownService.getByNodeCode(nodeCode); |
| | | if (powerNetFactorEntity != null) { |
| | | powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetFactorEntity, PowerNetFactorQuery.class); |
| | | } else if (powerNetDropdownEntity != null) { |
| | | powerNetFactorQuery = ConvertUtils.sourceToTarget(powerNetDropdownEntity, PowerNetFactorQuery.class); |
| | | } |
| | | if (powerNetFactorQuery == null) { |
| | | log.info("powerNetFactor is null"); |
| | | continue; |
| | | } |
| | | |
| | | log.info("开始查询,"); |
| | | ApiPointValueQueryDTO apiPointValueQueryDTO = new ApiPointValueQueryDTO(); |
| | | String pointNo = ""; |
| | | switch (queryType.toUpperCase()) { |
| | | case "P": |
| | | pointNo = powerNetFactorQuery.getCurP(); |
| | | break; |
| | | case "Q": |
| | | pointNo = powerNetFactorQuery.getCurQ(); |
| | | break; |
| | | case "COS": |
| | | pointNo = powerNetFactorQuery.getCurCos(); |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | |
| | | //查询图表 |
| | | apiPointValueQueryDTO.setPointNo(pointNo); |
| | | apiPointValueQueryDTO.setEnd(end0); |
| | | apiPointValueQueryDTO.setStart(start0); |
| | | List<ApiPointValueDTO> chartData = dataPointApi.queryPointHistoryValue(apiPointValueQueryDTO); |
| | | List<Object[]> dataList = new ArrayList<>(); |
| | | List<Double> valueList = new ArrayList<>(); |
| | | for (ApiPointValueDTO pv : chartData) { |
| | | Object[] data = new Object[2]; |
| | | data[0] = DateUtils.format(pv.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); |
| | | data[1] = pv.getV(); |
| | | dataList.add(data); |
| | | valueList.add(pv.getV()); |
| | | } |
| | | powerHistoryDTO.setDataList(dataList); |
| | | |
| | | //查询月最大最小值 |
| | | /*ApiPointValueQueryDTO apiPointValueQueryDTO1 = new ApiPointValueQueryDTO(); |
| | | apiPointValueQueryDTO1.setStart(start1); |
| | | apiPointValueQueryDTO1.setEnd(new Date()); |
| | | apiPointValueQueryDTO1.setPointNo(pointNo); |
| | | Map<String, Object> maxV = dataPointApi.queryPointMaxValueRange(apiPointValueQueryDTO1); |
| | | Map<String, Object> minV = dataPointApi.queryPointMaxValueRange(apiPointValueQueryDTO1); |
| | | if (maxV != null && maxV.containsKey(pointNo)) { |
| | | powerHistoryDTO.setMax(new BigDecimal(maxV.get(pointNo).toString())); |
| | | } |
| | | if (minV != null && minV.containsKey(pointNo)) { |
| | | powerHistoryDTO.setMin(new BigDecimal(minV.get(pointNo).toString())); |
| | | }*/ |
| | | |
| | | double fsl = 0; |
| | | double max = 0; |
| | | double min = 0; |
| | | double avg = 0; |
| | | if (!CollectionUtils.isEmpty(valueList)) { |
| | | max = valueList.stream().mapToDouble(Double::doubleValue).max().getAsDouble(); |
| | | min = valueList.stream().mapToDouble(Double::doubleValue).min().getAsDouble(); |
| | | avg = valueList.stream().mapToDouble(Double::doubleValue).average().getAsDouble(); |
| | | |
| | | for (Double val : valueList) { |
| | | if (val < 0) { |
| | | fsl += val; |
| | | } |
| | | } |
| | | } |
| | | powerHistoryDTO.setFsl(new BigDecimal(fsl).setScale(2, BigDecimal.ROUND_HALF_UP)); |
| | | powerHistoryDTO.setMax(new BigDecimal(max).setScale(2, BigDecimal.ROUND_HALF_UP)); |
| | | powerHistoryDTO.setMin(new BigDecimal(min).setScale(2, BigDecimal.ROUND_HALF_UP)); |
| | | powerHistoryDTO.setAvg(new BigDecimal(avg).setScale(2, BigDecimal.ROUND_HALF_UP)); |
| | | |
| | | result.put(nodeCode, powerHistoryDTO); |
| | | } |
| | | return result; |
| | | return success(result); |
| | | } |
| | | |
| | | @GetMapping("/adjust-factor") |
| | |
| | | List<PowerAdjustedFactorDTO> dtoList = ConvertUtils.sourceToTarget(list, PowerAdjustedFactorDTO.class); |
| | | Map<String, Double> result = new HashMap<>(); |
| | | if (CollectionUtils.isEmpty(list)) { |
| | | log.info("PowerAdjustedFactor List is empty"); |
| | | return success(result); |
| | | } |
| | | List<String> points = new ArrayList<>(); |
| | |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | dataMap = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | |
| | | for (PowerAdjustedFactorDTO powerAdjustedFactorDTO : dtoList) { |
| | | Double value = dataMap.get(powerAdjustedFactorDTO.getPointNo()) == null ? 0 : Double.parseDouble(dataMap.get(powerAdjustedFactorDTO.getPointNo()).toString()); |
| | | result.put(powerAdjustedFactorDTO.getName(), value); |
| | |
| | | } |
| | | |
| | | @PostMapping("/demand/history") |
| | | @Operation(summary = "负荷移植-实测需量,有功功率 历史") |
| | | @Operation(summary = "负荷移植-实测需量有功功率历史") |
| | | public CommonResult<PowerHistoryDTO> getPowerDemandHistory(@RequestBody PowerDemandHisReqDTO dto) { |
| | | log.info("请求参数: {}", JSONObject.toJSONString(dto)); |
| | | |
| | |
| | | |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/demand/history-list") |
| | | @Operation(summary = "负荷移植-实测需量有功功率历史(多code)") |
| | | public CommonResult<LinkedHashMap<String, PowerHistoryDTO>> getPowerDemandHistoryList(@RequestBody PowerDemandHisReqDTO dto) { |
| | | log.info("请求参数: {}", JSONObject.toJSONString(dto)); |
| | | LinkedHashMap<String, PowerHistoryDTO> result = new LinkedHashMap<>(); |
| | | |
| | | // 参数校验 |
| | | if (CollectionUtils.isEmpty(dto.getCodeList())) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST, "codeList不能为空"); |
| | | } |
| | | if (StringUtils.isBlank(dto.getQueryType())) { |
| | | return CommonResult.error(GlobalErrorCodeConstants.BAD_REQUEST, "queryType不能为空"); |
| | | } |
| | | Calendar cal = Calendar.getInstance(); |
| | | cal.set(Calendar.MILLISECOND, 0); |
| | | cal.set(Calendar.SECOND, 0); |
| | | Date endTime = dto.getEndTime() == null ? cal.getTime() : dto.getEndTime(); |
| | | Date startTime = dto.getStartTime(); |
| | | if (dto.getStartTime() == null) { |
| | | cal.add(Calendar.DAY_OF_YEAR, -1); |
| | | startTime = cal.getTime(); |
| | | } |
| | | |
| | | Calendar calendar1 = Calendar.getInstance(); |
| | | calendar1.set(Calendar.DAY_OF_MONTH, 1); |
| | | calendar1.set(Calendar.HOUR_OF_DAY, 0); |
| | | calendar1.set(Calendar.MINUTE, 0); |
| | | calendar1.set(Calendar.SECOND, 0); |
| | | calendar1.set(Calendar.MILLISECOND, 0); |
| | | Date start1 = calendar1.getTime(); |
| | | |
| | | for (String code : dto.getCodeList()) { |
| | | PowerHistoryDTO powerHistoryDTO = new PowerHistoryDTO(); |
| | | 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()); |
| | | continue; |
| | | } |
| | | |
| | | String queryType = dto.getQueryType().toUpperCase(); |
| | | String pointNo; |
| | | switch (queryType.toUpperCase()) { |
| | | case "D": |
| | | pointNo = powerNetFactorQuery.getCurDem(); |
| | | break; |
| | | case "P": |
| | | pointNo = powerNetFactorQuery.getCurP(); |
| | | break; |
| | | default: |
| | | throw new IllegalArgumentException("不支持的queryType: " + queryType); |
| | | } |
| | | |
| | | // 查询历史数据 |
| | | ApiPointValueQueryDTO query = new ApiPointValueQueryDTO(); |
| | | query.setPointNo(pointNo); |
| | | query.setStart(startTime); |
| | | query.setEnd(endTime); |
| | | log.info("开始查询实测需量有功功率历史数据,测点: {}", pointNo); |
| | | List<ApiPointValueDTO> chartData = dataPointApi.queryPointHistoryValue(query); |
| | | List<Object[]> dataList = chartData.stream() |
| | | .map(pv -> new Object[]{ |
| | | DateUtils.format(pv.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND), |
| | | pv.getV() |
| | | }) |
| | | .collect(Collectors.toList()); |
| | | |
| | | powerHistoryDTO.setDataList(dataList); |
| | | |
| | | //查询月最大最小值 |
| | | ApiPointValueQueryDTO apiPointValueQueryDTO1 = new ApiPointValueQueryDTO(); |
| | | apiPointValueQueryDTO1.setStart(start1); |
| | | apiPointValueQueryDTO1.setEnd(new Date()); |
| | | apiPointValueQueryDTO1.setPointNo(pointNo); |
| | | Map<String, Object> maxV = dataPointApi.queryPointMaxValueRange(apiPointValueQueryDTO1); |
| | | Map<String, Object> minV = dataPointApi.queryPointMinValueRange(apiPointValueQueryDTO1); |
| | | if (maxV != null && maxV.containsKey(pointNo)) { |
| | | powerHistoryDTO.setMax(new BigDecimal(maxV.get(pointNo).toString())); |
| | | } |
| | | if (minV != null && minV.containsKey(pointNo)) { |
| | | powerHistoryDTO.setMin(new BigDecimal(minV.get(pointNo).toString())); |
| | | } |
| | | |
| | | result.put(code, powerHistoryDTO); |
| | | } |
| | | |
| | | return success(result); |
| | | } |
| | | |
| | | |
| | | @GetMapping("/voltage/status-list") |
| | | @Operation(summary = "功率因数-母线电压状态") |
| | | public CommonResult<List<PowerVoltageStatusDTO>> getPowerVoltageStatusList(@RequestParam Map<String, Object> params) { |
| | | List<PowerVoltageStatusDTO> result = new ArrayList<>(); |
| | | List<PowerVoltageStatusEntity> list = powerVoltageStatusService.list(params); |
| | | if (CollectionUtils.isEmpty(list)) { |
| | | return success(result); |
| | | } |
| | | |
| | | List<String> points = new ArrayList<>(); |
| | | for (PowerVoltageStatusEntity entity : list) { |
| | | if (StringUtils.isBlank(entity.getPoint())) { |
| | | continue; |
| | | } |
| | | points.add(entity.getPoint()); |
| | | } |
| | | Map<String, Object> pointsRealValue = new HashMap<>(); |
| | | if (!CollectionUtils.isEmpty(points)) { |
| | | pointsRealValue = dataPointApi.queryPointsRealValue(points); |
| | | } |
| | | for (PowerVoltageStatusEntity entity : list) { |
| | | PowerVoltageStatusDTO dto = ConvertUtils.sourceToTarget(entity, PowerVoltageStatusDTO.class); |
| | | dto.setStatus(0); |
| | | BigDecimal value = new BigDecimal(pointsRealValue.get(entity.getPoint()).toString()); |
| | | if (value.compareTo(entity.getLimitH()) > 0) { |
| | | dto.setStatus(1); |
| | | } |
| | | dto.setVoltage(value); |
| | | result.add(dto); |
| | | } |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/power-maxdemand/page") |
| | | @Operation(summary = "负荷移植-最大需量发生记录分页") |
| | | public CommonResult<PageResult<PowerMaxDemandMainDTO>> getPowerMaxDemandMainPage(@RequestBody PowerMaxDemandMainPageReqVO reqVO) { |
| | | if (StringUtils.isBlank(reqVO.getCode())) { |
| | | log.info("code is blank"); |
| | | return error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | PageResult<PowerMaxdemandMainEntity> page = powerMaxDemandMainService.page(reqVO); |
| | | PageResult<PowerMaxDemandMainDTO> result = BeanUtils.toBean(page, PowerMaxDemandMainDTO.class); |
| | | result.getList().forEach(dto0 -> { |
| | | List<PowerMaxdemandDetEntity> detList0 = powerMaxdemandDetService.selectListByRelId(dto0.getId(), dto0.getOccurTime()); |
| | | dto0.setChildren(ConvertUtils.sourceToTarget(detList0, PowerMaxdemandDetDTO.class)); |
| | | if (!CollectionUtils.isEmpty(dto0.getChildren())) { |
| | | dto0.getChildren().forEach(dto1 -> { |
| | | List<PowerMaxdemandDetEntity> detList1 = powerMaxdemandDetService.selectListByRelId(dto1.getId(), dto1.getOccurTime()); |
| | | dto1.setChildren(ConvertUtils.sourceToTarget(detList1, PowerMaxdemandDetDTO.class)); |
| | | }); |
| | | } |
| | | }); |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/power-maxdemand/det-list") |
| | | @Operation(summary = "负荷移植-最大需量发生记录详情") |
| | | public CommonResult<List<PowerMaxdemandDetDTO>> getPowerMaxDemandDetList(@RequestBody Map<String, Object> params) { |
| | | String relId = (String) params.get("relId"); |
| | | if (StringUtils.isBlank(relId)) { |
| | | return error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | List<PowerMaxdemandDetEntity> list = powerMaxdemandDetService.selectListByRelId(relId); |
| | | return success(ConvertUtils.sourceToTarget(list, PowerMaxdemandDetDTO.class)); |
| | | } |
| | | |
| | | @GetMapping("/power-price/list") |
| | | @Operation(summary = "获取峰谷平电价信息") |
| | | public CommonResult<List<PowerPriceMainDTO>> getPowerPriceList(@RequestParam Map<String, Object> params) { |
| | | List<PowerPriceMainDTO> result = powerPriceMainService.list(params); |
| | | return success(result); |
| | | } |
| | | |
| | | @PostMapping("/power-price/save") |
| | | @Operation(summary = "保存峰谷平电价信息") |
| | | public CommonResult<Boolean> savePowerPriceList(@RequestBody PowerPriceMainDTO mainDTO) { |
| | | return success(powerPriceMainService.save(mainDTO)); |
| | | } |
| | | |
| | | @PostMapping("/power-price/update") |
| | | @Operation(summary = "修改峰谷平电价信息") |
| | | public CommonResult<Boolean> updatePowerPriceList(@RequestBody PowerPriceMainDTO mainDTO) { |
| | | if(StringUtils.isBlank(mainDTO.getId())) { |
| | | return error(GlobalErrorCodeConstants.BAD_REQUEST); |
| | | } |
| | | return success(powerPriceMainService.update(mainDTO)); |
| | | } |
| | | } |