From 0a3cbfd5731c46c2a89cc6a7b4ff5096dc89a315 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 07 一月 2025 13:56:53 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/TrafficService.java | 49 ++++++++++++++++++++++++++++++++----------------- 1 files changed, 32 insertions(+), 17 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/TrafficService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/TrafficService.java index 5384b38..e556498 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/TrafficService.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/TrafficService.java @@ -20,6 +20,7 @@ import com.zy.acs.manager.manager.enums.SegmentStateType; import com.zy.acs.manager.manager.enums.TaskTypeType; import com.zy.acs.manager.manager.service.*; +import com.zy.acs.manager.system.service.ConfigService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @@ -65,7 +66,7 @@ @Autowired private RetreatNavigateService retreatNavigateService; @Autowired - private TaskService taskService; + private ConfigService configService; @Autowired private JamService jamService; @Autowired @@ -75,6 +76,20 @@ public synchronized void trigger(Segment segment) { try { Date now = new Date(); + + // deprecate jam + if (this.isExpiredJamByAvo(segment.getId())) { + mainService.settleSegmentList(Utils.singletonList(segment), null); + return; + } + + // temporary ----------------- + Integer algoExtensionTime = configService.getVal("algoExtensionTime", Integer.class); + if (null != algoExtensionTime && algoExtensionTime > 0) { + Thread.sleep(algoExtensionTime); + } + // --------------------------- + Travel travel = travelService.getById(segment.getTravelId()); Agv agv = agvService.getById(travel.getAgvId()); AgvDetail agvDetail = agvDetailService.selectByAgvId(travel.getAgvId()); @@ -108,17 +123,14 @@ return; } - // deprecate jam - if (this.isExpiredJamByAvo(segment.getId())) { - mainService.settleSegmentList(Utils.singletonList(segment), null); - return; - } - // execute ----------------------------------------------- // ArrayList<List<TaskPosDto>> list = JSON.parseObject(travel.getTaskContent(), new TypeReference<ArrayList<List<TaskPosDto>>>() {}); - // get path list - avoidWaveCalculator.calcWaveScope(); // * sync wave scope + // * sync wave scope + if (!avoidWaveCalculator.calcWaveScope()) { + log.error("failed to calculate avoid wave matrix ..."); + return; + } // checkout path Code startCode = codeService.getById(agvDetail.getRecentCode()); @@ -188,7 +200,7 @@ mapService.lockPath(null, pathList, agv.getUuid()); - mainService.generateAction(segment.getAgvId(), segmentList, pathList); + mainService.generateAction(segment.getAgvId(), segmentList, pathList, now); } catch (Exception e) { log.error("TrafficService.trigger", e); @@ -279,7 +291,7 @@ if (!Cools.isEmpty(jam.getAvoAgv()) && BlockVehicleDto.customContain(blockVehicleList, agvService.getById(jam.getAvoAgv()).getUuid())) { - maxJamTimeoutFactor = 5; + maxJamTimeoutFactor = 4; } else { @@ -292,25 +304,25 @@ } else { // block vehicle info - Agv blockAgv = agvService.selectByUuid(blockAgvNo); - String blockAgvCode = codeService.getById(agvDetailService.selectByAgvId(blockAgv.getId()).getRecentCode()).getData(); + Long blockAgvId = agvService.getAgvId(blockAgvNo); + String blockAgvCode = codeService.getById(agvDetailService.selectByAgvId(blockAgvId).getRecentCode()).getData(); // create new jam if already notify the avoid vehicle - if (!Cools.isEmpty(jam.getAvoAgv(), jam.getAvoSeg()) && !blockAgv.getId().equals(jam.getAvoAgv())) { + if (!Cools.isEmpty(jam.getAvoAgv(), jam.getAvoSeg()) && !blockAgvId.equals(jam.getAvoAgv())) { jam = this.setupNewJam(jam, agv, startCode, segment, draftPath); } do { // 闃诲杞﹁締姝e湪鍘熷湴浣滀笟锛岀瓑寰� ===>> 瓒呰繃绛夊緟鏃堕棿锛岀粫璺� - List<Segment> runningSegList = segmentService.getByAgvAndState(blockAgv.getId(), SegmentStateType.RUNNING.toString()); + List<Segment> runningSegList = segmentService.getByAgvAndState(blockAgvId, SegmentStateType.RUNNING.toString()); if (!Cools.isEmpty(runningSegList)) { maxJamTimeoutFactor = 1; break; } // 鍒ゆ柇涓嬩釜浠诲姟鏄惁涓哄師鍦颁换鍔★紝濡傛灉鏄垯绛夊緟 ===>> 瓒呰繃绛夊緟鏃堕棿锛岀粫璺紱濡傛灉涓嶆槸锛岃闃诲杞﹁締閬胯 - List<Segment> waitingSegList = segmentService.getJustWaitingSeg(blockAgv.getId()); + List<Segment> waitingSegList = segmentService.getJustWaitingSeg(blockAgvId); if (null != waitingSegList && waitingSegList.stream().anyMatch( waitingSeg -> waitingSeg.getEndNode().equals(codeService.selectByData(blockAgvCode).getId()) @@ -324,7 +336,7 @@ if (jam.getCycleAvo() == 1) { jam.setCycleCode(endCode.getId()); } - jam.setAvoAgv(blockAgv.getId()); + jam.setAvoAgv(blockAgvId); jam.setNotifyTime(new Date()); if (!jamService.updateById(jam)) { throw new CoolException(jam.getUuid() + "-jam failed to update锛侊紒锛�"); @@ -590,6 +602,9 @@ List<String> waveCodeList = mapService.getWaveScopeByCode(lev, firstCodeNode, avoidDistance) .stream().map(NavigateNode::getCodeData).distinct().collect(Collectors.toList()); list.addAll(waveCodeList); + } else { + // 濡傛灉琚樆濉炶溅杈嗗凡缁忎笉鍦ㄥ師鏉ョ殑闃诲璺緞涓紝鑰冭檻閬胯杞﹁蛋琛屾椂涓嶉渶瑕佹妸涔嬪墠鐨勯樆濉炶矾寰勫姞鍏ラ粦鍚嶅崟 + list = new ArrayList<>(); } } -- Gitblit v1.9.1