From ebd2f4397a92c6a5096de1b86d59154363344720 Mon Sep 17 00:00:00 2001 From: vincentlu <t1341870251@gmail.com> Date: 星期二, 13 五月 2025 08:48:15 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/DemoController.java | 188 +++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 164 insertions(+), 24 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/DemoController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/DemoController.java index ed9c70b..b109ac2 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/DemoController.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/DemoController.java @@ -1,20 +1,25 @@ package com.zy.acs.manager.core; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.zy.acs.common.enums.AgvStatusType; import com.zy.acs.framework.common.R; import com.zy.acs.framework.common.SnowflakeIdWorker; import com.zy.acs.manager.core.service.*; import com.zy.acs.manager.core.service.astart.MapDataDispatcher; import com.zy.acs.manager.core.utils.RouteGenerator; -import com.zy.acs.manager.manager.entity.AgvDetail; -import com.zy.acs.manager.manager.enums.TaskTypeType; +import com.zy.acs.manager.manager.entity.*; +import com.zy.acs.manager.manager.enums.FuncStaType; +import com.zy.acs.manager.manager.enums.StatusType; import com.zy.acs.manager.manager.service.*; import com.zy.acs.manager.system.controller.BaseController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestMethod; -import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.bind.annotation.*; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; +import java.util.stream.Collectors; /** * Created by vincent on 11/15/2024 @@ -53,10 +58,67 @@ private PatrolService patrolService; @Autowired private RouteGenerator routeGenerator; + @Autowired + private FuncStaService funcStaService; + @Autowired + private AgvModelService agvModelService; @RequestMapping(value = "/system/info", method = {RequestMethod.GET, RequestMethod.POST}) public R systemInfo() { return R.ok("RCS-FLOW-1.0.0"); + } + + // {"msg":"Success","code":200,"data":[[38,2],[38,3],[38,4],[38,5],[38,6],[37,6],[36,6],[35,6],[34,6],[33,6],[32,6],[31,6],[30,6],[29,6],[28,6],[27,6],[26,6],[25,6]]} + // {"msg":"Success","code":200,"data":[[38,2],[38,3],[38,4],[38,5],[38,6],[37,6],[36,6],[35,6],[34,6],[33,6],[32,6],[31,6],[30,6],[29,6],[28,6],[27,6],[26,6],[25,6]]} + @RequestMapping(value = "/system/demo", method = {RequestMethod.GET, RequestMethod.POST}) + public R demo() { + long startTime = System.currentTimeMillis(); + for (int i = 0; i < 1000; i++) { + this.demo1(); + } + System.out.println(System.currentTimeMillis() - startTime); + return R.ok(); + } + + private R demo1() { + List<String> path = new ArrayList<>(); + path.add("00000035"); + path.add("00000085"); + path.add("00000135"); + path.add("00000185"); + path.add("00000235"); + path.add("00000234"); + path.add("00000233"); + path.add("00000232"); + path.add("00000231"); + path.add("00000230"); + path.add("00000229"); + path.add("00000228"); + path.add("00000227"); + path.add("00000226"); + path.add("00000225"); + path.add("00000224"); + path.add("00000223"); + path.add("00000222"); + +// List<int[]> codeMatrixIdxList = new ArrayList<>(); +// for (String pathStr : path) { +// int[] codeMatrixIdx = mapDataDispatcher.getCodeMatrixIdx(null, pathStr); +// codeMatrixIdxList.add(codeMatrixIdx); +// } + +// List<int[]> codeMatrixIdxList = mapDataDispatcher.getCodeMatrixIdxList(null, path); + +// System.out.println(codeMatrixIdxList.toString()); + +// return R.ok().add(codeMatrixIdxList); + + for (String codeData : path) { + Code code = codeService.getCacheByData(codeData); + Code byId = codeService.getCacheById(code.getId()); + } + + return R.ok(); } // @RequestMapping(value = "/system/route/generate", method = {RequestMethod.GET, RequestMethod.POST}) @@ -66,31 +128,109 @@ // return R.ok(String.valueOf(list.size())).add(list); // } - @GetMapping("/dead/lock") - public R aaa() { - AgvDetail agvDetail11 = agvDetailService.selectByAgvNo("11"); - agvDetail11.setCode(codeService.selectByData("00000251").getId()); - agvDetailService.updateById(agvDetail11); + // http://localhost:8088/demo/auto/go/standby + @GetMapping("/auto/go/standby") + public R autoGoStandby() { - AgvDetail agvDetail12 = agvDetailService.selectByAgvNo("12"); - agvDetail12.setCode(codeService.selectByData("00000204").getId()); - agvDetailService.updateById(agvDetail12); + List<FuncSta> standbyFunStaList = funcStaService.list(new LambdaQueryWrapper<FuncSta>() + .eq(FuncSta::getStatus, StatusType.ENABLE.val) + .eq(FuncSta::getType, FuncStaType.STANDBY.toString()) + .orderByAsc(FuncSta::getId)); - AgvDetail agvDetail14 = agvDetailService.selectByAgvNo("14"); - agvDetail14.setCode(codeService.selectByData("00000101").getId()); - agvDetailService.updateById(agvDetail14); + List<Agv> agvList = agvService.list(new LambdaQueryWrapper<Agv>().eq(Agv::getStatus, StatusType.ENABLE.val). orderByAsc(Agv::getId)); + + int size = Math.min(standbyFunStaList.size(), agvList.size()); + + for (int i = 0; i < size; i++) { + + FuncSta funcSta = standbyFunStaList.get(i); + Code code = codeService.getCacheById(funcSta.getCode()); + + Agv agv = agvList.get(i); + AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId()); + AgvModel agvModel = agvModelService.getByAgvId(agv.getId()); + Double workDirection = agvModel.getWorkDirection(); + + agvDetail.setPos(1); + agvDetail.setCode(code.getId()); + agvDetail.setStatus(AgvStatusType.IDLE.val); + agvDetail.setAgvAngle(workDirection); + agvDetail.setVol(5000); + + agvDetailService.updateById(agvDetail); + } avoidWaveCalculator.calcDynamicNodeWhenBoot(); - - mainLockWrapService.buildMinorTask(agvService.getById(agvDetail14.getAgvId()), TaskTypeType.MOVE, - codeService.selectByData("00000303").getData(), null); - mainLockWrapService.buildMinorTask(agvService.getById(agvDetail11.getAgvId()), TaskTypeType.MOVE, - codeService.selectByData("00000411").getData(), null); - mainLockWrapService.buildMinorTask(agvService.getById(agvDetail12.getAgvId()), TaskTypeType.MOVE, - codeService.selectByData("00000403").getData(), null); +// AgvDetail agvDetail11 = agvDetailService.selectByAgvNo("11"); +// agvDetail11.setCode(codeService.getCacheByData("00000251").getId()); +// agvDetailService.updateById(agvDetail11); +// +// AgvDetail agvDetail12 = agvDetailService.selectByAgvNo("12"); +// agvDetail12.setCode(codeService.getCacheByData("00000204").getId()); +// agvDetailService.updateById(agvDetail12); +// +// AgvDetail agvDetail14 = agvDetailService.selectByAgvNo("14"); +// agvDetail14.setCode(codeService.getCacheByData("00000101").getId()); +// agvDetailService.updateById(agvDetail14); +// +// avoidWaveCalculator.calcDynamicNodeWhenBoot(); +// +// mainLockWrapService.buildMinorTask(agvService.getById(agvDetail14.getAgvId()), TaskTypeType.MOVE, +// codeService.getCacheByData("00000303").getData(), null); +// mainLockWrapService.buildMinorTask(agvService.getById(agvDetail11.getAgvId()), TaskTypeType.MOVE, +// codeService.getCacheByData("00000411").getData(), null); +// mainLockWrapService.buildMinorTask(agvService.getById(agvDetail12.getAgvId()), TaskTypeType.MOVE, +// codeService.getCacheByData("00000403").getData(), null); return R.ok(); } + // http://localhost:8088/demo/auto/go/patrol?count=10 + @GetMapping("/auto/go/patrol") + public R autoGoPatrol(@RequestParam(required = false, defaultValue = "5") Integer count) { + List<Agv> list = agvService.list(new LambdaQueryWrapper<Agv>().eq(Agv::getStatus, StatusType.ENABLE.val)); + + // stop + if (count == 0) { + for (String agvNo : list.stream().map(Agv::getUuid).collect(Collectors.toList())) { + if (patrolService.isPatrolling(agvNo)) { + patrolService.shutdownPatrol(agvNo); + } + } + return R.ok(); + } + + // start + Collections.shuffle(list); + if (list.size() > count) { + list = list.subList(0, count); + } + int result = 0; + for (Agv agv : list) { + patrolService.startupPatrol(agv.getUuid()); + result++; + } + return R.ok().add(result); + } + + + @Autowired + private MapService mapService; + @Autowired + private SegmentService segmentService; + + @GetMapping("/astarDemo") // astar spend time: 3866, count:3855 + public R astarDemo() { + long startTime = System.currentTimeMillis(); + List<String> path = mapService.checkoutPath("18" + , codeService.getCacheByData("00001318") + , codeService.getCacheByData("00003447") + , true + , new ArrayList<>() + , segmentService.getById(1390)); + System.out.println("demo spend time: " + (System.currentTimeMillis() - startTime)); + return R.ok().add(path); + } + } -- Gitblit v1.9.1