首页 > 解决方案 > Optaplanner VRP 示例,同一时间窗口内每次停靠需要多辆车

问题描述

我们正在使用定制的VRP教程示例来优化服务工程师前往客户那里执行某些维修和安装任务的日常路线。我们确实有时间窗口,我们会在未来数周内优化 1000 多项任务。

我们的(简化的)领域模型包括:


作为一项新要求,我们现在必须支持两名工程师在同一任务上并行工作。

我们目前的计划是通过为第二个工程师创建子任务来实现这一点,并实施一个规则,即他们的到达时间必须与主要任务相同。然而,这是有问题的,因为将相互依赖的任务之一移动到不同的时间(例如,不同的 DailyRoute)将主要违反上述约束。

到目前为止,我们已经提出了以下想法:

标签: optaplannervehicle-routing

解决方案


对于同时从事同一任务的两名工程师,请参阅文档“设计模式”,特别是“延迟到最后一个模式”。没有示例,但我们的支持服务已经帮助实施了几次 - 它有效。

对于同一位置的多个站点:我已经看到用户将此类访问分成更小的部分,以允许 optaplanner 选择要聚合的部分。它有效,但并不完美:碎片越细,搜索空间就越大 - 添加一个专注于将所有碎片移动在一起的自定义移动可能会有所帮助(但我不会从它开始)。一般来说:如果最小的车辆的容量为 100,我会进行一些实验,将容量分成一半 - 他们也尝试四分之一,只是为了通过 optaplanner-benchmark 进行基准测试来看看什么效果最好。


推荐阅读