org.chocosolver.parser.flatzinc.ast.searches.SetSearch Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of choco-parsers Show documentation
Show all versions of choco-parsers Show documentation
Provide parsers from FlatZinc, XCSP3 and MSP to Choco-solver.
/*
* This file is part of choco-parsers, http://choco-solver.org/
*
* Copyright (c) 2024, IMT Atlantique. All rights reserved.
*
* Licensed under the BSD 4-clause license.
*
* See LICENSE file in the project root for full license information.
*/
package org.chocosolver.parser.flatzinc.ast.searches;
import org.chocosolver.solver.Model;
import org.chocosolver.solver.search.strategy.selectors.values.SetDomainMax;
import org.chocosolver.solver.search.strategy.selectors.values.SetDomainMin;
import org.chocosolver.solver.search.strategy.selectors.values.SetValueSelector;
import org.chocosolver.solver.search.strategy.selectors.variables.InputOrder;
import org.chocosolver.solver.search.strategy.selectors.variables.Occurrence;
import org.chocosolver.solver.search.strategy.selectors.variables.VariableSelector;
import org.chocosolver.solver.search.strategy.strategy.AbstractStrategy;
import org.chocosolver.solver.search.strategy.strategy.SetStrategy;
import org.chocosolver.solver.variables.SetVar;
/**
*
*
* @author Charles Prud'homme
* @since 27/01/11
*/
public class SetSearch {
private SetSearch() {
}
public static AbstractStrategy build(SetVar[] variables, VarChoice varChoice, Assignment assignment, Model solver) {
VariableSelector varsel = variableSelector(varChoice, solver);
return valueSelector(variables, varsel, assignment);
}
private static VariableSelector variableSelector(VarChoice varChoice, Model solver) {
switch (varChoice) {
case input_order:
return new InputOrder<>(solver);
case occurrence:
return new Occurrence<>();
case first_fail:
case anti_first_fail:
case smallest:
case largest:
case most_constrained:
case max_regret:
case dom_w_deg:
default:
System.err.println("% No implementation for " + varChoice.name() + ". Set default.");
return new InputOrder<>(solver);
}
}
private static SetStrategy valueSelector(SetVar[] scope, VariableSelector variableSelector,
Assignment assignment) {
SetValueSelector valSelector;
switch (assignment) {
case indomain:
case indomain_min:
valSelector = new SetDomainMin();
break;
case indomain_max:
valSelector = new SetDomainMax();
break;
case indomain_middle:
case indomain_median:
case indomain_random:
case indomain_split:
case indomain_interval:
case indomain_reverse_split:
default:
System.err.println("% No implementation for " + assignment.name() + ". Set default.");
valSelector = new SetDomainMin();
}
return new SetStrategy(scope, variableSelector, valSelector, true);
}
}