本调度平台旨在打造一个通用性更强的平台,在该平台上可以比较算法在标准调度案例上的性能。通用性体现在两个方面:算法实现和调度表达。算法通用性方面,平台支持各种不同的优化算法,包括启发式(简单规则)、元启发式(遗传算法,粒子群算法)和深度强化学习(这部分因为和课题相关,暂时也不发布),并且平台建立了完善的调度算法接口,可以实现各种想要实现的算法。问题通用性在于建立了通用的调度模型,可以表达单机调度问题,并行机调度问题,流水调度问题,作业车间调度问题和柔性作业车间调度问题,这些问题会在之后的版本发行中陆续给出。在当前v0.0.0版本只公开了使用启发式求解单机调度问题相关的代码。
JobShhopScheduler共包含两个Maven项目:instance-scheduler和web-scheduler。instance-scheduler是实现调度功能的核心项目,通过该项目可以使用不同的算法得到工序在何时由什么机床进行加工。web-scheduler是一个maven web项目,用于展示一些调度结果和算法学习过程。
本手册将给出完整的关于调度平台的使用说明。
注:本调度平台所使用到的所有安装程序和文件均可在这里找到,密码为nb31。
打开Eclipse,依次选择File->Import->Git->Projects from Git->Clone URI,Next之后填写Github远程仓库地址:https://github.com/hanbaoan123/JobShopScheduler.git,然后选择保存的目录即可。
代码导入后会出现报错,不要着急,这是因为java和maven等没有进行配置造成的。
- JDK配置
在Window->preferences中设置installed JRES,添加jdk(java8及以上版本),同时设置编译级别为1.8。关于JDK的安装与环境变量配置请自行百度。
- Maven配置
在Maven的User Settings中,选择maven的配置文件,关于如何安装和配置maven可以自行百度。
这时Eclipse会根据配置的maven自动的更新项目所需要的jar包,等待完成。
如果此时还有报错,则设置项目的编译路径,在项目上右键->Build Path->Configure Build Path,右侧Libraries中选择安装的jdk。
在该调度平台中已经事先生成好了单机调度标准案例,将“instance”文件夹复制到用户目录下(注意放在别的路径是无效的),如C:\Users\hba下,需要根据自己的系统和用户目录确定。
在instanceScheduler项目下的src/test/java中,给出了启发式调度运行的测试程序,直接右键Run As->Java Application即可。
结果可视化主要用于展示调度结果和算法学习过程,用于不同算法间性能的对比,目前只发布了甘特图的动态展示页面。