<html><body><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></body></html>