summaryrefslogtreecommitdiff
path: root/src/theory/quantifiers/sygus
diff options
context:
space:
mode:
Diffstat (limited to 'src/theory/quantifiers/sygus')
-rw-r--r--src/theory/quantifiers/sygus/sygus_enumerator.cpp15
-rw-r--r--src/theory/quantifiers/sygus/sygus_enumerator.h12
2 files changed, 21 insertions, 6 deletions
diff --git a/src/theory/quantifiers/sygus/sygus_enumerator.cpp b/src/theory/quantifiers/sygus/sygus_enumerator.cpp
index bd85ea496..736fdebee 100644
--- a/src/theory/quantifiers/sygus/sygus_enumerator.cpp
+++ b/src/theory/quantifiers/sygus/sygus_enumerator.cpp
@@ -25,8 +25,13 @@ namespace theory {
namespace quantifiers {
SygusEnumerator::SygusEnumerator(TermDbSygus* tds, SynthConjecture* p)
- : d_tds(tds), d_parent(p), d_tlEnum(nullptr), d_abortSize(-1)
+ : d_tds(tds),
+ d_parent(p),
+ d_tlEnum(nullptr),
+ d_abortSize(-1),
+ d_rewriteChecks("sygus-rr-verify-rewrite-checks", 0)
{
+ smtStatisticsRegistry()->registerStat(&d_rewriteChecks);
}
void SygusEnumerator::initialize(Node e)
@@ -152,7 +157,8 @@ SygusEnumerator::TermCache::TermCache()
void SygusEnumerator::TermCache::initialize(Node e,
TypeNode tn,
TermDbSygus* tds,
- SygusPbe* pbe)
+ SygusPbe* pbe,
+ IntStat* rewriteChecks)
{
Trace("sygus-enum-debug") << "Init term cache " << tn << "..." << std::endl;
d_enum = e;
@@ -161,6 +167,7 @@ void SygusEnumerator::TermCache::initialize(Node e,
d_pbe = pbe;
d_sizeStartIndex[0] = 0;
d_isSygusType = false;
+ d_rewriteChecks = rewriteChecks;
// compute static information about tn
if (!d_tn.isDatatype())
@@ -320,7 +327,7 @@ bool SygusEnumerator::TermCache::addTerm(Node n)
{
d_sampleRrVInit = true;
d_samplerRrV.initializeSygus(
- d_tds, d_enum, options::sygusSamples(), false);
+ d_tds, d_enum, options::sygusSamples(), false, d_rewriteChecks);
}
d_samplerRrV.checkEquivalent(bn, bnr);
}
@@ -539,7 +546,7 @@ void SygusEnumerator::initializeTermCache(TypeNode tn)
pbe = nullptr;
}
}
- d_tcache[tn].initialize(d_enum, tn, d_tds, pbe);
+ d_tcache[tn].initialize(d_enum, tn, d_tds, pbe, &d_rewriteChecks);
}
SygusEnumerator::TermEnum* SygusEnumerator::getMasterEnumForType(TypeNode tn)
diff --git a/src/theory/quantifiers/sygus/sygus_enumerator.h b/src/theory/quantifiers/sygus/sygus_enumerator.h
index d4c466b03..0f5c581f4 100644
--- a/src/theory/quantifiers/sygus/sygus_enumerator.h
+++ b/src/theory/quantifiers/sygus/sygus_enumerator.h
@@ -45,7 +45,10 @@ class SygusEnumerator : public EnumValGenerator
{
public:
SygusEnumerator(TermDbSygus* tds, SynthConjecture* p);
- ~SygusEnumerator() {}
+ ~SygusEnumerator()
+ {
+ smtStatisticsRegistry()->unregisterStat(&d_rewriteChecks);
+ }
/** initialize this class with enumerator e */
void initialize(Node e) override;
/** Inform this generator that abstract value v was enumerated. */
@@ -100,7 +103,8 @@ class SygusEnumerator : public EnumValGenerator
void initialize(Node e,
TypeNode tn,
TermDbSygus* tds,
- SygusPbe* pbe = nullptr);
+ SygusPbe* pbe = nullptr,
+ IntStat* rewriteChecks = nullptr);
/** get last constructor class index for weight
*
* This returns a minimal index n such that all constructor classes at
@@ -183,6 +187,8 @@ class SygusEnumerator : public EnumValGenerator
quantifiers::SygusSampler d_samplerRrV;
/** is the above sampler initialized? */
bool d_sampleRrVInit;
+
+ IntStat* d_rewriteChecks;
};
/** above cache for each sygus type */
std::map<TypeNode, TermCache> d_tcache;
@@ -448,6 +454,8 @@ class SygusEnumerator : public EnumValGenerator
*/
std::unordered_set<Node, NodeHashFunction> d_sbExcTlCons;
//-------------------------------- end externally specified symmetry breaking
+
+ IntStat d_rewriteChecks;
};
} // namespace quantifiers
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback