<html><body><div style="color:#000; background-color:#fff; font-family:arial, helvetica, sans-serif;font-size:10pt"><div><span>Anyone having an idea?</span></div><div style="color: rgb(0, 0, 0); font-size: 13.3333px; font-family: arial,helvetica,sans-serif; background-color: transparent; font-style: normal;"><br><span></span></div><div style="color: rgb(0, 0, 0); font-size: 13.3333px; font-family: arial,helvetica,sans-serif; background-color: transparent; font-style: normal;"><span>Thanks</span></div><div style="color: rgb(0, 0, 0); font-size: 13.3333px; font-family: arial,helvetica,sans-serif; background-color: transparent; font-style: normal;"><br><span></span></div><div style="color: rgb(0, 0, 0); font-size: 13.3333px; font-family: arial,helvetica,sans-serif; background-color: transparent; font-style: normal;"><span>Michiel</span></div><div>&nbsp;</div><div>-----------------<br>http://www.codessentials.com - Your essential software, for
 free!<br>Follow us at http://twitter.com/#!/Codessentials<br></div>  <div style="font-family: arial, helvetica, sans-serif; font-size: 10pt;"> <div style="font-family: times new roman, new york, times, serif; font-size: 12pt;"> <div dir="ltr"> <font face="Arial" size="2"> ----- Forwarded Message -----<br>  <b><span style="font-weight:bold;">From:</span></b> Michiel Vermandel &lt;mvermand@yahoo.com&gt;<br> <b><span style="font-weight: bold;">To:</span></b> Rules lists.jboss.org &lt;rules-users@lists.jboss.org&gt; <br> <b><span style="font-weight: bold;">Sent:</span></b> Thursday, February 28, 2013 8:54 PM<br> <b><span style="font-weight: bold;">Subject:</span></b> [rules-users] constraints lacking and in excess<br> </font> </div> <br>
<div id="yiv1439528921"><div><div style="color:#000;background-color:#fff;font-family:arial, helvetica, sans-serif;font-size:10pt;"><div><span>Hi,</span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><br><span></span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><span>I have written a custom move implementation.</span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><span>At first I got the exception:</span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><br><span></span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;
font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><span>java.lang.IllegalStateException: The moveClass (class my.planner.solver.MoveGroupToPeriod)'s move (PROJECT Period GroupChange:{T= Inspect 55871.I#0 [4-&gt;4] Bart DE BIE IV XI} =&gt; (P5)&nbsp; [i1]) probably has a corrupted undoMove (my.planner.solver.util.TaskChangeListMove@35e8df37). Or maybe there are corrupted score rules.<br>...<br></span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><span><br></span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;">I found out that I did not undo all changes that I made in the move.</div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica,
 sans-serif;background-color:transparent;font-style:normal;">After fixing this, I now often get Score corruption as below.</div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;">I checked and all changes are preceded with director.beforeVariableChanged(...) and followed by director.afterVariableChanged(...);</div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><br></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;">What could cause this corruption?<br></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><br></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;
font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;">java.lang.IllegalStateException: Score corruption: the workingScore (-286hard/-30601soft) is not the uncorruptedScore (-286hard/-30401soft):<br>&nbsp; The workingMemory has 3 ConstraintOccurrence(s) in excess:<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 115519.I#0 [8-&gt;8] Dirk JANSSENS IV V}, Johan LAMOTE, 99, V]=99<br>&nbsp;&nbsp;&nbsp; taskSpreading/NEGATIVE_HARD:[(P7) , 77]=100<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 115519.I#1 [8-&gt;8] Erik VERHOEVEN TL V}, Dirk JANSSENS, 99, V]=99<br>&nbsp; The workingMemory has 6 ConstraintOccurrence(s) lacking:<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 115519.I#0 [8-&gt;8] Dirk JANSSENS IV V}, Dirk JANSSENS, 99, V]=99<br>&nbsp;&nbsp;&nbsp; taskSpreading/NEGATIVE_HARD:[(P7) , 75]=36<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 115519.I#1
 [8-&gt;8]
 Erik VERHOEVEN TL V}, Erik VERHOEVEN, 99, V]=99<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 4747.I#0 [10-&gt;10] Johan LAMOTE IV V}, Johan LAMOTE, 99, V]=99<br>&nbsp;&nbsp;&nbsp; taskSpreading/NEGATIVE_HARD:[(P8) , 74]=16<br>&nbsp;&nbsp;&nbsp; preferedRegion/NEGATIVE_SOFT:[{T= Inspect 4747.I#1 [10-&gt;10] Dirk JANSSENS TL V}, Dirk JANSSENS, 99, V]=99<br>&nbsp; Check the score rules who created those ConstraintOccurrences. Verify that each ConstraintOccurrence's causes and weight is correct.<br>&nbsp;&nbsp;&nbsp; at org.drools.planner.core.score.director.AbstractScoreDirector.assertWorkingScore(AbstractScoreDirector.java:249)<br>&nbsp;&nbsp;&nbsp; at org.drools.planner.core.solver.scope.DefaultSolverScope.assertWorkingScore(DefaultSolverScope.java:96)<br>&nbsp;&nbsp;&nbsp; at org.drools.planner.core.phase.AbstractSolverPhaseScope.assertWorkingScore(AbstractSolverPhaseScope.java:124)<br>&nbsp;&nbsp;&nbsp; at
 org.drools.planner.core.localsearch.DefaultLocalSearchSolverPhase.solve(DefaultLocalSearchSolverPhase.java:86)<br>&nbsp;&nbsp;&nbsp; at org.drools.planner.core.solver.DefaultSolver.runSolverPhases(DefaultSolver.java:190)<br>&nbsp;&nbsp;&nbsp; at org.drools.planner.core.solver.DefaultSolver.solve(DefaultSolver.java:155)<br>&nbsp;&nbsp;&nbsp; at my.planner.app.InspectionSchedule.solve(InspectionSchedule.java:275)<br>&nbsp;&nbsp;&nbsp; at my.planner.testcore.AbstractPlanningTestClass.solve(AbstractPlanningTestClass.java:444)<br>&nbsp;&nbsp;&nbsp; at my.planner.testcore.AbstractPlanningTestClass.solve(AbstractPlanningTestClass.java:469)<br>&nbsp;&nbsp;&nbsp; at my.planner.RealBaoTest.datasetBAO20122013(RealBaoTest.java:226)<br>&nbsp;&nbsp;&nbsp; at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<br>&nbsp;&nbsp;&nbsp; at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)<br>&nbsp;&nbsp;&nbsp; at
 sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)<br>&nbsp;&nbsp;&nbsp; at java.lang.reflect.Method.invoke(Unknown Source)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)<br>&nbsp;&nbsp;&nbsp; at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)<br>&nbsp;&nbsp;&nbsp; at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)<br>&nbsp;&nbsp;&nbsp; at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.BlockJUnit4ClassRunner.runNotIgnored(BlockJUnit4ClassRunner.java:79)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:71)<br>&nbsp;&nbsp;&nbsp; at
 org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:49)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)<br>&nbsp;&nbsp;&nbsp; at org.junit.runners.ParentRunner.run(ParentRunner.java:236)<br>&nbsp;&nbsp;&nbsp; at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)<br>&nbsp;&nbsp;&nbsp; at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)<br>&nbsp;&nbsp;&nbsp; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)<br>&nbsp;&nbsp;&nbsp;
 at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)<br>&nbsp;&nbsp;&nbsp; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)<br>&nbsp;&nbsp;&nbsp; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)<br><br>Thanks,</div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><br></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;">Michiel<br><span></span></div><div style="color:rgb(0, 0, 0);font-size:13.3333px;font-family:arial, helvetica, sans-serif;background-color:transparent;font-style:normal;"><span><br></span></div><div>&nbsp;</div><div>-----------------<br>http://www.codessentials.com - Your essential software, for free!<br>Follow us
 at http://twitter.com/#!/Codessentials</div></div></div></div><br>_______________________________________________<br>rules-users mailing list<br><a ymailto="mailto:rules-users@lists.jboss.org" href="mailto:rules-users@lists.jboss.org">rules-users@lists.jboss.org</a><br><a href="https://lists.jboss.org/mailman/listinfo/rules-users" target="_blank">https://lists.jboss.org/mailman/listinfo/rules-users</a><br><br> </div> </div>  </div></body></html>