我正在尝试将规划实体和问题事实连接到约束流中,但是我的集成开发环境抛出了一个错误:Cannot resolve method 'join(java.lang.Class<Edge>, org.optaplanner.core.api.score.stream.bi.BiJoiner<A,B>)'
我的问题结构与交通问题非常相似。我有节点和边,想要计算边的数量。
我的主要问题是:
class Node{
UUID id;
int itemsInInventory;
...
}和规划实体:
@PlanningEntity
class Edge{
Node from;
Node to;
@PlanningVariable
int itemsTransported;
getFromId(){return from.getId()}
getToId(){return to.getId()}
}约束的代码是:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Edge.class, equal(Edge::getFromId, Edge::getId))
...
}如果我尝试将边与边连接起来,例如:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Node, equal(Node:: getId, Node::getId)) //EDITED
...
}这是没有错误的工作。原因是,我试图将节点连接到节点中Edge属性的边中吗?有没有别的方法可以做我想做的事?
发布于 2021-04-26 23:11:38
我不得不说,我不明白后一个示例是如何工作的:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Node, equal(Node:: getId, Edge::getId))
...
}在本例中,您将加入Node和另一个Node。因此,equal(...) joiner需要在两端都使用Node,如下所示:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Node.class, equal(Node::getId, Node::getId))
...
}或者,更简短地说:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Node.class, equal(Node::getId))
...
}这也是您的第一个示例不能编译的原因:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Edge.class, equal(Edge::getFromId, Edge::getId))
...
}在本例中,您将使用Edge连接Node,因此equal(...) joiner需要在左侧使用Node,在右侧使用Edge,如下所示:
public Constraint minimizeShortage(ConstraintFactory constraintFactory) {
return constraintFactory.from(Node.class)
.join(Edge.class, equal(Node::getId, Edge::getFromId))
...
}https://stackoverflow.com/questions/67268488
复制相似问题