【译】Optaplanner开发手册本地化: (0) - 前言及概念
在此之前,针对APS写了一些理论性的文章;而对于Optaplanner也写了一些介绍性质,几少量入门级的帮助初学者走近Optaplanner。在此以后,老农将会按照Optaplanner官方的用户手册的结构,按章节地对其进行翻译,并成型一系列的操作说明文章。在文章中,为了降低对原文的理解难度,有些地方我不会直接按原文档的字面翻译,而是有可能加入一些我自己的理解,或添一些解释性的内容。毕竟英语环境下的思维和语言表达方式,跟中文或多或少会有差别的,所以如果全部按字面翻译,内容就非常生硬,可读性差,解程难度较大。我认为应该在理解了作者原意的基础上,再进一步以中文方式的表达,才算是真的的本地化。记得老农还是少农时,学习开发技术,需要阅读一些外国书箱的翻译本时,印象最深的是候捷老师的书,尽管《深入浅出MFC》,砖头厚度的书,硬是被我翻散了线,MFC尽管真的晦涩难懂,但候老却能把Windows的消息机制及MFC中整个个宏体系,系统地通俗地描述出来,令读者不需要花费太多精力去理解猜测书中字面的意义,大大降低的VC++中MFC的学习门槛。但老农毕竟只是一个一线开发人员,不是专业的技术资料翻译人才,不可能有候老师的专业水平,因此,我也只可尽我所能把内容尽量描述得通俗一些,让读者尽量容易理解,花费更少的时间掌握这些知道要点。
本文以Optaplanner 7.10.0 Final版本的开发手册作为基础进行翻译。
1. Optapplanner 介绍
1.1. 什么是Optaplanner?
每个组织都需要面对规划、排程问题:在有限的资源约束下提供服务与产品(例如人员,资产,时间及资本等限制)。Optaplanner可以优化这类规划、排程问题,令到使用它的组织可以用更少的资源做更多的事(尽可能的花少钱办大事)。这就是著名的的约束满足规划,它属于运筹学的一部分。
Optaplanner是一个轻量的、可嵌入的,可以对规划问题进行优化的约束满足引擎,它可以解决案例有:
- 员工排班:为护士、维修工等人员制定上班时间表。
- 方程安排:安排会议、约见、维修工作、广告时间等。
- 教育领域的时间安排:安排课程、课堂、考试、会议讲座等。
- 规划车辆运动路线:通过已知的地图工具,为货运、客运(货车、火车、轮船、航班等)规划交通工具多目标的运行路线。
- 装箱问题:向容器、货车、轮船和仓库装载货物,同时可以规划电脑的资源加载利用,例如云计算的资源分配问题。
- 车间生产安排:规划汽车组装生产线,机器队规划,劳动任务的规则等。
- 下料问题:在下料分割的时候,实量最小的浪费,例如切割纸张、钢铁、地毯等。
- 运动赛事安排:规划比赛和训练,例如安排足球联赛、棒球联赛等。
- 金融优化:投资组合优化、实现风险分散等。
1.2. 什么是规划问题?
一个规划问题,基于有限的资源和指定的约束,有一个优化目标。优化目标可以是多种事物,例如:
- 利润最大化 - 优化目标得出的结果是尽可以高的利润。
- 最小化生态足迹(即尽可能减少对生态的影响) - 优化目标是对环境产生尽可能小的影响。
- 最大化员工或客户的满足度 - 优化目标重视员工与客户的需要。
实现这些目标的能力依赖于可用资料的数量,例如:
- 人员数量
- 时间
- 预算
- 特殊资产,例如机台,车辆,计算机,建筑物等。
与这此资源相关的约束也必然计算在内,例如,一个人的工作小时数, 他们可使用(操作)的机台数量,设备之间的兼容性等。
Optaplanner可以帮助Java程序员有效地解决约束满足问题, 在Optaplanner引擎中,对每个有效的约束分数计算中,组合了启发式和元启发式算法。
1.2.1 规划问题属于NP-Complete问题或NP-hard问题
上述所有的案例或许都属于NP-complete/NP-hard问题,(什么是NP-Complete/NP-hard问题呢?),在外行人看来,它的定义是:
对于一个问题:
- 在合理时间内可以容易地验证一个给定的解。
- 在合理时间内,目前尚没有行之有效的解法,能找到其绝对最优解(注1)。
(注1):至少,到目前为止,仍未有一个世界上最聪明的计算机科学家能找到此方法。可是一旦他们找到对其中一个NP-Complete问题的有效解法,那么这个方法对所有NP-Complete问题都是可行办法。事实上,如果任何人只需证明是这种解法的存在与否,即可获得100万美元的奖励。
其实这其含义是相当悲观的:要解决这些问题或许比你预想中更困难,因为目前针对这种问题的常见两种技术是未足够解决此类问题的。这两种方法是:
- 暴力算法(尽管是一些优化过,相对聪明的暴力算法变种), 但获得其解所需的时间非常长(译者:主要原因是时间复杂度非常高)。
- 快速算法,例如在Bin packing问题中,先装入最大项;但得到的解离绝对最优解仍存在相当大距离的。
通过使用一些更高级的算法,Optaplanner可以在合理的时间内,对这些规划问题找到相对较优解。
1.2.2 规划问题存在约束(包括硬约束与软件约束)
通常来说,一个规划问题至少包括两个层次的约束:
- (负面)硬约束,不可被违反。例如:一个教师在同节的时间内不能同时上两门课。
- (负面)软件约束,若可避免,它不应该被违反。例如:教师都不太喜欢在周五下午上课。
也有些问题存在一些正面的约束:
- 正面分数在可能情况下应该实现。例如:教师B喜欢在周一上午上果。
一些比较基础的规划问题(例如8王后问题),只存在硬约束;有一些规划问题则存在超3层,甚至更多层次的约束。例如:硬约束,中间约束和软约束。
这些约束会被定义在规划问题的Score calculation里(也称为适应度函数)里。规划问题里的每一个解的优劣,都可以通过分数来评价。在Optaplanner中,分数约束是通过面向对象语文编写的,例如Java代码或通过Drools脚本实现的rules. 这些代码相当容易编写,灵活且易于扩展。
1.2.3 规划问题存在巨大的搜索空间
一个规划问题存在非常多的解,这些解可以分为以下数种:
- 可能解:规划问题的任意一个解都称作可能解,无论这个解是否违反了约束,或违反了多少约束。规划问题往往存在令人难以至今的巨量可能解,这里面很多解是毫无价值的。
- 可行解:规划问题的可行解是指没有违反任何(负面)硬约束的解。一个规划问题的可行解的数量,与其可能解相关。有时也不存在可行解,一个规划问题的每一个可行解,都是该问题的一个可能解。
- 绝对最优解:绝对最优解是这个规则问题获得约束分最高的那个解。规划问题通常只有1个或少量数个绝对最优解。通常存在至少1个绝对最优解,尽管当这个规划问题不存在可行解,它也存在绝对最优解,这时候绝对最优解就是非可行解。
- 相对最优解:相对最优解是指规划问题在一定的求解时间内得到评分最高的解。相对最优解通常是可行解,只要有足够的运行时间,找到的相对最优解就是绝对最优。
此外,尽管基于一个较小的数据集描述的一个规划问题,其可能解的数量通常是非常巨大的(如果计算正确的话)。正如你从示例中可以看到,大多数情况下,一个规划问题的可能解数量,对目前已知宇宙的原子数量还要多(10的80次方)。因为目前还没有直接的办法找出规划问题的绝对最优解,一些求解实现方法是通过暴力穷举的方法,至少可以穷举所有可能解中的一个子集。
OptaPlanner支持多种优化算法,以有效地涉足大量可能解,根据不同使用场景的情况,一些优化算法的性能比其它算法更佳,但哪个更佳是无法预先告知的(译者:需要通过Benchmark等功能测定)。在Optaplanner里,很容易能过修改几行XML内容或Java code,来更改求解器的配置,从而切换不同的优化算法。
【未完,待续...】
原创不易,如果觉得文章对你有帮助,欢迎点赞、评论。文章有疏漏之处,欢迎批评指正。
本系列文章在公众号不定时连载,请关注公众号(让APS成为可能)及时接收,二维码:
如需了解更多关于Optaplanner的应用,请发电邮致:kentbill@gmail.com
或到讨论组发表你的意见:https://groups.google.com/forum/#!forum/optaplanner-cn
若有需要可添加本人微信(13631823503)或QQ(12977379)实时沟通,但因本人日常工作繁忙,通过微信,QQ等工具可能无法深入沟通,较复杂的问题,建议以邮件或讨论组方式提出。(讨论组属于google邮件列表,国内网络可能较难访问,需自行解决)
【译】Optaplanner开发手册本地化: (0) - 前言及概念的更多相关文章
- 【miscellaneous】 GStreamer应用开发手册学习笔记之基础概念介绍
第3章. 基础概念介绍 本章将介绍GStreamer的基本概念. 理解这些概念对于你后续的学习非常重要,因为后续深入的讲解我们都假定你已经完全理解了这些概念. 3.1. 元件(Elements) 元件 ...
- 阿里巴巴 JAVA 开发手册
阿里巴巴 JAVA 开发手册 1.0.0 阿里巴巴集团技术部 2016.12.7 首次向 Java 业界公开 一. 编程规约(一) 命名规约1. [强制]所有编程相关命名均不能以下划线或美元符号开始, ...
- 阿里巴巴 Java 开发手册 1.4.0
一.编程规约(一) 命名风格1. [强制]代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束.反例: _name / __name / $name / name_ / name$ ...
- 读阿里巴巴Java开发手册v1.2.0之工程结构有感【架构篇】
首先,把昨天那俩条sql语句的优化原因给大家补充一下,第一条效率极低,第二条优化后的,sql语句截图如下: 经过几个高手的评论和个人的分析: 第一条sql语句查询很慢是因为它首先使用了in关键字查询, ...
- 读阿里巴巴Java开发手册v1.2.0之编程规约有感【架构篇】
不为过去蹉跎,改变当下. 为什么开篇就送这么一句话给大家,我相信很多处于1-3年码龄的哥们儿们,在平时的编码历程中编码的个性可能是多彩的,每个人都有每个人特定的风格,但是我们现在这么随意写,以后这么 ...
- 阿里Java开发手册1.3.0 文字版
版本: 1.3.0 update: 2017.9.25 一.编程规约 (一) 命名风格 1. [强制]代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束. 反例:_name _na ...
- 304902阿里巴巴Java开发手册1.4.0
转自官网 前言 <阿里巴巴Java开发手册>是阿里巴巴集团技术团队的集体智慧结晶和经验总结,经历了多次大规模一线实战的检验及不断完善,系统化地整理成册,回馈给广大开发者.现代软件行业的高速 ...
- 《阿里巴巴Java开发手册1.4.0》阅读总结与心得(五)
笔者作为一名有数年工作经验的Java程序员,仔细研读了这份手册,觉得其是一份不可多得的好材料.阿里巴巴在发布时所说,“阿里巴巴集团推出的<阿里巴巴Java开发手册(正式版)>是阿里巴巴近万 ...
- 安卓开发开发规范手册V1.0
安卓开发开发规范手册V1.0 之前发布过一份Web安全开发规范手册V1.0,看到收藏文章的读者挺多,发现整理这些文档还挺有意义. 最近周末抽了些时间把之前收集关于安卓安全开发的资料也整理了一下,整理出 ...
随机推荐
- Sublime使用及配置C编译器
一.环境配置 在安装了MinGW+Gcc的基础上做如下设置—— 新建编译系统c.sublime-build: { "cmd" : ["gcc", "$ ...
- mknod语法
1.语法 mknod [选项] 设备名 设备类型 主设备号 次设备号 2.选项参数列表 选项 说明 --version 显示命令版本信息 --help 显示帮助信息 -m | - ...
- WINDOWS7环境下Informatica的安装[新手]
环境: 操作系统:Windows7(64位): 数据库:Oracle 11g R2: 数据库字符集:UTF-8 一.下载: (参考链接:https://blog.csdn.net/u011031430 ...
- 在Java中用 . 深层访问JSON数据
本文介绍Java中解析JSON的一种方法,可以让我们在Java程序中也用x.x.x的形式访问JSON数据中的值. 代码大部分来源非本人,本人在源代码基础上加以修改以使正常运行. 代码: // 将提取方 ...
- iOS原生自动布局NSLayoutConstraint
AutoLayout概念是苹果自iOS6开始引入的概念. 目前为止,实现自动布局技术选型方面也可以使用xib和storyboard.在开发过程中通常登录.注册等变动可能性较小的视图,我会采用xib开发 ...
- [转]大白话讲解Promise(一)
http://www.cnblogs.com/lvdabao/p/es6-promise-1.html 去年6月份, ES2015正式发布(也就是ES6,ES6是它的乳名),其中Promise被列为正 ...
- Kafka如何彻底删除topic及数据
前言:删除kafka topic及其数据,严格来说并不是很难的操作.但是,往往给kafka 使用者带来诸多问题.项目组之前接触过多个开发者,发现都会偶然出现无法彻底删除kafka的情况.本文总结多个删 ...
- python 启动时报错无法正常启动(0xc000007b)请单击“确定”关闭应用程序的解决办法
这是一个自己非常傻逼的问题,但是还是想记录下来 晚上安装python,不管是命令提示符中运行还是python直接打开,都提示报错 各种百度,各种查找排除以后,皆不能解决错误 最后发现:特么64位系统下 ...
- Linux装系统问题
最近要把以前的Linux red hat 5.3,32位的系统换成Linux red hat6.2 64位系统,中间出现问题,不知道为什么系统装完之后回滚,还是之前的5.3.,为此纠结好久,终于找到问 ...
- day09 函数学习
内容详细 1.函数 1.1.面向过程: 可读性差/可重用差 1.2.面向对象: