Package com.google.ortools.sat
Class CpSolver
- java.lang.Object
-
- com.google.ortools.sat.CpSolver
-
public final class CpSolver extends java.lang.ObjectWrapper around the SAT solver.This class proposes different solve() methods, as well as accessors to get the values of variables in the best solution, as well as general statistics of the search.
-
-
Constructor Summary
Constructors Constructor Description CpSolver()Main construction of the CpSolver class.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description doublebestObjectiveBound()Returns the best lower bound found when minimizing, of the best upper bound found when maximizing.java.lang.BooleanbooleanValue(Literal var)Returns the Boolean value of a literal in the last solution found.SatParameters.BuildergetParameters()Returns the builder of the parameters of the SAT solver for modification.java.lang.StringgetSolutionInfo()Returns some information on how the solution was found, or the reason why the model or the parameters are invalid.longnumBranches()Returns the number of branches explored during search.longnumConflicts()Returns the number of conflicts created during search.doubleobjectiveValue()Returns the best objective value found during search.CpSolverResponseresponse()Returns the internal response protobuf that is returned internally by the SAT solver.java.lang.StringresponseStats()Returns some statistics on the solution found as a string.CpSolverStatussearchAllSolutions(CpModel model, CpSolverSolutionCallback cb)Deprecated.Use the solve() method with the same signature, after setting the enumerate_all_solution parameter to true.voidsetLogCallback(java.util.function.Consumer<java.lang.String> cb)Sets the log callback for the solver.CpSolverStatussolve(CpModel model)Solves the given model, and returns the solve status.CpSolverStatussolve(CpModel model, CpSolverSolutionCallback cb)Solves the given model, calls the solution callback at each incumbent solution, and returns the solve status.CpSolverStatussolveWithSolutionCallback(CpModel model, CpSolverSolutionCallback cb)Deprecated.Use the solve() method with the same signature.voidstopSearch()Stops the search asynchronously.java.util.List<java.lang.Integer>sufficientAssumptionsForInfeasibility()doubleuserTime()Returns the user time of the search.longvalue(LinearArgument expr)Returns the value of a linear expression in the last solution found.doublewallTime()Returns the wall time of the search.
-
-
-
Method Detail
-
solve
public CpSolverStatus solve(CpModel model)
Solves the given model, and returns the solve status.
-
solve
public CpSolverStatus solve(CpModel model, CpSolverSolutionCallback cb)
Solves the given model, calls the solution callback at each incumbent solution, and returns the solve status.
-
solveWithSolutionCallback
@Deprecated public CpSolverStatus solveWithSolutionCallback(CpModel model, CpSolverSolutionCallback cb)
Deprecated.Use the solve() method with the same signature.Solves the given model, passes each incumber solution to the solution callback if not null, and returns the solve status.
-
searchAllSolutions
@Deprecated public CpSolverStatus searchAllSolutions(CpModel model, CpSolverSolutionCallback cb)
Deprecated.Use the solve() method with the same signature, after setting the enumerate_all_solution parameter to true.Searches for all solutions of a satisfiability problem.This method searches for all feasible solutions of a given model. Then it feeds the solutions to the callback.
Note that the model cannot have an objective.
- Parameters:
model- the model to solvecb- the callback that will be called at each solution- Returns:
- the status of the solve (FEASIBLE, INFEASIBLE...)
-
stopSearch
public void stopSearch()
Stops the search asynchronously.
-
objectiveValue
public double objectiveValue()
Returns the best objective value found during search.
-
bestObjectiveBound
public double bestObjectiveBound()
Returns the best lower bound found when minimizing, of the best upper bound found when maximizing.
-
value
public long value(LinearArgument expr)
Returns the value of a linear expression in the last solution found.
-
booleanValue
public java.lang.Boolean booleanValue(Literal var)
Returns the Boolean value of a literal in the last solution found.
-
response
public CpSolverResponse response()
Returns the internal response protobuf that is returned internally by the SAT solver.
-
numBranches
public long numBranches()
Returns the number of branches explored during search.
-
numConflicts
public long numConflicts()
Returns the number of conflicts created during search.
-
wallTime
public double wallTime()
Returns the wall time of the search.
-
userTime
public double userTime()
Returns the user time of the search.
-
sufficientAssumptionsForInfeasibility
public java.util.List<java.lang.Integer> sufficientAssumptionsForInfeasibility()
-
getParameters
public SatParameters.Builder getParameters()
Returns the builder of the parameters of the SAT solver for modification.
-
setLogCallback
public void setLogCallback(java.util.function.Consumer<java.lang.String> cb)
Sets the log callback for the solver.
-
responseStats
public java.lang.String responseStats()
Returns some statistics on the solution found as a string.
-
getSolutionInfo
public java.lang.String getSolutionInfo()
Returns some information on how the solution was found, or the reason why the model or the parameters are invalid.
-
-