package com.zy.acs.manager.core.scheduler; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.zy.acs.common.constant.RedisConstant; import com.zy.acs.common.utils.RedisSupport; import com.zy.acs.framework.common.Cools; import com.zy.acs.framework.common.SnowflakeIdWorker; import com.zy.acs.manager.common.domain.TaskDto; import com.zy.acs.manager.core.constant.AgvGroupConstant; import com.zy.acs.manager.core.constant.LocGroupConstant; import com.zy.acs.manager.core.constant.StaGroupConstant; import com.zy.acs.manager.core.service.MainService; import com.zy.acs.manager.manager.controller.param.OpenBusSubmitParam; import com.zy.acs.manager.manager.entity.Agv; import com.zy.acs.manager.manager.entity.AgvModel; import com.zy.acs.manager.manager.entity.Loc; import com.zy.acs.manager.manager.entity.Task; import com.zy.acs.manager.manager.enums.AgvModelType; import com.zy.acs.manager.manager.enums.LocStsType; import com.zy.acs.manager.manager.enums.TaskStsType; 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.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import java.util.*; @Slf4j @Component public class EfficiencyTestV2Scheduler { private final RedisSupport redis = RedisSupport.defaultRedisSupport; @Autowired private AgvService agvService; @Autowired private MainService mainService; @Autowired private ConfigService configService; @Autowired private LocService locService; @Autowired private StaService staService; @Autowired private TaskService taskService; @Autowired private AgvModelService agvModelService; @Autowired private SnowflakeIdWorker snowflakeIdWorker; @Scheduled(fixedDelay = 1000) // 固定频率执行,同步 private void execute() { String efficiency = configService.getVal("EfficiencyV2", String.class); // 1/0,23,1/2,1-5,1 1,60,7-ruku // 是否开启,1开启,0关闭 哪些区,1入库还是2出库,一次生成任务数量,最大任务数 if (!Cools.isEmpty(efficiency)) { String[] split = efficiency.split(","); if (split[0].equals("1")) { this.autoRun(LocGroupConstant.RIGHT_LOC_ROW_LIST, StaGroupConstant.RIGHT_STA_ROW_LIST, AgvGroupConstant.FOURTH_AGV_GROUP, 5, Integer.parseInt(split[1]), split[2]); } } } private void autoRun(List locGroupList, List staGroupList, List agvGroupList, Integer taskNum, Integer taskMax, String memo) { List staPreNos = getStaPrefixes(staGroupList); String staTaskMemo = "DEMO_STA_" + String.join("-", staPreNos) + "_" + memo; // 最多 ? 个任务运行 if (taskMax <= taskService.count(new LambdaQueryWrapper().in(Task::getTaskSts, TaskStsType.INIT.val(), TaskStsType.WAITING.val(), TaskStsType.ASSIGN.val(), TaskStsType.PROGRESS.val()).in(Task::getMemo, staTaskMemo))) { return; } Integer startRow = Collections.min(locGroupList); Integer endRow = Collections.max(locGroupList); LambdaQueryWrapper stockWrapper = new LambdaQueryWrapper().eq(Loc::getLocSts, LocStsType.STOCK.val()); if (null != startRow) { stockWrapper.ge(Loc::getRow, startRow); } if (null != endRow) { stockWrapper.le(Loc::getRow, endRow); } List stockList = locService.list(stockWrapper); if (Cools.isEmpty(stockList) || stockList.size() < 5) { return; } // 入库 this.runStaToLoc(locGroupList, staGroupList, staTaskMemo, taskNum, "4-1"); // 出库 this.runLocToSta(locGroupList, staGroupList, staTaskMemo, taskNum, "3-1"); } // 入库 private void runStaToLoc(List locGroupList, List staGroupList, String memo, Integer taskNum, String sta) { Integer startRow = Collections.min(locGroupList); Integer endRow = Collections.max(locGroupList); AgvModel agvModel = agvModelService.getOne(new LambdaQueryWrapper().eq(AgvModel::getType, AgvModelType.CTU_BOX_TRANSPORT_AGV.toString())); if (null == agvModel) { return; } // IDLE LambdaQueryWrapper idleWrapper = new LambdaQueryWrapper().eq(Loc::getLocSts, LocStsType.IDLE.val()); if (null != startRow) { idleWrapper.ge(Loc::getRow, startRow); } if (null != endRow) { idleWrapper.le(Loc::getRow, endRow); } List idleList = locService.list(idleWrapper); if (Cools.isEmpty(idleList)) { return; } Collections.shuffle(idleList); OpenBusSubmitParam param = new OpenBusSubmitParam(); param.setBatch(String.valueOf(snowflakeIdWorker.nextId()).substring(13, 19)); for (int i = 0; i < taskNum; i++) { Loc idleLoc = idleList.get(i); TaskDto taskDto = new TaskDto(); taskDto.setOriSta(sta); taskDto.setDestLoc(idleLoc.getLocNo()); taskDto.setPriority(100); taskDto.setSeqNum(String.valueOf(snowflakeIdWorker.nextId()).substring(11, 19)); taskDto.setMemo(memo); param.getTaskList().add(taskDto); } mainService.generateBusAndTask(param, memo); } // 出库 private void runLocToSta(List locGroupList, List staGroupList, String memo, Integer taskNum, String sta) { Integer startRow = Collections.min(locGroupList); Integer endRow = Collections.max(locGroupList); AgvModel agvModel = agvModelService.getOne(new LambdaQueryWrapper().eq(AgvModel::getType, AgvModelType.CTU_BOX_TRANSPORT_AGV.toString())); if (null == agvModel) { return; } // LOC STOCK LambdaQueryWrapper stockWrapper = new LambdaQueryWrapper().eq(Loc::getLocSts, LocStsType.STOCK.val()); if (null != startRow) { stockWrapper.ge(Loc::getRow, startRow); } if (null != endRow) { stockWrapper.le(Loc::getRow, endRow); } List stockList = locService.list(stockWrapper); if (Cools.isEmpty(stockList)) { return; } Collections.shuffle(stockList); OpenBusSubmitParam param = new OpenBusSubmitParam(); param.setBatch(String.valueOf(snowflakeIdWorker.nextId()).substring(13, 19)); for (int i = 0; i < taskNum; i++) { Loc stockLoc = stockList.get(i); TaskDto taskDto = new TaskDto(); taskDto.setOriLoc(stockLoc.getLocNo()); taskDto.setDestSta(sta); taskDto.setPriority(100); taskDto.setSeqNum(String.valueOf(snowflakeIdWorker.nextId()).substring(11, 19)); taskDto.setMemo(memo); param.getTaskList().add(taskDto); } mainService.generateBusAndTask(param, memo); } public static List getStaPrefixes(List staGroupList) { Set rowSet = new HashSet<>(); for (String s : staGroupList) { rowSet.add(s.split("-")[0]); } List result = new ArrayList<>(rowSet); result.sort(Comparator.comparingInt(Integer::parseInt)); return result; } private int getAvailableAgvCount(List agvNos) { int res = 0; if (Cools.isEmpty(agvNos)) { return res; } for (String agvNo : agvNos) { if (null == redis.getObject(RedisConstant.AGV_ONLINE_FLAG, agvNo)) { continue; } Agv agv = agvService.selectByUuid(agvNo); if (!agv.getStatusBool()) { continue; } res++; } return res; } }