Class CpSolver

java.lang.Object
com.google.ortools.sat.CpSolver

public final class CpSolver extends Object
Wrapper 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 Details

    • CpSolver

      public CpSolver()
      Main construction of the CpSolver class.
  • Method Details

    • 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 solve
      cb - 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 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 List<Integer> sufficientAssumptionsForInfeasibility()
    • getParameters

      public SatParameters.Builder getParameters()
      Returns the builder of the parameters of the SAT solver for modification.
    • setLogCallback

      public void setLogCallback(Consumer<String> cb)
      Sets the log callback for the solver.
    • clearLogCallback

      public void clearLogCallback()
      Clears the log callback.
    • setBestBoundCallback

      public void setBestBoundCallback(Consumer<Double> cb)
      Sets the best bound callback for the solver.
    • clearBestBoundCallback

      public void clearBestBoundCallback()
      Clears the best bound callback.
    • responseStats

      public String responseStats()
      Returns some statistics on the solution found as a string.
    • getSolutionInfo

      public String getSolutionInfo()
      Returns some information on how the solution was found, or the reason why the model or the parameters are invalid.