org.drools.planner.examples.nurserostering.benchmark.nurseRosteringMediumBenchmarkConfig.xml Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of drools-planner-examples Show documentation
Show all versions of drools-planner-examples Show documentation
Drools Planner optimizes automated planning by combining metaheuristic search algorithms with rule
engine powered score calculation. This is the drools-planner-examples module which contains examples on how to use
Drools Planner.
<?xml version="1.0" encoding="UTF-8"?> <plannerBenchmark> <benchmarkDirectory>local/data/nurserostering/medium</benchmarkDirectory> <parallelBenchmarkCount>AUTO</parallelBenchmarkCount> <warmUpSecondsSpend>30</warmUpSecondsSpend> <inheritedSolverBenchmark> <problemBenchmarks> <xstreamAnnotatedClass>org.drools.planner.examples.nurserostering.domain.NurseRoster</xstreamAnnotatedClass> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late01_initialized.xml</inputSolutionFile>--> <inputSolutionFile>data/nurserostering/unsolved/medium01.xml</inputSolutionFile> <inputSolutionFile>data/nurserostering/unsolved/medium02.xml</inputSolutionFile> <!--<inputSolutionFile>data/nurserostering/unsolved/medium03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium04.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium05.xml</inputSolutionFile>--> <inputSolutionFile>data/nurserostering/unsolved/medium_hint01.xml</inputSolutionFile> <inputSolutionFile>data/nurserostering/unsolved/medium_hint02.xml</inputSolutionFile> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_hint03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late01.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late02.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late04.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/medium_late05.xml</inputSolutionFile>--> <problemStatisticType>BEST_SOLUTION_CHANGED</problemStatisticType> <!--<problemStatisticType>CALCULATE_COUNT_PER_SECOND</problemStatisticType>--> <!--<problemStatisticType>MEMORY_USE</problemStatisticType>--> </problemBenchmarks> <solver> <solutionClass>org.drools.planner.examples.nurserostering.domain.NurseRoster</solutionClass> <planningEntityClass>org.drools.planner.examples.nurserostering.domain.ShiftAssignment</planningEntityClass> <scoreDirectorFactory> <scoreDefinitionType>HARD_AND_SOFT</scoreDefinitionType> <scoreDrl>/org/drools/planner/examples/nurserostering/solver/nurseRosteringScoreRules.drl</scoreDrl> </scoreDirectorFactory> <termination> <!-- Official benchmark maximumSecondsSpend allowed on: - ge0ffrey's main pc: sprint 11, medium 700, long 42000 --> <maximumSecondsSpend>700</maximumSecondsSpend> <!--<scoreAttained>0hard/-999999999soft</scoreAttained>--> </termination> <constructionHeuristic> <constructionHeuristicType>BEST_FIT</constructionHeuristicType> </constructionHeuristic> </solver> </inheritedSolverBenchmark> <solverBenchmark> <name>tabuSearch-moveTabu</name> <solver> <localSearch> <unionMoveSelector> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwapMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>STEP</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwapMoveFactory</moveListFactoryClass> </moveListFactory> </unionMoveSelector> <acceptor> <moveTabuSize>7</moveTabuSize> </acceptor> <forager> <minimalAcceptedSelection>800</minimalAcceptedSelection> </forager> </localSearch> </solver> </solverBenchmark> <solverBenchmark> <name>tabuSearch-entityTabu</name> <solver> <constructionHeuristic> <constructionHeuristicType>BEST_FIT</constructionHeuristicType> </constructionHeuristic> <localSearch> <unionMoveSelector> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwapMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>STEP</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwapMoveFactory</moveListFactoryClass> </moveListFactory> </unionMoveSelector> <acceptor> <planningEntityTabuSize>7</planningEntityTabuSize> </acceptor> <forager> <minimalAcceptedSelection>800</minimalAcceptedSelection> </forager> </localSearch> </solver> </solverBenchmark> <solverBenchmark> <name>simulatedAnnealing</name> <solver> <localSearch> <unionMoveSelector> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>PHASE</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwapMoveFactory</moveListFactoryClass> </moveListFactory> <moveListFactory> <cacheType>STEP</cacheType> <moveListFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwapMoveFactory</moveListFactoryClass> </moveListFactory> </unionMoveSelector> <acceptor> <simulatedAnnealingStartingTemperature>0hard/8soft</simulatedAnnealingStartingTemperature> <planningEntityTabuSize>5</planningEntityTabuSize> </acceptor> <forager> <minimalAcceptedSelection>4</minimalAcceptedSelection> </forager> </localSearch> </solver> </solverBenchmark> </plannerBenchmark>