blob: 17aeb43815ea3278863aeecbd4ae01d1c87fdd3e (
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
/********************* */
/*! \file evaluator.h
** \verbatim
** Top contributors (to current version):
** Andres Noetzli
** This file is part of the CVC4 project.
** Copyright (c) 2009-2017 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 The Evaluator class
**
** The Evaluator class.
**/
#include "cvc4_private.h"
#pragma once
#include <utility>
#include <vector>
#include "expr/node.h"
#include "util/bitvector.h"
namespace CVC4 {
namespace theory {
struct Result
{
enum
{
BITVECTOR,
BOOL,
INVALID
} d_tag;
union
{
bool d_bool;
BitVector d_bv;
};
Result(const Result& other)
{
d_tag = other.d_tag;
switch (d_tag)
{
case BITVECTOR:
new (&d_bv) BitVector;
d_bv = other.d_bv;
break;
case BOOL: d_bool = other.d_bool; break;
case INVALID: break;
}
}
Result() : d_tag(INVALID) {}
Result(bool b) : d_tag(BOOL), d_bool(b) {}
Result(const BitVector& bv) : d_tag(BITVECTOR), d_bv(bv) {}
Result& operator=(const Result& other)
{
if (this != &other)
{
d_tag = other.d_tag;
switch (d_tag)
{
case BITVECTOR:
new (&d_bv) BitVector;
d_bv = other.d_bv;
break;
case BOOL: d_bool = other.d_bool; break;
case INVALID: break;
}
}
return *this;
}
~Result()
{
if (d_tag == BITVECTOR)
{
d_bv.~BitVector();
}
}
Node toNode()
{
NodeManager* nm = NodeManager::currentNM();
switch (d_tag)
{
case Result::BITVECTOR: return nm->mkConst(d_bv);
case Result::BOOL: return nm->mkConst(d_bool);
default:
{
Debug("evaluator") << "Missing conversion from " << d_tag << " to node"
<< std::endl;
return Node();
}
}
return Node();
}
};
class Evaluator
{
public:
Node eval(TNode n,
const std::vector<Node>& args,
const std::vector<Node>& vals);
private:
bool d_hasResult;
std::unordered_map<TNode, Result, TNodeHashFunction> d_results;
};
} // namespace theory
} // namespace CVC4
|