org.optaplanner.examples.nurserostering.benchmark.nurseRosteringSprintBenchmarkConfig.xml Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of optaplanner-examples Show documentation
Show all versions of optaplanner-examples Show documentation
OptaPlanner solves planning problems.
This lightweight, embeddable planning engine implements powerful and scalable algorithms
to optimize business resource scheduling and planning.
This module contains the examples which demonstrate how to use it in a normal Java application.
<?xml version="1.0" encoding="UTF-8"?> <plannerBenchmark> <benchmarkDirectory>local/data/nurserostering/sprint</benchmarkDirectory> <parallelBenchmarkCount>AUTO</parallelBenchmarkCount> <warmUpSecondsSpentLimit>5</warmUpSecondsSpentLimit> <inheritedSolverBenchmark> <problemBenchmarks> <xStreamAnnotatedClass>org.optaplanner.examples.nurserostering.domain.NurseRoster</xStreamAnnotatedClass> <inputSolutionFile>data/nurserostering/unsolved/sprint01.xml</inputSolutionFile> <inputSolutionFile>data/nurserostering/unsolved/sprint02.xml</inputSolutionFile> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint04.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint05.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint06.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint07.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint08.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint09.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint10.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_hint01.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_hint02.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_hint03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late01.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late02.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late03.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late04.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late05.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late06.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late07.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late08.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late09.xml</inputSolutionFile>--> <!--<inputSolutionFile>data/nurserostering/unsolved/sprint_late10.xml</inputSolutionFile>--> <!--<problemStatisticType>BEST_SCORE</problemStatisticType>--> <!--<problemStatisticType>STEP_SCORE</problemStatisticType>--> <!--<problemStatisticType>SCORE_CALCULATION_SPEED</problemStatisticType>--> <!--<problemStatisticType>BEST_SOLUTION_MUTATION</problemStatisticType>--> <!--<problemStatisticType>MOVE_COUNT_PER_STEP</problemStatisticType>--> <!--<problemStatisticType>MEMORY_USE</problemStatisticType>--> <!--<singleStatisticType>CONSTRAINT_MATCH_TOTAL_BEST_SCORE</singleStatisticType>--> <!--<singleStatisticType>CONSTRAINT_MATCH_TOTAL_STEP_SCORE</singleStatisticType>--> <!--<singleStatisticType>PICKED_MOVE_TYPE_BEST_SCORE_DIFF</singleStatisticType>--> <!--<singleStatisticType>PICKED_MOVE_TYPE_STEP_SCORE_DIFF</singleStatisticType>--> </problemBenchmarks> <solver> <solutionClass>org.optaplanner.examples.nurserostering.domain.NurseRoster</solutionClass> <entityClass>org.optaplanner.examples.nurserostering.domain.ShiftAssignment</entityClass> <scoreDirectorFactory> <scoreDrl>org/optaplanner/examples/nurserostering/solver/nurseRosteringConstraints.drl</scoreDrl> </scoreDirectorFactory> <termination> <secondsSpentLimit>10</secondsSpentLimit> </termination> <constructionHeuristic> <constructionHeuristicType>WEAKEST_FIT</constructionHeuristicType> </constructionHeuristic> </solver> </inheritedSolverBenchmark> <solverBenchmark> <name>Tabu Search</name> <solver> <localSearch> <unionMoveSelector> <moveListFactory> <cacheType>STEP</cacheType> <moveListFactoryClass>org.optaplanner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwapMoveFactory</moveListFactoryClass> </moveListFactory> <changeMoveSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </changeMoveSelector> <swapMoveSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </swapMoveSelector> </unionMoveSelector> <acceptor> <entityTabuSize>11</entityTabuSize> </acceptor> <forager> <acceptedCountLimit>300</acceptedCountLimit> </forager> </localSearch> </solver> </solverBenchmark> <solverBenchmark> <name>Late Acceptance</name> <solver> <localSearch> <unionMoveSelector> <changeMoveSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </changeMoveSelector> <swapMoveSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </swapMoveSelector> <pillarChangeMoveSelector> <subPillarType>SEQUENCE</subPillarType> <pillarSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </pillarSelector> </pillarChangeMoveSelector> <pillarSwapMoveSelector> <subPillarType>SEQUENCE</subPillarType> <pillarSelector> <entitySelector> <filterClass>org.optaplanner.examples.nurserostering.domain.solver.MovableShiftAssignmentSelectionFilter</filterClass> </entitySelector> </pillarSelector> </pillarSwapMoveSelector> </unionMoveSelector> <acceptor> <lateAcceptanceSize>50</lateAcceptanceSize> </acceptor> <forager> <acceptedCountLimit>4</acceptedCountLimit> </forager> </localSearch> </solver> </solverBenchmark> </plannerBenchmark>