summaryrefslogtreecommitdiff
path: root/src/theory/quantifiers
diff options
context:
space:
mode:
authorAndrew Reynolds <andrew.j.reynolds@gmail.com>2020-09-14 21:58:08 -0500
committerGitHub <noreply@github.com>2020-09-14 21:58:08 -0500
commit4a1b5ea5568fb6c688f407946f9a7fbb1cec3c31 (patch)
tree016119f36abe7835183ce3ca3e2b7ffdaa383fcb /src/theory/quantifiers
parent996f6f9e2ecf76e39c236f9c410c109807c7073d (diff)
Fix needsModel method for CEGQI (#5048)
There was a bug in CEGQI's needModel method which could say that it doesnt need a model built when there are no active quantifiers. However, computing active quantifiers is not done in QuantifiersEngine::check until after this method is called, meaning it was using stale data on whether a quantifier was active or not. This could lead to the use of bogus models in CEGQI in incremental mode in some corner cases, leading to the assertion failure in #5019. Fixes #5019.
Diffstat (limited to 'src/theory/quantifiers')
-rw-r--r--src/theory/quantifiers/cegqi/inst_strategy_cegqi.cpp7
-rw-r--r--src/theory/quantifiers/first_order_model.cpp3
-rw-r--r--src/theory/quantifiers/first_order_model.h2
3 files changed, 8 insertions, 4 deletions
diff --git a/src/theory/quantifiers/cegqi/inst_strategy_cegqi.cpp b/src/theory/quantifiers/cegqi/inst_strategy_cegqi.cpp
index ab1bb16b5..d16024ee3 100644
--- a/src/theory/quantifiers/cegqi/inst_strategy_cegqi.cpp
+++ b/src/theory/quantifiers/cegqi/inst_strategy_cegqi.cpp
@@ -82,9 +82,12 @@ bool InstStrategyCegqi::needsCheck(Theory::Effort e)
QuantifiersModule::QEffort InstStrategyCegqi::needsModel(Theory::Effort e)
{
- for( unsigned i=0; i<d_quantEngine->getModel()->getNumAssertedQuantifiers(); i++ ){
+ size_t nquant = d_quantEngine->getModel()->getNumAssertedQuantifiers();
+ for (size_t i = 0; i < nquant; i++)
+ {
Node q = d_quantEngine->getModel()->getAssertedQuantifier( i );
- if( doCbqi( q ) && d_quantEngine->getModel()->isQuantifierActive( q ) ){
+ if (doCbqi(q))
+ {
return QEFFORT_STANDARD;
}
}
diff --git a/src/theory/quantifiers/first_order_model.cpp b/src/theory/quantifiers/first_order_model.cpp
index 61eb4ff39..51ca919bb 100644
--- a/src/theory/quantifiers/first_order_model.cpp
+++ b/src/theory/quantifiers/first_order_model.cpp
@@ -51,7 +51,8 @@ void FirstOrderModel::assertQuantifier( Node n ){
}
}
-unsigned FirstOrderModel::getNumAssertedQuantifiers() {
+size_t FirstOrderModel::getNumAssertedQuantifiers() const
+{
return d_forall_asserts.size();
}
diff --git a/src/theory/quantifiers/first_order_model.h b/src/theory/quantifiers/first_order_model.h
index bdf6d0607..b35bd6447 100644
--- a/src/theory/quantifiers/first_order_model.h
+++ b/src/theory/quantifiers/first_order_model.h
@@ -60,7 +60,7 @@ class FirstOrderModel : public TheoryModel
/** assert quantifier */
void assertQuantifier( Node n );
/** get number of asserted quantifiers */
- unsigned getNumAssertedQuantifiers();
+ size_t getNumAssertedQuantifiers() const;
/** get asserted quantifier */
Node getAssertedQuantifier( unsigned i, bool ordered = false );
/** initialize model for term */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback