OptaPlanner Медсестра Ростеринг совокупная сумма Исключение нулевого указателя

Я пытаюсь изменить пример списка медсестер OptaPlanner. Пока что я хочу написать правило в файле drl, которое реагирует, когда сотрудник работает более 13 часов в день. Я расширил класс shiftType, чтобы получить часы за смену.

На первый взгляд кажется, что правило работает, но когда через некоторое время не существует приемлемого решения, я получаю исключение NullPointerException.

Вот соответствующий код:

rule "dailyRestPeriod"
when


ShiftAssignment($employee : employee, $shiftType : shiftType, $shiftDate : shiftDate, $employee!=null)
$dailyTotalHours : Number( intValue > 13) from accumulate(
                 $assignmentEmployee:  ShiftAssignment(employee == $employee, shiftDate == $shiftDate),
            sum($assignmentEmployee.getShiftType().getShiftDurationHours())
        )
then

System.out.println("Employee " +$employee +" dailyTotal " +$dailyTotalHours);
 scoreHolder.addHardConstraintMatch(kcontext, - 1);
end

И часть исключения

Exception in thread "AWT-EventQueue-0" java.lang.IllegalStateException: Solving failed.
    at org.optaplanner.examples.common.swingui.SolverAndPersistenceFrame$SolveWorker.done(SolverAndPersistenceFrame.java:319)
    at javax.swing.SwingWorker$5.run(Unknown Source)
    at javax.swing.SwingWorker$DoSubmitAccumulativeRunnable.run(Unknown Source)
    at sun.swing.AccumulativeRunnable.run(Unknown Source)
    at javax.swing.SwingWorker$DoSubmitAccumulativeRunnable.actionPerformed(Unknown Source)
    at javax.swing.Timer.fireActionPerformed(Unknown Source)
    at javax.swing.Timer$DoPostEvent.run(Unknown Source)
    at java.awt.event.InvocationEvent.dispatch(Unknown Source)
    at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
    at java.awt.EventQueue.access$500(Unknown Source)
    at java.awt.EventQueue$3.run(Unknown Source)
    at java.awt.EventQueue$3.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
    at java.awt.EventQueue.dispatchEvent(Unknown Source)
    at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
    at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
    at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
    at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
    at java.awt.EventDispatchThread.run(Unknown Source)
Caused by: java.lang.RuntimeException: java.lang.NullPointerException
    at org.drools.core.rule.SingleAccumulate.reverse(SingleAccumulate.java:124)
    at org.drools.core.phreak.PhreakAccumulateNode.removeMatch(PhreakAccumulateNode.java:806)
    at org.drools.core.phreak.PhreakAccumulateNode.removePreviousMatchesForRightTuple(PhreakAccumulateNode.java:865)
    at org.drools.core.phreak.PhreakAccumulateNode.doRightUpdates(PhreakAccumulateNode.java:444)
    at org.drools.core.phreak.PhreakAccumulateNode.doNode(PhreakAccumulateNode.java:87)
    at org.drools.core.phreak.RuleNetworkEvaluator.switchOnDoBetaNode(RuleNetworkEvaluator.java:534)
    at org.drools.core.phreak.RuleNetworkEvaluator.evalBetaNode(RuleNetworkEvaluator.java:505)
    at org.drools.core.phreak.RuleNetworkEvaluator.evalNode(RuleNetworkEvaluator.java:341)
    at org.drools.core.phreak.RuleNetworkEvaluator.innerEval(RuleNetworkEvaluator.java:301)
    at org.drools.core.phreak.RuleNetworkEvaluator.outerEval(RuleNetworkEvaluator.java:136)
    at org.drools.core.phreak.RuleNetworkEvaluator.evaluateNetwork(RuleNetworkEvaluator.java:94)
    at org.drools.core.phreak.RuleExecutor.reEvaluateNetwork(RuleExecutor.java:194)
    at org.drools.core.phreak.RuleExecutor.evaluateNetworkAndFire(RuleExecutor.java:73)
    at org.drools.core.common.DefaultAgenda.fireNextItem(DefaultAgenda.java:970)
    at org.drools.core.common.DefaultAgenda.fireLoop(DefaultAgenda.java:1312)
    at org.drools.core.common.DefaultAgenda.fireAllRules(DefaultAgenda.java:1251)

person An Gi    schedule 08.03.2017    source источник
comment
Какая это версия Drools и OptaPlanner? Сообщение об ошибке NPE должно быть более понятным.   -  person Geoffrey De Smet    schedule 08.03.2017
comment
Я использую OptaPlanner 6.5.0 @GeoffreyDeSmet   -  person An Gi    schedule 09.03.2017
comment
Эта трассировка стека (NPE на реверсе) указывает на проблему в Drools: либо есть прямая ошибка в слюнях, либо когда пользователь делает что-то не так, слюни не сообщают об этом правильно. В любом случае это нужно исправить. Можете ли вы создать jira и прикрепить репродуктор?   -  person Geoffrey De Smet    schedule 10.03.2017


Ответы (1)


Я не понимаю, почему, но когда я немного меняю правило, оно отлично работает, когда я нарушаю правило. Возможно, это имеет какое-то отношение к параметрам планирования и объекту планирования, но я не уверен. Вот код, как он выглядит сейчас:

rule "dailyRestPeriod"
when
$employee : Employee()
$shift : Shift( $shiftType : shiftType ,  $shiftDate :shiftDate )
$dailyTotalHours : Number( intValue >= 13) from accumulate(
                 $assignmentEmployee:  ShiftAssignment(employee == $employee, shiftDate == $shiftDate),
            sum($assignmentEmployee.getShiftType().getShiftDurationHours())
        )
then
scoreHolder.addHardConstraintMatch(kcontext, - 1);
end
person An Gi    schedule 08.03.2017