Class AsynchronousCloseSatSolverState

  • All Implemented Interfaces:
    java.lang.AutoCloseable, SatSolverState

    public class AsynchronousCloseSatSolverState
    extends java.lang.Object
    implements SatSolverState
    The cleanup after the close() call happens (possibly) in a separate thread, depending on the provided executor.
    Author:
    Mathias Hofer
    • Method Summary

      Modifier and Type Method Description
      boolean add​(java.util.Collection<Disjunction> clauses)
      Adds the given set of clauses to the solver state.
      boolean add​(Disjunction clause)
      Adds the given clause to the solver state.
      void assume​(Proposition proposition, boolean value)
      Assumes the truth value of the given proposition for the next call to SatSolverState.satisfiable().
      void close()  
      boolean satisfiable()
      Computes if the current state is satisfiable.
      Interpretation<PlBeliefSet,​PlFormula> witness()
      Returns a witness of the satisfiability of all the clauses in the state, or null if the state is unsatisfiable.
      • Methods inherited from class java.lang.Object

        equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Constructor Detail

      • AsynchronousCloseSatSolverState

        public AsynchronousCloseSatSolverState​(SatSolverState delegate,
                                               java.util.concurrent.Executor executor)
        Parameters:
        delegate - the state
        executor - the executor which is used to execute the calls to the delegate state
    • Method Detail

      • satisfiable

        public boolean satisfiable()
        Description copied from interface: SatSolverState
        Computes if the current state is satisfiable. Also takes made assumptions into account.

        Note that it is up to the implementation if the current satisfiability status is cached or if it is computed for every call.

        Specified by:
        satisfiable in interface SatSolverState
        Returns:
        true if the state is satisfiable, false if it is not
      • add

        public boolean add​(Disjunction clause)
        Description copied from interface: SatSolverState
        Adds the given clause to the solver state.
        Specified by:
        add in interface SatSolverState
        Parameters:
        clause - a clause containing only literals - no constants!
        Returns:
        true if the clause could be added to the state, false if it failed
      • add

        public boolean add​(java.util.Collection<Disjunction> clauses)
        Description copied from interface: SatSolverState
        Adds the given set of clauses to the solver state.

        If one of the clauses cannot be added, the rest of the clauses may or may not be added. Hence, there is no guarantee that this method tries to add the remaining clauses after the first fail. If this method however returns true, then all of the given clauses were successfully added to the state.

        Specified by:
        add in interface SatSolverState
        Parameters:
        clauses - a set of clauses
        Returns:
        true if all of the clauses could be added to the state, false if at least one clause failed
      • close

        public void close()
        Specified by:
        close in interface java.lang.AutoCloseable
        Specified by:
        close in interface SatSolverState