GCC Code Coverage Report
Directory: . Exec Total Coverage
File: src/theory/decision_strategy.cpp Lines: 59 62 95.2 %
Date: 2021-09-10 Branches: 85 158 53.8 %

Line Exec Source
1
/******************************************************************************
2
 * Top contributors (to current version):
3
 *   Andrew Reynolds, Aina Niemetz
4
 *
5
 * This file is part of the cvc5 project.
6
 *
7
 * Copyright (c) 2009-2021 by the authors listed in the file AUTHORS
8
 * in the top-level source directory and their institutional affiliations.
9
 * All rights reserved.  See the file COPYING in the top-level source
10
 * directory for licensing information.
11
 * ****************************************************************************
12
 *
13
 * Implementation of base classes for decision strategies used by theory
14
 * solvers for use in the DecisionManager of TheoryEngine.
15
 */
16
17
#include "theory/decision_strategy.h"
18
19
#include "theory/rewriter.h"
20
21
using namespace cvc5::kind;
22
23
namespace cvc5 {
24
namespace theory {
25
26
5195
DecisionStrategyFmf::DecisionStrategyFmf(context::Context* satContext,
27
5195
                                         Valuation valuation)
28
    : d_valuation(valuation),
29
      d_has_curr_literal(false, satContext),
30
5195
      d_curr_literal(0, satContext)
31
{
32
5195
}
33
34
4495
void DecisionStrategyFmf::initialize() { d_literals.clear(); }
35
36
2260742
Node DecisionStrategyFmf::getNextDecisionRequest()
37
{
38
4521484
  Trace("dec-strategy-debug")
39
2260742
      << "Get next decision request " << identify() << "..." << std::endl;
40
2260742
  if (d_has_curr_literal.get())
41
  {
42
2166159
    Trace("dec-strategy-debug") << "...already has decision" << std::endl;
43
2166159
    return Node::null();
44
  }
45
  bool success;
46
94583
  unsigned curr_lit = d_curr_literal.get();
47
65658
  do
48
  {
49
160241
    success = true;
50
    // get the current literal
51
273940
    Node lit = getLiteral(curr_lit);
52
320478
    Trace("dec-strategy-debug")
53
160239
        << "...check literal #" << curr_lit << " : " << lit << std::endl;
54
    // if out of literals, we are done in the current SAT context
55
160239
    if (!lit.isNull())
56
    {
57
      bool value;
58
157911
      if (!d_valuation.hasSatValue(lit, value))
59
      {
60
46540
        Trace("dec-strategy-debug") << "...not assigned, return." << std::endl;
61
        // if it has not been decided, return it
62
46540
        return lit;
63
      }
64
111371
      else if (!value)
65
      {
66
131316
        Trace("dec-strategy-debug")
67
65658
            << "...assigned false, increment." << std::endl;
68
        // asserted false, the current literal is incremented
69
65658
        curr_lit = d_curr_literal.get() + 1;
70
65658
        d_curr_literal.set(curr_lit);
71
        // repeat
72
65658
        success = false;
73
      }
74
      else
75
      {
76
45713
        Trace("dec-strategy-debug") << "...already assigned true." << std::endl;
77
      }
78
    }
79
    else
80
    {
81
2328
      Trace("dec-strategy-debug") << "...exhausted literals." << std::endl;
82
    }
83
113699
  } while (!success);
84
  // the current literal has been decided with the right polarity, we are done
85
48041
  d_has_curr_literal = true;
86
48041
  return Node::null();
87
}
88
89
1210
bool DecisionStrategyFmf::getAssertedLiteralIndex(unsigned& i) const
90
{
91
1210
  if (d_has_curr_literal.get())
92
  {
93
1210
    i = d_curr_literal.get();
94
1210
    return true;
95
  }
96
  return false;
97
}
98
99
427
Node DecisionStrategyFmf::getAssertedLiteral()
100
{
101
427
  if (d_has_curr_literal.get())
102
  {
103
427
    Assert(d_curr_literal.get() < d_literals.size());
104
427
    return getLiteral(d_curr_literal.get());
105
  }
106
  return Node::null();
107
}
108
109
170235
Node DecisionStrategyFmf::getLiteral(unsigned n)
110
{
111
  // allocate until the index is valid
112
177750
  while (n >= d_literals.size())
113
  {
114
15032
    Node lit = mkLiteral(d_literals.size());
115
7515
    if (!lit.isNull())
116
    {
117
6830
      lit = Rewriter::rewrite(lit);
118
    }
119
7515
    d_literals.push_back(lit);
120
  }
121
162718
  Node ret = d_literals[n];
122
162718
  if (!ret.isNull())
123
  {
124
    // always ensure it is in the CNF stream
125
160390
    ret = d_valuation.ensureLiteral(ret);
126
  }
127
162718
  return ret;
128
}
129
130
2201
DecisionStrategySingleton::DecisionStrategySingleton(
131
    const char* name,
132
    Node lit,
133
    context::Context* satContext,
134
2201
    Valuation valuation)
135
2201
    : DecisionStrategyFmf(satContext, valuation), d_name(name), d_literal(lit)
136
{
137
2201
}
138
139
2799
Node DecisionStrategySingleton::mkLiteral(unsigned n)
140
{
141
2799
  if (n == 0)
142
  {
143
2114
    return d_literal;
144
  }
145
685
  return Node::null();
146
}
147
148
Node DecisionStrategySingleton::getSingleLiteral() { return d_literal; }
149
150
}  // namespace theory
151
29502
}  // namespace cvc5