Package solver.search.strategy.strategy

Source Code of solver.search.strategy.strategy.IntStrategy

/*
* Copyright (c) 1999-2014, Ecole des Mines de Nantes
* All rights reserved.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
*     * Redistributions of source code must retain the above copyright
*       notice, this list of conditions and the following disclaimer.
*     * Redistributions in binary form must reproduce the above copyright
*       notice, this list of conditions and the following disclaimer in the
*       documentation and/or other materials provided with the distribution.
*     * Neither the name of the Ecole des Mines de Nantes nor the
*       names of its contributors may be used to endorse or promote products
*       derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

package solver.search.strategy.strategy;

import solver.search.strategy.assignments.DecisionOperator;
import solver.search.strategy.decision.Decision;
import solver.search.strategy.decision.fast.FastDecision;
import solver.search.strategy.selectors.IntValueSelector;
import solver.search.strategy.selectors.VariableSelector;
import solver.variables.IntVar;
import util.PoolManager;

/**
* Class to perform branching decisions over integer variables
* <br/>
*
* @author Charles Prud'homme, Jean-Guillaume Fages
* @since 2 juil. 2010
*/
public class IntStrategy extends AbstractStrategy<IntVar> {

  // Search strategy parameters
    VariableSelector<IntVar> variableSelector;
    IntValueSelector valueSelector;
  DecisionOperator<IntVar> decisionOperator;

  // object recycling management
    PoolManager<FastDecision> decisionPool;

  /**
   * Creates a search strategy which selects a variable X and a value V to perform
   * the decision X = V
   *
   * BEWARE: if the variable domain is not enumerated, the value V should be a domain bound.
   * Otherwise, the decision cannot be negated, and the search may loop infinitely.
   *
   * @param scope      defines which variables to branch on
   * @param varSelector  defines how to select the next variable to branch on
   * @param valSelector  defines how to select the value involved in the branching decision
   */
    public IntStrategy(IntVar[] scope, VariableSelector<IntVar> varSelector, IntValueSelector valSelector) {
        this(scope, varSelector, valSelector,DecisionOperator.int_eq);
    }

  /**
   * Creates a search strategy which selects a variable X and a value V to perform
   * the decision X decOperator V
   *
   * This can be X <= V for instance.
   *
   * BEWARE: if the variable domain is not enumerated, and if the operator is either "=" or "!=",
   * then the value V should be a domain bound. Otherwise, the decision cannot be negated,
   * and the search may loop infinitely.
   *
   * @param scope      defines which variables to branch on
   * @param varSelector  defines how to select the next variable to branch on
   * @param valSelector  defines how to select the value involved in the branching decision
   * @param decOperator  defines what to do in a branching decision
   */
    public IntStrategy(IntVar[] scope, VariableSelector<IntVar> varSelector, IntValueSelector valSelector,
             DecisionOperator<IntVar> decOperator) {
        super(scope);
        this.variableSelector = varSelector;
        this.valueSelector = valSelector;
    this.decisionOperator = decOperator;
        this.decisionPool = new PoolManager<>();
    }

    @Override
    public void init() {}

    @Override
    public Decision<IntVar> computeDecision(IntVar variable) {
        if (variable == null || variable.isInstantiated()) {
            return null;
        }
        int value = valueSelector.selectValue(variable);
        FastDecision d = decisionPool.getE();
        if (d == null) {
            d = new FastDecision(decisionPool);
        }
        d.set(variable, value, decisionOperator);
        return d;
    }

    @SuppressWarnings({"unchecked"})
    @Override
    public Decision getDecision() {
        IntVar variable = variableSelector.getVariable(vars);
        return computeDecision(variable);
    }
}
TOP

Related Classes of solver.search.strategy.strategy.IntStrategy

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.