OptaPlanner创办人Geoffrey De Smet及其团队,在Red Hat 技术峰会上主题会场上,演示了一个通过OptaPlanner实现实时规划与调度的示例。Geoffrey及其团队专门为此分三篇博文描述了该程序。该程序及其相关博文是OptaPlanner在VRP领域极之经典之作。本系列也分三篇对博文进行翻译,以飨各位ORer, APSer和Planner.

目前本人正在研究该程序,未来将会进一步对该程序作更深入的分析,并形成博文,分享其中奥妙。

【以下为译文】

今年,我和我的团队在Red Hat技术峰会上作了主旨演讲。在7000人面前,我们演示了一个实时调度程序,该程序可以实现对现场观众通过手机App的输入进行实时反应。在过去两个月里,我们的团队和其它中间件的团队一起协同,在Burr Sutter的出色指导下,创建了这个实时调度程序。这个程序集成了多种技术,例如Android/iPhone的加速感应器,还有OpenShift / Kubernetes, Quarkus, KNative, TensorFlow, Kafka/Strimzi, Camel, Node.js, Godot, Infinispan, Drools等,当然少不了主角OptaPlanner.

我们写了一个模拟器,模拟一个典型的地板生产场景,场景中涉及装配线上的机械。当我第一次向我和妻子展示这个程序时,引发了一个有趣的对话:

"看,亲爱的,这是在主旨演讲上的示例程序,我们过去两周时间一直在努力(构建它)"

"看起来像小游戏,那些是Mario和Luigi在到处跑吗?"

"注意,(这些是机器维修师)它演示了OptaPlanner是如何优化他们的行走时间,使他们可以花更多的时候在维修机械上。"

"你打算就把这玩艺展示给7000多个商务客呀?"

"当然,展示将会非常精彩."

程序运行的效率如下:

现有10台机器(编号从A到J)运行过程中会出现磨损,并通过传感器检查发现磨损情况。(现场观众安装和我们的APP)在现场观众的帮忙下,我们通过获取他们手机上的加速感应器的数据,来模拟传感器。正所谓当事物变得越摇摇欲坠时,它就变更脆弱。当观众拼命摇晃,或用手机做出其它晃动的动作时,程序中对应的机器就会收到损坏信息。(由于人数众多),现场的每一部分观众通过晃动手机,就会向对应的一台机器发送损害信息为,对应机器的健康值就会减少。如果有一台机器的健康值降到0,那就表示这台机器崩溃了。

此时,那些受损的机器在它们崩溃之前安排维修,这就是OptaPlanner用武之地了。程序中有2到3名机械师来修复这些受损的机器,与机械师们在机器之间穿梭,及在修复机器的同时,所有机器都在持续地降低健康值(现场观众正在持续拼命地晃动他们的手机)。在安排机器时工作时,决定各个机器的维修次序是很困难的,因为损坏无时无刻地发生着。幸亏,OptaPlanner为帮我们调度这些机械师,它会实时地对机台健康的变化作出反映,如视频所示:

示例视频

(下面讨论一下规划程序的具体设计)

这个规划问题的挑战

规划目标只有一个:不能让做任意一个机台的健康值掉到0%。这看起来是一个简单的约束,但事实上它存在两个冲突的约束:

  1. 优先修复健康值最低的机器,因为最低健康值的机器,其崩溃的风险最高。
  2. 通过让机械师走最短的穿梭路径,让机械师尽量快的时间修复就近的机器 。原因如下:
    1. 机器时需要进行修复机器之外,还需要在机器之间到处到动,通过减少他们的穿梭时间,提高他们的生产力。
    2. 若只考虑最短路径一个约束,这就是一个TSP问题(旅行商问题)。

上述两个约束存在竞争的,它们各自会偏向输出以下不同的解决方案:

这两种约束对完成时间的影响差别不太明显,即如何影响机械师一次修复所有有故障机器的所需时间。维修的时间越长,将会降低生产力:

因此,我们最终需要权衡这两种约束。我们通过对每台损坏的机器评定惩罚性分数,将损坏量乘以持续时间,直到该机器被修复为止。因此,OptaPlanner规划出来的方案中,将会尽可能地避免让机器的损坏程度增大,或尽可能将机器处于损坏状态的时间减少。

这只是一个车辆路线规划问题(VRP)

在运筹学的学术界,此类问题也被称为车辆路线规则问题(Vehicle Routing Problem - VRP), 在该类问题中,我们需要一些车辆(例如货车)发送到多个目的地。

通过上图可以看出,这些只是存在一些约束差别的相同问题。

目前OptaPlanner确实擅长于求解车辆路线规划问题的优化:通过对整个车辆运行时间达到15%甚至更多的时间减少,我们每年为一些客户节省了数亿美元。同时也大大地减少了车辆的能源消耗,从而减少了碳排放,因此对环保也相当有益。

了解更多关于OptaPlanner在VRP问题的优化,或看一下Jiri(OptaPlanner项目另一位成员)在VRP问题的最新Demo,演示视频如下:

(机械师调度程序中)现实的挑战

首先,实现这种车辆路线规划的变种问题其实并不复杂,但要让程序的交互与演示运行得足够流畅,我们面临着更大的挑战。毕竟,我们不能冒着在演示期间,在观众与老板,包括我们的CEO Jim Whitehurst 面前程序崩溃的险。

  • 要了解有关我们的架构以及与所有其他技术的集成的更多信息,请阅读Musa的文章(第2部分)。
  • 要了解有关扩展挑战以及我们运行的模拟和负载测试的基准的更多信息,请阅读Radovan的文章(第3部分)。

如果想自己调度这个程序,可以从这里下载并根据readme的介绍进行调度。

End.


创作不易,欢迎转载,请标明出处。
本系列文章在公众号不定时连载,请关注公众号(让APS成为可能)及时接收,二维码:
如需了解更多关于OptaPlanner的应用,请发电邮致:kentbill@gmail.com
或到讨论组发表你的意见:https://groups.google.com/forum/#!forum/optaplanner-cn
若有需要可添加本人微信(13631823503)或QQ(12977379)实时沟通,但因本人日常工作繁忙,通过微信,QQ等工具可能无法深入沟通,较复杂的问题,建议以邮件或讨论组方式提出。(讨论组属于google邮件列表,国内网络可能较难访问,需自行解决)

机械师实时调度示例(I) - 实时规划相关推荐

  1. 《机械师实时调度示例(I) - 实时规划》的视频翻译

    之前翻译了红帽2019年技术峰会上,OptaPlanner演示实时调度的一个案例中的文章.其中关于案例的讲解,最近有时间将它翻译一下,大家可以结合视频来细看该文章. <机械师实时调度示例(I) ...

  2. linux什么是实时调度,Linux 实时调度 示例

    在上一篇博文中进行了原理性分析之后,本文举出一个实例进行分析(假设所有的cpu处于同一个cpuset中). 当前系统中cpu的情况如下如所示: 说明:0~99代表的是进程的实时优先级,cpu的状态与该 ...

  3. 【Linux 内核】实时调度类 ① ( 进程分类 | 实时进程、普通进程 | Linux 内核 SCHED_FIFO、SCHED_RR 调度策略 | 实时调度实体 sched_rt_entity )

    文章目录 一.进程分类 ( 实时进程 | 普通进程 ) 二.Linux 内核调度策略 1.SCHED_FIFO 调度策略 2.SCHED_RR 调度策略 三.实时调度实体 sched_rt_entit ...

  4. Linux内核进程管理实时调度与SMP

    一,实时调度器类 实时调度类有两类进程: 循环进程SCHED_RR:循环进程有时间片,随着进程的运行时间会减少.当时间片用完时又将其置为初值,并将进程置于队列末尾.先进先出SCHED_FIFO:没有时 ...

  5. 【操作系统/OS笔记10】进程/线程的调度原则、调度算法、实时调度、多处理器调度、优先级反转

    本次笔记内容: 8.1 背景 8.2 调度原则 8.3 调度算法1 8.4 调度算法2 8.5 实时调度 8.6 多处理调度与优先级反转 文章目录 CPU调度背景 上下文切换 CPU调度 在进程/线程 ...

  6. java可以实现agv调度吗_AGV路线优化及实时调度

    对于单台的AGV的搬运很简单,对于多台AGV如何合理的安排,使其工作效率达到最高,这就需要用到AGV调度系统.AGV调度系统一旦为AGV指定好路径后,AGV上的车载控制器会根据指令完成具体的运动控制任 ...

  7. 百度地图绘制实时路线以及最短线路规划

    如何使用百度地图绘制实时路线以及最短线路规划 最近在做百度地图的实时路线绘制,发现一些问题,比如由于定位漂移带来的路线绘制偏差,还有由于定位漂移,导致人未走动时,也会绘制路线等.百度鹰眼的线路纠偏个人 ...

  8. Linux进程调度 - 实时调度器 LoyenWang

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...

  9. Linux进程管理 (9)实时调度类分析,以及FIFO和RR对比实验

    关键词:rt_sched_class.SCHED_FIFO.SCHED_RR.sched_setscheduler().sched_setaffinity().RR_TIMESLICE. 本文主要关注 ...

最新文章

  1. Vue2.0中引入element-ui
  2. Ajax Toolkit日历控件CalendarExtender求教!
  3. 重置linux内核,Linux Kernel 驱动非授权重置统计漏洞
  4. UART串口通信浅谈之(一)--基础概述
  5. POJ 3061 -- Subsequence(二分)
  6. XorPay.com 支付平台介绍【免费申请个人微信支付接口】
  7. 80%的程序员都不了解的调试技巧
  8. 【无标题】物联网安全挑战:为什么企业现在必须评估它们
  9. 前端学习(2861):简单秒杀系统学习之前端优化css
  10. html中怎么自动获得搜索文本框的光标焦点
  11. 2012-11-25学习笔记
  12. django 定制admin
  13. 方舟手游服务器能修改密码吗,明日方舟怎么改密码_明日方舟改密码方法详细解析一览[多图]...
  14. 对waitpid 的学习
  15. absolute绝对定位的参考坐标和参考对象问题详解
  16. 【GAPPER乡村笔记项目】盘点老龄化社会背景下人工智能及机器人技术的应用
  17. PowerPoint放映时的动画怎么取消?
  18. 入行 AI,如何选个脚踏实地的岗位?
  19. python数据采集2-HTML解析
  20. Python爬取拉钩招聘网,用数据告诉你这类程序员最赚钱

热门文章

  1. Andorid BluetoothSocket的工作原理之二
  2. google运行速度最近突然变慢了!!怎么回事!!!完美解决!!
  3. vue3+ts 之echarts的使用 以及 echarts 图表初始不渲染,代码改变之后才渲染
  4. 2023年谷歌seo排名优化指南
  5. mysql跳板机怎么搭建_Jumpserver跳板机的搭建和部署
  6. 傻瓜攻略(十二)——MATLAB实现偏最小二乘回归PLS
  7. MySql语句查询某一级节点的所有子节点
  8. QQ--基于TCP/UDP协议的通讯原理
  9. hello new one
  10. 阿根廷接连赢下3次空中球