blob: cda7ad67a2f439947532f409ecc81f4c8e2e2187 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
/********************* */
/*! \file quantifiers_preprocess.cpp
** \verbatim
** Top contributors (to current version):
** Caleb Donovick
** 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 Remove rewrite rules, apply pre-skolemization to existential
*quantifiers
**
**
** Calls the quantifier rewriter, removing rewrite rules and applying
** pre-skolemization to existential quantifiers
**/
#include "preprocessing/passes/quantifiers_preprocess.h"
#include "base/output.h"
#include "theory/quantifiers/quantifiers_rewriter.h"
#include "theory/rewriter.h"
namespace CVC4 {
namespace preprocessing {
namespace passes {
using namespace CVC4::theory;
QuantifiersPreprocess::QuantifiersPreprocess(PreprocessingPassContext* preprocContext)
: PreprocessingPass(preprocContext, "quantifiers-preprocess"){};
PreprocessingPassResult QuantifiersPreprocess::applyInternal(
AssertionPipeline* assertionsToPreprocess)
{
size_t size = assertionsToPreprocess->size();
for (size_t i = 0; i < size; ++i)
{
Node prev = (*assertionsToPreprocess)[i];
TrustNode trn = quantifiers::QuantifiersRewriter::preprocess(prev);
if (!trn.isNull())
{
Node next = trn.getNode();
assertionsToPreprocess->replace(i, Rewriter::rewrite(next));
Trace("quantifiers-preprocess") << "*** Pre-skolemize " << prev << endl;
Trace("quantifiers-preprocess")
<< " ...got " << (*assertionsToPreprocess)[i] << endl;
}
}
return PreprocessingPassResult::NO_CONFLICT;
}
} // namespace passes
} // namespace preprocessing
} // namespace CVC4
|