0

嗨,我刚开始将 OptaPlanner 与流口水结合使用。但是我有两个问题。我相信这取决于我对语法的理解。

当我尝试实例化求解器时,以下规则会引发错误。

//Soft constraints
rule "waistedArea"
    when
        $sheet : Sheet($area: (area * 10000))
        $usedAreaTotal : Number (intValue > 0 && intValue < $area ) from accumulate(
            Part(
                    sheet == $sheet,
                    $usedArea : requiredArea * 10000
                ),
            sum($usedArea)
        ) 
        $waste : ($area - $usedAreaTotal)
        eval($waste > 0)
     then
        insertLogical(new IntConstraintOccurrence("waistedArea", constraintType.NEGATIVE_SOFT, $waste,$sheet)
    end

乘以 10000 是从 double 值到 int 的临时强制转换,但要知道它的语法。

该规则旨在计算分配有许多组件的工作表的腰围值。

该规则引发以下错误。

Message [id=1, level=ERROR, path=optaplanner-kie-namespace//Resources/DRLRools
/NestingRules.drl, line=71, column=0
   text=[ERR 102] Line 71:24 mismatched input '-' in rule "waistedArea"]
Message [id=2, level=ERROR, path=optaplanner-kie-namespace//Resources/DRLRools
/NestingRules.drl, line=0, column=0
   text=Parser returned a null Package]

任何解释都会有所帮助。

4

1 回答 1

1

您不能这样写,因为它不是“条件元素”:

$waste : ($area - $usedAreaTotal)

这就足够了:

eval($area > $usedAreaTotal)

我看不出乘以 10000 的任何充分理由 - 最后,您比较两个值,乘以 10000 不会改变关系。Number也有doubleValue()

并且:它被称为废物-腰部是你的腰带所在的地方:-)

于 2014-06-09T09:41:10.263 回答