diff options
author | Andrew Reynolds <andrew.j.reynolds@gmail.com> | 2021-03-01 21:37:03 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-02 03:37:03 +0000 |
commit | 4132e91fdb2f8912a89a101e96c86bf5076b327a (patch) | |
tree | 9d773b3a36aa68bda3d7b7839d9d8cd72a4061ef /src/theory/quantifiers/term_registry.cpp | |
parent | b5073e16ea49ce9214fcc5318ce080724719c809 (diff) |
Introduce quantifiers term registry (#5983)
This groups utilities related to ground terms into TermRegistry which will be passed to quantifier modules.
Diffstat (limited to 'src/theory/quantifiers/term_registry.cpp')
-rw-r--r-- | src/theory/quantifiers/term_registry.cpp | 93 |
1 files changed, 93 insertions, 0 deletions
diff --git a/src/theory/quantifiers/term_registry.cpp b/src/theory/quantifiers/term_registry.cpp new file mode 100644 index 000000000..40e45ae35 --- /dev/null +++ b/src/theory/quantifiers/term_registry.cpp @@ -0,0 +1,93 @@ +/********************* */ +/*! \file term_registry.cpp + ** \verbatim + ** Top contributors (to current version): + ** Andrew Reynolds + ** This file is part of the CVC4 project. + ** Copyright (c) 2009-2020 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.\endverbatim + ** + ** \brief term registry class + **/ + +#include "theory/quantifiers/term_registry.h" + +#include "options/quantifiers_options.h" +#include "options/smt_options.h" +#include "theory/quantifiers/quantifiers_state.h" + +namespace CVC4 { +namespace theory { +namespace quantifiers { + +TermRegistry::TermRegistry(QuantifiersState& qs, + QuantifiersInferenceManager& qim, + QuantifiersRegistry& qr) + : d_presolve(qs.getUserContext(), true), + d_presolveCache(qs.getUserContext()), + d_termEnum(new TermEnumeration), + d_termDb(new TermDb(qs, qim, qr)), + d_sygusTdb(nullptr) +{ + if (options::sygus() || options::sygusInst()) + { + // must be constructed here since it is required for datatypes finistInit + d_sygusTdb.reset(new TermDbSygus(qs, qim)); + } +} + +void TermRegistry::presolve() +{ + d_termDb->presolve(); + d_presolve = false; + // add all terms to database + if (options::incrementalSolving() && !options::termDbCd()) + { + Trace("quant-engine-proc") + << "Add presolve cache " << d_presolveCache.size() << std::endl; + for (const Node& t : d_presolveCache) + { + addTerm(t); + } + Trace("quant-engine-proc") << "Done add presolve cache " << std::endl; + } +} + +void TermRegistry::addTerm(Node n, bool withinQuant) +{ + // don't add terms in quantifier bodies + if (withinQuant && !options::registerQuantBodyTerms()) + { + return; + } + if (options::incrementalSolving() && !options::termDbCd()) + { + d_presolveCache.insert(n); + } + // only wait if we are doing incremental solving + if (!d_presolve || !options::incrementalSolving() || options::termDbCd()) + { + d_termDb->addTerm(n); + if (d_sygusTdb.get() && options::sygusEvalUnfold()) + { + d_sygusTdb->getEvalUnfold()->registerEvalTerm(n); + } + } +} + +TermDb* TermRegistry::getTermDatabase() const { return d_termDb.get(); } + +TermDbSygus* TermRegistry::getTermDatabaseSygus() const +{ + return d_sygusTdb.get(); +} + +TermEnumeration* TermRegistry::getTermEnumeration() const +{ + return d_termEnum.get(); +} +} // namespace quantifiers +} // namespace theory +} // namespace CVC4 |