All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cvc5-cvc5-1.2.0.src.theory.quantifiers.oracle_engine.h Maven / Gradle / Ivy

The newest version!
/******************************************************************************
 * Top contributors (to current version):
 *   Andrew Reynolds
 *
 * This file is part of the cvc5 project.
 *
 * Copyright (c) 2009-2024 by the authors listed in the file AUTHORS
 * in the top-level source directory and their institutional affiliations.
 * All rights reserved.  See the file COPYING in the top-level source
 * directory for licensing information.
 * ****************************************************************************
 *
 * Oracle engine for SMTO
 */

#include "cvc5_private.h"

#ifndef CVC5__THEORY__QUANTIFIERS__ORACLE_ENGINE_H
#define CVC5__THEORY__QUANTIFIERS__ORACLE_ENGINE_H

#include "theory/decision_strategy.h"
#include "theory/quantifiers/oracle_checker.h"
#include "theory/quantifiers/quant_module.h"

namespace cvc5::internal {
namespace theory {
namespace quantifiers {

/**
 * Oracle engine
 *
 * This class manages the list of declared oracle functions and asserted
 * oracle interfaces.
 *
 * For SMT modulo oracles (SMTO) queries, this class is responsible for
 * invoking oracles, as specified by oracle interface quantifiers (see
 * OracleInterfaceAttribute), until all oracle functions have consistent
 * definitions with respect to the current model.
 *
 * In detail, an oracle function f has a consistent definition with respect to
 * the current model M if all invocations f(t) in assertions are such that
 * we have invoked its associated oracle on t^M and that invocation returned
 * the value f(t)^M. This module is complete for oracle interface quantifiers
 * if their associated oracle function has a consistent definition.
 *
 * For details, see Polgreen et al VMCAI 2022.
 */
class OracleEngine : public QuantifiersModule
{
 public:
  OracleEngine(Env& env,
               QuantifiersState& qs,
               QuantifiersInferenceManager& qim,
               QuantifiersRegistry& qr,
               TermRegistry& tr);
  ~OracleEngine() {}
  /** Presolve */
  void presolve() override;
  /** Needs check. */
  bool needsCheck(Theory::Effort e) override;
  /** Needs model. */
  QEffort needsModel(Theory::Effort e) override;
  /** Reset round. */
  void reset_round(Theory::Effort e) override;
  /** Register quantified formula q */
  void registerQuantifier(Node q) override;
  /** Check.
   * Adds instantiations for all currently asserted
   * quantified formulas via calls to process(...)
   */
  void check(Theory::Effort e, QEffort quant_e) override;
  /**
   * Check was complete for quantified formula q, return true if we can say
   * "sat" provided that q is currently asserted.
   */
  bool checkCompleteFor(Node q) override;
  /** check ownership */
  void checkOwnership(Node q) override;
  /** Identify. */
  std::string identify() const override;

  /** Declare oracle fun */
  void declareOracleFun(Node f);
  /** Get the list of all declared oracle functions */
  std::vector getOracleFuns() const;

  /** Make an oracle interface quantifier */
  static Node mkOracleInterface(const std::vector& inputs,
                                const std::vector& outputs,
                                Node assume,
                                Node constraint,
                                Node oracleNode);
  /**
   * Get oracle interface, returns true if q is an oracle interface quantifier
   * (constructed by the above method). Obtains the arguments for which q is
   * constructed.
   */
  bool getOracleInterface(Node q,
                          std::vector& inputs,
                          std::vector& outputs,
                          Node& assume,
                          Node& constraint,
                          Node& oracleNode) const;

 private:
  /** The oracle functions (user-context dependent) */
  context::CDList d_oracleFuns;
  /** Pointer to the oracle checker */
  OracleChecker* d_ochecker;
  /**
   * In a given instantiation round, did consistency checks pass for all
   * oracle interface quantified formulas?
   */
  bool d_consistencyCheckPassed;
  /**
   * A decision strategy that prefers equating arguments of oracles to
   * values that we have already evaluated the oracle on. For example, if
   * we have an application (f a) of oracle function f, then if a=5 in one
   * model, we may generate the lemma (=> (= a 5) (= (f a) 10)), where 10 is
   * result of calling f on 5. This decision strategy will henceforth decide
   * (= a 5) -> true. This ensures that we don't invoke f for evaluating (f a)
   * again until we are sure that (= a 5) cannot be made true.
   */
  DecisionStrategyVector d_dstrat;
};

}  // namespace quantifiers
}  // namespace theory
}  // namespace cvc5::internal

#endif




© 2015 - 2024 Weber Informatics LLC | Privacy Policy