| | |
| | | List<MdcEquipment> equipmentList = mdcEquipmentService.list(); |
| | | for (MdcEquipment mdcEquipment : equipmentList) { |
| | | String equipmentId = mdcEquipment.getEquipmentId(); |
| | | // 查询班次分类 |
| | | |
| | | MdcOverallEquipmentEfficiency mdcOverallEquipmentEfficiency = new MdcOverallEquipmentEfficiency(); |
| | | // 时间开动率计算 |
| | | mdcOverallEquipmentEfficiency.setEquipmentId(equipmentId); |
| | | mdcOverallEquipmentEfficiency.setEquipmentName(mdcEquipment.getEquipmentName()); |
| | | mdcOverallEquipmentEfficiency.setEquipmentModel(mdcEquipment.getEquipmentModel()); |
| | | mdcOverallEquipmentEfficiency.setValidDate(validDate); |
| | | |
| | | // 查询班制分类 |
| | | List<String> shiftSubIdList = mdcDeviceCalendarService.findShiftSort(equipmentId, validDate); |
| | | if (shiftSubIdList != null && !shiftSubIdList.isEmpty()) { |
| | | String shift = String.join(",", shiftSubIdList); |
| | | mdcOverallEquipmentEfficiency.setShift(shift); |
| | | } |
| | | |
| | | BigDecimal shiftTimeCount = mdcDeviceCalendarService.computeShiftTimeCount(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setShiftTimeCount(shiftTimeCount); |
| | | |
| | | // 计算加班时间 |
| | | BigDecimal overtime = mdcEquipmentOvertimeService.computeOvertime(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setOvertime(overtime); |
| | | |
| | | // 计算实际班产天数 |
| | | BigDecimal actualWorkDayCount = mdcDeviceCalendarService.computeActualWorkDayCount(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setActualWorkDayCount(actualWorkDayCount); |
| | | |
| | | // 月度实际班产总时间(分钟) |
| | | mdcOverallEquipmentEfficiency.setMonthActualWorkDayTimeCount(mdcOverallEquipmentEfficiency.getShiftTimeCount().add(overtime)); |
| | | |
| | | // 故障停机时长统计(分钟) |
| | | BigDecimal breakdownDownDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.BREAKDOWN_DOWN); |
| | | mdcOverallEquipmentEfficiency.setBreakdownDownDuration(breakdownDownDuration); |
| | | // 换型调试时长统计(分钟) |
| | | BigDecimal conversionDebugDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.CONVERSION_DEBUG); |
| | | mdcOverallEquipmentEfficiency.setConversionDebugDuration(conversionDebugDuration); |
| | | // 物料短缺时长统计(分钟) |
| | | BigDecimal materialShortageDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.MATERIAL_SHORTAGE); |
| | | mdcOverallEquipmentEfficiency.setMaterialShortageDuration(materialShortageDuration); |
| | | // 计划等任务时长统计(分钟) |
| | | BigDecimal plannedTaskDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.PLANNED_TASK); |
| | | mdcOverallEquipmentEfficiency.setPlannedTaskDuration(plannedTaskDuration); |
| | | // 检验时长统计(分钟) |
| | | BigDecimal inspectDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.INSPECT); |
| | | mdcOverallEquipmentEfficiency.setInspectDuration(inspectDuration); |
| | | // 其他时长统计(分钟) |
| | | BigDecimal otherDuration = mdcNoplanCloseService.findNoplanTimeDuration(equipmentId, validDate, MdcConstant.OTHER); |
| | | mdcOverallEquipmentEfficiency.setOtherDuration(otherDuration); |
| | | // 计划保养时长统计(分钟) |
| | | BigDecimal plannedMaintenanceDuration = new BigDecimal("0"); |
| | | BigDecimal plannedMaintenanceDuration = mdcPlanCloseService.findPlanTimeDuration(actualWorkDayCount, MdcConstant.PLANNED_MAINTENANCE); |
| | | mdcOverallEquipmentEfficiency.setPlannedMaintenanceDuration(plannedMaintenanceDuration); |
| | | // 会议/培训时长统计(分钟) |
| | | BigDecimal conferenceTrainingDuration = new BigDecimal("0"); |
| | | BigDecimal conferenceTrainingDuration = mdcPlanCloseService.findPlanTimeDuration(actualWorkDayCount, MdcConstant.CONFERENCE_TRAINING); |
| | | mdcOverallEquipmentEfficiency.setConferenceTrainingDuration(conferenceTrainingDuration); |
| | | // 其它休息时长统计(分钟) |
| | | BigDecimal otherRestDuration = new BigDecimal("0"); |
| | | if (shiftSubIdList != null && !shiftSubIdList.isEmpty()) { |
| | | for (String shiftSubId : shiftSubIdList) { |
| | | MdcOverallEquipmentEfficiency mdcOverallEquipmentEfficiency = new MdcOverallEquipmentEfficiency(); |
| | | // 时间开动率计算 |
| | | mdcOverallEquipmentEfficiency.setEquipmentId(equipmentId); |
| | | mdcOverallEquipmentEfficiency.setEquipmentName(mdcEquipment.getEquipmentName()); |
| | | mdcOverallEquipmentEfficiency.setEquipmentModel(mdcEquipment.getEquipmentModel()); |
| | | mdcOverallEquipmentEfficiency.setValidDate(validDate); |
| | | // 班次 班次时间 |
| | | mdcOverallEquipmentEfficiency.setShiftSubId(shiftSubId); |
| | | BigDecimal shiftTimeCount = mdcDeviceCalendarService.computeShiftTimeCount(shiftSubId, equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setShiftTimeCount(shiftTimeCount); |
| | | // 计算加班时间 |
| | | BigDecimal overtime = mdcEquipmentOvertimeService.computeOvertime(shiftSubId, equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setOvertime(overtime); |
| | | // 计算实际班产天数 |
| | | BigDecimal actualWorkDayCount = mdcDeviceCalendarService.computeActualWorkDayCount(shiftSubId, equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setActualWorkDayCount(actualWorkDayCount); |
| | | // 月度实际班产总时间(分钟) |
| | | mdcOverallEquipmentEfficiency.setMonthActualWorkDayTimeCount(mdcOverallEquipmentEfficiency.getShiftTimeCount().add(overtime)); |
| | | // 故障停机时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setBreakdownDownDuration(breakdownDownDuration); |
| | | // 换型调试时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setConversionDebugDuration(conversionDebugDuration); |
| | | // 物料短缺时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setMaterialShortageDuration(materialShortageDuration); |
| | | // 计划等任务时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setPlannedTaskDuration(plannedTaskDuration); |
| | | // 检验时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setInspectDuration(inspectDuration); |
| | | // 其他时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setOtherDuration(otherDuration); |
| | | // 计划保养时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setPlannedMaintenanceDuration(plannedMaintenanceDuration); |
| | | // 会议/培训时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setConferenceTrainingDuration(conferenceTrainingDuration); |
| | | // 其它休息时长统计(分钟) |
| | | mdcOverallEquipmentEfficiency.setOtherRestDuration(otherRestDuration); |
| | | /* |
| | | 负荷时间(小时) = 工作日历时间 - 计划停机时间 |
| | | 工作日历时间 = 日历时间 - 法定假日 - 双休日 + 加班时间 |
| | | 计划停机时间 = 计划保养时长 + 会议/培训时长 + 会议/培训时长 |
| | | */ |
| | | // mdcOverallEquipmentEfficiency.getShiftTimeCount() - plannedMaintenanceDuration - conferenceTrainingDuration - otherRestDuration |
| | | // 负荷时间(分钟) |
| | | BigDecimal loadTime = mdcOverallEquipmentEfficiency.getShiftTimeCount().subtract(plannedMaintenanceDuration).subtract(conferenceTrainingDuration).subtract(otherRestDuration); |
| | | mdcOverallEquipmentEfficiency.setLoadTime(loadTime.divide(new BigDecimal("60"), 1, RoundingMode.HALF_UP)); |
| | | // 时间开动率 |
| | | BigDecimal timeActuationRate = BigDecimal.ZERO; |
| | | if (loadTime.compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setTimeActuationRate(BigDecimal.ZERO); |
| | | } else { |
| | | timeActuationRate = (loadTime.subtract(breakdownDownDuration).subtract(conversionDebugDuration).subtract(materialShortageDuration).subtract(plannedTaskDuration).subtract(inspectDuration).subtract(otherDuration)).divide(loadTime, 4, RoundingMode.HALF_UP); |
| | | mdcOverallEquipmentEfficiency.setTimeActuationRate(timeActuationRate); |
| | | } |
| | | // 加工零件数(件) processQuantity |
| | | BigDecimal processQuantity = mdcPassRateService.findProcessQuantity(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setProcessQuantity(processQuantity); |
| | | // 标准加工时间(分钟) |
| | | MdcStandardProcessDuration mdcStandardProcessDuration = mdcStandardProcessDurationService.getOne(new LambdaQueryWrapper<MdcStandardProcessDuration>().eq(MdcStandardProcessDuration::getEquipmentId, equipmentId)); |
| | | if (mdcStandardProcessDuration != null) { |
| | | mdcOverallEquipmentEfficiency.setStandardProcessDuration(new BigDecimal(mdcStandardProcessDuration.getDuration()).multiply(processQuantity)); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setStandardProcessDuration(BigDecimal.ZERO); |
| | | } |
| | | |
| | | // 性能开动率 = 主轴运行时间/负荷时间 |
| | | // 查询主轴运行时间(分钟) |
| | | BigDecimal spindleRunDuration = mdcEquipmentStatisticalShiftInfoService.findSpindleRunDuration(equipmentId, validDate, shiftSubId); |
| | | if (loadTime.compareTo(BigDecimal.ZERO) != 0) { |
| | | mdcOverallEquipmentEfficiency.setPerformanceRate(spindleRunDuration.divide(loadTime, 4, RoundingMode.HALF_UP)); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setPerformanceRate(BigDecimal.ZERO); |
| | | } |
| | | // 废品数 unqualifiedQuantity |
| | | BigDecimal unqualifiedQuantity = mdcPassRateService.findUnqualifiedQuantity(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setUnqualifiedQuantity(unqualifiedQuantity); |
| | | // 合格率 |
| | | if (processQuantity.compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setPassRate(BigDecimal.ONE); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setPassRate((processQuantity.subtract(unqualifiedQuantity)).divide(processQuantity, 4, RoundingMode.HALF_UP)); |
| | | } |
| | | // 设备综合效率 = 时间开动率 × 性能开动率 × 合格品率 |
| | | mdcOverallEquipmentEfficiency.setOverallEquipmentEfficiency(timeActuationRate.multiply(mdcOverallEquipmentEfficiency.getPerformanceRate()).multiply(mdcOverallEquipmentEfficiency.getPassRate())); |
| | | if (mdcOverallEquipmentEfficiency.getOverallEquipmentEfficiency().compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setOverallEquipmentEfficiency(BigDecimal.ONE); |
| | | } |
| | | result.add(mdcOverallEquipmentEfficiency); |
| | | } |
| | | BigDecimal otherRestDuration = mdcPlanCloseService.findPlanTimeDuration(actualWorkDayCount, MdcConstant.OTHER_REST); |
| | | mdcOverallEquipmentEfficiency.setOtherRestDuration(otherRestDuration); |
| | | /* |
| | | 负荷时间(小时) = 工作日历时间 - 计划停机时间 |
| | | 工作日历时间 = 日历时间 - 法定假日 - 双休日 + 加班时间 |
| | | 计划停机时间 = 计划保养时长 + 会议/培训时长 + 会议/培训时长 |
| | | */ |
| | | // mdcOverallEquipmentEfficiency.getShiftTimeCount() - plannedMaintenanceDuration - conferenceTrainingDuration - otherRestDuration |
| | | // 负荷时间(分钟) |
| | | BigDecimal loadTime = mdcOverallEquipmentEfficiency.getShiftTimeCount().subtract(plannedMaintenanceDuration).subtract(conferenceTrainingDuration).subtract(otherRestDuration); |
| | | mdcOverallEquipmentEfficiency.setLoadTime(loadTime.divide(new BigDecimal("60"), 1, RoundingMode.HALF_UP)); |
| | | // 时间开动率 |
| | | BigDecimal timeActuationRate = BigDecimal.ZERO; |
| | | if (loadTime.compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setTimeActuationRate(BigDecimal.ZERO); |
| | | } else { |
| | | timeActuationRate = (loadTime.subtract(breakdownDownDuration).subtract(conversionDebugDuration).subtract(materialShortageDuration).subtract(plannedTaskDuration).subtract(inspectDuration).subtract(otherDuration)).divide(loadTime, 4, RoundingMode.HALF_UP); |
| | | mdcOverallEquipmentEfficiency.setTimeActuationRate(timeActuationRate); |
| | | } |
| | | // 加工零件数(件) processQuantity |
| | | BigDecimal processQuantity = mdcPassRateService.findProcessQuantity(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setProcessQuantity(processQuantity); |
| | | // 标准加工时间(分钟) |
| | | MdcStandardProcessDuration mdcStandardProcessDuration = mdcStandardProcessDurationService.getOne(new LambdaQueryWrapper<MdcStandardProcessDuration>().eq(MdcStandardProcessDuration::getEquipmentId, equipmentId)); |
| | | if (mdcStandardProcessDuration != null) { |
| | | mdcOverallEquipmentEfficiency.setStandardProcessDuration(new BigDecimal(mdcStandardProcessDuration.getDuration()).multiply(processQuantity)); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setStandardProcessDuration(BigDecimal.ZERO); |
| | | } |
| | | |
| | | // 性能开动率 = 主轴运行时间/负荷时间 |
| | | // 查询主轴运行时间(分钟) |
| | | BigDecimal spindleRunDuration = mdcEquipmentStatisticalShiftInfoService.findSpindleRunDuration(equipmentId, validDate); |
| | | if (loadTime.compareTo(BigDecimal.ZERO) != 0) { |
| | | mdcOverallEquipmentEfficiency.setPerformanceRate(spindleRunDuration.divide(loadTime, 4, RoundingMode.HALF_UP)); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setPerformanceRate(BigDecimal.ZERO); |
| | | } |
| | | // 废品数 unqualifiedQuantity |
| | | BigDecimal unqualifiedQuantity = mdcPassRateService.findUnqualifiedQuantity(equipmentId, validDate); |
| | | mdcOverallEquipmentEfficiency.setUnqualifiedQuantity(unqualifiedQuantity); |
| | | // 合格率 |
| | | if (processQuantity.compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setPassRate(BigDecimal.ONE); |
| | | } else { |
| | | mdcOverallEquipmentEfficiency.setPassRate((processQuantity.subtract(unqualifiedQuantity)).divide(processQuantity, 4, RoundingMode.HALF_UP)); |
| | | } |
| | | // 设备综合效率 = 时间开动率 × 性能开动率 × 合格品率 |
| | | mdcOverallEquipmentEfficiency.setOverallEquipmentEfficiency(timeActuationRate.multiply(mdcOverallEquipmentEfficiency.getPerformanceRate()).multiply(mdcOverallEquipmentEfficiency.getPassRate())); |
| | | if (mdcOverallEquipmentEfficiency.getOverallEquipmentEfficiency().compareTo(BigDecimal.ZERO) == 0) { |
| | | mdcOverallEquipmentEfficiency.setOverallEquipmentEfficiency(BigDecimal.ONE); |
| | | } |
| | | result.add(mdcOverallEquipmentEfficiency); |
| | | |
| | | } |
| | | super.saveBatch(result); |
| | | } |