All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.drools.planner.examples.nurserostering.benchmark.nurseRosteringMediumSolverBenchmarkConfig.xml Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 6.0.0.Alpha9
Show newest version
<?xml version="1.0" encoding="UTF-8"?>
<solverBenchmarkSuite>
  <benchmarkDirectory>local/data/nurserostering</benchmarkDirectory>
  <solverStatisticType>BEST_SOLUTION_CHANGED</solverStatisticType>
  <warmUpSecondsSpend>30</warmUpSecondsSpend>

  <inheritedSolverBenchmark>
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late01_initialized.xml</unsolvedSolutionFile>-->

    <unsolvedSolutionFile>data/nurserostering/unsolved/medium01.xml</unsolvedSolutionFile>
    <unsolvedSolutionFile>data/nurserostering/unsolved/medium02.xml</unsolvedSolutionFile>
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium03.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium04.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium05.xml</unsolvedSolutionFile>-->
    <unsolvedSolutionFile>data/nurserostering/unsolved/medium_hint01.xml</unsolvedSolutionFile>
    <unsolvedSolutionFile>data/nurserostering/unsolved/medium_hint02.xml</unsolvedSolutionFile>
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_hint03.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late01.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late02.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late03.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late04.xml</unsolvedSolutionFile>-->
    <!--<unsolvedSolutionFile>data/nurserostering/unsolved/medium_late05.xml</unsolvedSolutionFile>-->

    <solver>
      <solutionClass>org.drools.planner.examples.nurserostering.domain.NurseRoster</solutionClass>
      <planningEntityClass>org.drools.planner.examples.nurserostering.domain.ShiftAssignment</planningEntityClass>
      <scoreDrl>/org/drools/planner/examples/nurserostering/solver/nurseRosteringScoreRules.drl</scoreDrl>
      <scoreDefinition>
        <scoreDefinitionType>HARD_AND_SOFT</scoreDefinitionType>
      </scoreDefinition>
      <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>StartingSolutionInitializer</name>
    <solver>
      <customSolverPhase>
        <customSolverPhaseCommandClass>org.drools.planner.examples.nurserostering.solver.solution.initializer.NurseRosteringStartingSolutionInitializer</customSolverPhaseCommandClass>
      </customSolverPhase>
    </solver>
  </solverBenchmark>
  <solverBenchmark>
    <name>FIRST_FIT</name>
    <solver>
      <constructionHeuristic>
        <constructionHeuristicType>FIRST_FIT</constructionHeuristicType>
      </constructionHeuristic>
    </solver>
  </solverBenchmark>
  <solverBenchmark>
    <name>FIRST_FIT_DECREASING</name>
    <solver>
      <constructionHeuristic>
        <constructionHeuristicType>FIRST_FIT_DECREASING</constructionHeuristicType>
      </constructionHeuristic>
    </solver>
  </solverBenchmark>
  <solverBenchmark>
    <name>BEST_FIT</name>
    <solver>
      <constructionHeuristic>
        <constructionHeuristicType>BEST_FIT</constructionHeuristicType>
      </constructionHeuristic>
    </solver>
  </solverBenchmark>
  <solverBenchmark>
    <name>BEST_FIT_DECREASING</name>
    <solver>
      <constructionHeuristic>
        <constructionHeuristicType>BEST_FIT_DECREASING</constructionHeuristicType>
      </constructionHeuristic>
    </solver>
  </solverBenchmark>

  <!--<solverBenchmark>-->
    <!--<name>tabuSearch-moveTabu</name>-->
    <!--<solver>-->
      <!--<localSearch>-->
        <!--<selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
        <!--</selector>-->
        <!--<acceptor>-->
          <!--<completeSolutionTabuSize>1000</completeSolutionTabuSize>-->
          <!--<completeMoveTabuSize>7</completeMoveTabuSize>-->
        <!--</acceptor>-->
        <!--<forager>-->
          <!--<minimalAcceptedSelection>800</minimalAcceptedSelection>-->
        <!--</forager>-->
      <!--</localSearch>-->
    <!--</solver>-->
  <!--</solverBenchmark>-->
  <!--<solverBenchmark>-->
    <!--<name>tabuSearch-propertyTabu</name>-->
    <!--<solver>-->
      <!--<localSearch>-->
        <!--<selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
        <!--</selector>-->
        <!--<acceptor>-->
          <!--<completeSolutionTabuSize>1000</completeSolutionTabuSize>-->
          <!--<completePropertyTabuSize>11</completePropertyTabuSize>-->
        <!--</acceptor>-->
        <!--<forager>-->
          <!--<minimalAcceptedSelection>800</minimalAcceptedSelection>-->
        <!--</forager>-->
      <!--</localSearch>-->
    <!--</solver>-->
  <!--</solverBenchmark>-->
  <!--<solverBenchmark>-->
    <!--<name>simulatedAnnealing</name>-->
    <!--<solver>-->
      <!--<localSearch>-->
        <!--<selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.EmployeeChangeMoveFactory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
          <!--<selector>-->
            <!--<moveFactoryClass>org.drools.planner.examples.nurserostering.solver.move.factory.ShiftAssignmentPillarPartSwitchMoveFactoryctory</moveFactoryClass>-->
          <!--</selector>-->
        <!--</selector>-->
        <!--<acceptor>-->
          <!--<simulatedAnnealingStartingTemperature>0hard/8soft</simulatedAnnealingStartingTemperature>-->
          <!--<completePropertyTabuSize>5</completePropertyTabuSize>-->
        <!--</acceptor>-->
        <!--<forager>-->
          <!--&lt;!&ndash;<pickEarlyType>FIRST_BEST_SCORE_IMPROVING</pickEarlyType>&ndash;&gt;-->
          <!--<minimalAcceptedSelection>4</minimalAcceptedSelection>-->
        <!--</forager>-->
      <!--</localSearch>-->
    <!--</solver>-->
  <!--</solverBenchmark>-->
</solverBenchmarkSuite>




© 2015 - 2024 Weber Informatics LLC | Privacy Policy