关于OptaPlanner的使用(三)——运行代码案例

简介: 关于OptaPlanner的使用(三)——运行代码案例

打开下载的Optaplanner的示例的example的source文件件,可以看到这是一个maven的java项目,将这个项目导入到IDEA中,等待依赖jar包下载完成,就可以运行了。 项目结构大概如下:

案例中的一些计算机和任务的参数在data文件夹下。


java文件下写的是对于各种情况的规划问题的代码,resource中写的是一些计算规则,比如使用什么算法计算,目标是得到什么结果,什么时候计算结束等。

运行app文件下的OptaPlannerExamplesApp.java的main方法,就会打开之前的示例界面。和执行runExamples.bat的效果是一样的。


还是以Cloud balancing为例,打开Cloud balancing文件下的app文件夹,有两个java文件,一个是CloudBalancingApp,运行结果是会出现Cloud balancing的运行界面。另一个是CloudBalancingHelloWorld,运行的话会进行规划运算。源码写的比较复杂,我们先简单看一下运算步骤的代码。

public static void main(String[] args) {
        // Build the Solver
        //建立一个创建solver的工厂,内容从cloudBalancingSolverConfig.xml中获取。
        SolverFactory<CloudBalance> solverFactory = SolverFactory.createFromXmlResource(
"org/optaplanner/examples/cloudbalancing/solver/cloudBalancingSolverConfig.xml");
        //创建一个solver,可以理解为规划算法计算的对象,会规定使用什么算法,要达到什么目的等       
        Solver<CloudBalance> solver = solverFactory.buildSolver();
        int computerSize = 2;int processLise = 6;//这是我自己加的变量,之前案例里的计算机数和任务数是写死的。
        // Load a problem with 400 computers and 1200 processes
        //这一步是初始化需要被规划的计算机和任务对象
        CloudBalance unsolvedCloudBalance = new CloudBalancingGenerator().createCloudBalance(computerSize , processLise );
        // Solve the problem
        //对计算机和任务使用solver开始进行规划
        CloudBalance solvedCloudBalance = solver.solve(unsolvedCloudBalance);
        // Display the result
       System.out.println("\nSolved cloudBalance with "+computerSize+" computers and "+processLise+" processes:\n"
+ toDisplayString(solvedCloudBalance));
    }
    public static String toDisplayString(CloudBalance cloudBalance) {
        StringBuilder displayString = new StringBuilder();
        for (CloudProcess process : cloudBalance.getProcessList()) {
            CloudComputer computer = process.getComputer();
            displayString.append("  ").append(process.getLabel()).append(" -> ")
                    .append(computer == null ? null : computer.getLabel()).append("\n");
        }
        return displayString.toString();
    }

运行这个main方法,结果如下:

控制台中打印出了规划的过程和最终的规划结果。

这里是对两台电脑和六个任务的排序,结果是应该很快出来的,但是如果要规划几千台计算机和几万个任务的话,可能要规划出最终的最优结果需要很长的时间。所以在cloudBalancingSolverConfig.xml中有一个配

<!-- Optimization algorithms configuration -->
  <termination>
    <minutesSpentLimit>2</minutesSpentLimit>
  </termination>

限制是规划算法进行2分钟以后取得结果。

如果很快就找到最优解了,也要运行够两分钟才会出现计算结果,如果两分钟没有计算出最完美的结果,也会在2分钟的时候停止计算,返回结果。这个要根据需要被规划的数据量和情况多少来设置计算时间,保证能在计算停止的时候,能得到近似最优解的规划方案。(一般的情况下,2分钟够用了)


好吧,暂时先到此为止,真正想把自己的业务放进optaplanner里的时候才发现这个真心需要不少学习成本,连能不能实现还不知道。。。。。。

目录
相关文章
|
算法 Java 决策智能
运筹优化工具库介绍(一)
运筹优化问题有时候极其复杂,我们可以使用运筹优化工具库帮助数学建模,解决复杂的最优化问题,本文介绍几个常见的运筹优化工具库。
2844 0
|
11月前
|
安全 Java 编译器
JD-GUI,java反编译工具及原理: JavaDecompiler一个Java反编译器
Java Decompiler (JD-GUI) 是一款由 Pavel Kouznetsov 开发的图形化 Java 反编译工具,支持 Windows、Linux 和 Mac Os。它能将 `.class` 文件反编译为 Java 源代码,支持多文件标签浏览、高亮显示,并兼容 Java 5 及以上版本。JD-GUI 支持对整个 Jar 文件进行反编译,可跳转源码,适用于多种 JDK 和编译器。其原理基于将字节码转换为抽象语法树 (AST),再通过反编译生成代码。尽管程序可能带来安全风险,但可通过代码混淆降低可读性。最新版修复了多项识别错误并优化了内存管理。
9329 1
|
11月前
|
Java API 微服务
Java 21 与 Spring Boot 3.2 微服务开发从入门到精通实操指南
《Java 21与Spring Boot 3.2微服务开发实践》摘要: 本文基于Java 21和Spring Boot 3.2最新特性,通过完整代码示例展示了微服务开发全流程。主要内容包括:1) 使用Spring Initializr初始化项目,集成Web、JPA、H2等组件;2) 配置虚拟线程支持高并发;3) 采用记录类优化DTO设计;4) 实现JPA Repository与Stream API数据访问;5) 服务层整合虚拟线程异步处理和结构化并发;6) 构建RESTful API并使用Springdoc生成文档。文中特别演示了虚拟线程配置(@Async)和StructuredTaskSco
1154 0
|
算法 Java Linux
java制作海报二:java使用Graphics2D 在图片上合成另一个照片,并将照片切割成头像,头像切割成圆形方法详解
这篇文章介绍了如何使用Java的Graphics2D类在图片上合成另一个照片,并将照片切割成圆形头像的方法。
303 1
java制作海报二:java使用Graphics2D 在图片上合成另一个照片,并将照片切割成头像,头像切割成圆形方法详解
|
开发框架 供应链 JavaScript
齐套检查与分配在生产计划中的实现
最近一段时间看到很多关于生产计划中,作齐套检查与分析讨论,正好我们的易排1.5版添加了类似功能。本文结合易排平台上相应的功能与特征,介绍一下我们在这方面的些许研究结论与看法。
749 0
|
Java 数据处理
接口设计规范
接口设计规范
934 2
|
JavaScript iOS开发 MacOS
掌握NVM、NRM和NPM:Node.js开发的利器
掌握NVM、NRM和NPM:Node.js开发的利器
691 0
|
安全 PHP
文件上传漏洞(low,medium,high)
文件上传漏洞(low,medium,high)
214 0
文件上传漏洞(low,medium,high)
关于OptaPlanner的使用(二)——运行案例
关于OptaPlanner的使用(二)——运行案例
418 0

热门文章

最新文章