当前位置: 首页 > 知识库问答 >
问题:

允许与OptaPlanner和TSPTW重叠

司徒云
2023-03-14

我认为我可以实现这一点的方法是:

  1. 为每一个Type A任务指定第二个(非链接的)计划变量,称为OverlappingTask。
  2. 将当前的“Tasks”ValueRangeProvider拆分为两个ValueRangeProviders:“TypeaTasks”和“TypeBTasks”。
  3. 将PreviousTask的ValueRangeProviders注释为typeATasks和TypeBTasks。
  4. 将OverlappingTask的ValueRangeProviders注释为仅为TypebTasks。

我正在解决的问题将始终至少有一个A型任务,但可能没有任何B型任务。这给我提出的解决方案带来了一个问题,因为“TypebTasks”ValueRangeProvider有时为空,这会为previousTask规划变量抛出一个IllegalStateException。

有没有更好的方法来解决这个问题?有没有办法解决ValueRangeProvider的空问题?鉴于ValueRangeProviders的组合不是空的,对previousTask的空洞抱怨似乎很奇怪。似乎OptaPlanner最好检查组合是否为空,而不是单独检查每个输入。

下面是一些代码片段来阐明当前的设计:

public Solution
{
    @PlanningEntityCollectionProperty
    @ValueRangeProvider(id = "typeATasks")
    public List<TypeA> getTypeATasks)

    @PlanningEntityCollectionProperty
    @ValueRangeProvider(id = "typeBTasks")
    public List<TypeB> getTypeBTasks()
}

public class Task
{
    @PlanningVariable(valueRangeProviderRefs = { "typeATasks", "typeBTasks" },
                      graphType = PlanningVariableGraphType.CHAINED)
    public Task getPreviousTask()
}

public class TaskB extends Task {}

public class TaskA extends Task
{
    @PlanningVariable(valueRangeProviderRefs = { "typeBTasks" }, nullable = true)
    public TaskB getOverlappingTask()
}

共有1个答案

魏臻
2023-03-14

不是说你的模型不好,让我们把你的建议叫做C)。看到我上面的评论,这是optaplanner 6.4.0的一个bug。Beta2在那个模型上很快就失败了。

但我想到了一个这样的模型,提案a):

@PlanningEntity class TaskAssignment {
    TaskDef taskDef;
    @PlanningVariable TaskAssignment previousTaskAssignment;
    @PlanningVariable Boolean overlapPreviousIfPossible;

    boolean isOverLappingPrevious {
        return taskDef.isTypeB() && overlapPreviousIfPossible;
    }
}

在这种情况下,值范围提供程序只返回所有TaskAssignments。

 类似资料:
  • 问题内容: 我似乎无法使实例正常工作。我使用的代码如下: 子类 该代码输出 问题答案: 您需要覆盖。而不是这样做,您实现了一个带有signature 的方法。因此,您使用的是为相等性测试定义的默认方法。 默认实现基于对象标识,因此,该集合“允许”您添加两个在语义上相等的不同对象。

  • Meteor 的安全系统不需要我们在每次修改数据的时候,在各自的函数里面进行手动检查。 例如,对于一个博客系统,我们常常需要做很多操作,往新帖子上添加属性,当发布帖子的时候进行特定检查。这些操作都是围绕帖子(post)这个对象进行的,所以我们应该为帖子设置一个专门的函数进行安全检查。 但在另一方面,我们又不希望为修改帖子或删除帖子这些简单的操作编写特定的函数。我们只需要在这些操作之前,检查用户是否

  • Android官方文档指出,不建议使用,因为它可能会长时间锁定UI并触发ANR。但是Kotlin协同程序使我们能够在主线程中执行一些操作,而不会有效地阻塞UI。 所以我要问:使用并在主线程上运行的Couroutine作用域中访问数据库是否安全?如下所示: 或者我们应该坚持不允许主线程查询和在另一个线程中执行数据库查询的旧方法? 我这样问是因为前一种方式(使用): 更具可读性(我可以在访问数据库的函

  • 问题内容: 我需要对元素进行排序,但不会删除重复项。 我已经去了,因为实际上将值添加到支持的: 然后TreeMap使用 逻辑删除重复项 我写了一个在元素相等的情况下返回1而不是0的a 。因此,在元素相等的情况下,带有此元素将不会覆盖重复项,而只会对其进行排序。 我已经为简单对象测试过,但是我需要一组自定义对象。 这种方法是好的还是有更好的方法来实现呢? 编辑 实际上,我有以下类的ArrayList

  • 我正在检查< code>HashSet的< code>add方法。有人提到 如果该集合已经包含元素,则调用保持集合不变,并返回false。 但是方法在内部保存中的值 的方法声明 将指定值与该映射中的指定键相关联。如果映射先前包含该键的映射,则旧值将被替换。 那么,如果 的 方法替换了旧值,那么 方法如何在元素重复的情况下保持集合不变?

  • 我一直在捕捉非数字时遇到问题。 我试过了,但抓不住。如果我让它捕获非数字,但不让用户再次尝试输入。。。它完全停止了我的代码。 这是我的密码:

  • 答:[65,65,65,A]但我料到了[65,A]

  • 问题内容: 编辑:当我说“ SQL Server”时,我实际上是在谈论Management Studio。 抱歉,这令人困惑。 哦,我讨厌这种事情发生。昨天我在使用SQL Server,并尝试使用PIVOT命令来弄清楚它是如何工作的。因此,我创建了一个包含四列的新表,第一列的前几行将具有相同的值。 我在第一行,第一列中添加了“ value1”,然后按回车键–因为还没有添加任何键或约束,它使我可以向