-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSMTNodeKind.java
114 lines (105 loc) · 2.78 KB
/
SMTNodeKind.java
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
/* FuzzSMT: Fuzzing tool for Satisfiablity Modulo Theories (SMT) benchmarks.
* Copyright (C) 2009 Robert Daniel Brummayer
*
* This file is part of FuzzSMT.
*
* FuzzSMT is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* FuzzSMT is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
public enum SMTNodeKind {
/* input */
CONST("constant", 0),
VAR("variable", 0),
/* boolean */
TRUE("true", 0),
FALSE("false", 0),
NOT("not", 1),
AND("and", 2),
OR("or", 2),
IMPLIES("=>", 2),
XOR("xor", 2),
IFF("=", 2),
IF_THEN_ELSE("ite", 3), // if-then-else on boolean operands
/* bit-vector operators: */
/* unary operators */
BVNOT("bvnot", 1),
BVNEG("bvneg", 1),
/* unary operators with index */
EXTRACT("(_ extract", 1),
REPEAT("(_ repeat", 1),
ZERO_EXTEND("(_ zero_extend", 1),
SIGN_EXTEND("(_ sign_extend", 1),
ROTATE_LEFT("(_ rotate_left", 1),
ROTATE_RIGHT("(_ rotate_right", 1),
/* commutative binary operators */
BVAND("bvand", 2),
BVNAND("bvnand", 2),
BVOR("bvor", 2),
BVNOR("bvnor", 2),
BVXOR("bvxor", 2),
BVXNOR("bvxnor", 2),
BVADD("bvadd", 2),
BVMUL("bvmul", 2),
BVCOMP("bvcomp", 2),
/* non-commutative binary operators */
BVULT("bvult", 2),
BVULE("bvule", 2),
BVUGT("bvugt", 2),
BVUGE("bvuge", 2),
BVSLT("bvslt", 2),
BVSLE("bvsle", 2),
BVSGT("bvsgt", 2),
BVSGE("bvsge", 2),
BVSHL("bvshl", 2),
BVLSHR("bvlshr", 2),
BVASHR("bvashr", 2),
BVSUB("bvsub", 2),
BVUDIV("bvudiv", 2),
BVUREM("bvurem", 2),
BVSDIV("bvsdiv", 2),
BVSREM("bvsrem", 2),
BVSMOD("bvsmod", 2),
CONCAT("concat", 2),
/* interpreted predicates */
LT("<", 2),
GT(">", 2),
LE("<=", 2),
GE(">=", 2),
EQ("=", 2),
DISTINCT("distinct", -1),
/* interpreted functions */
PLUS("+", 2),
UNMINUS("-", 1),
BINMINUS("-", 2),
MUL("*", 2),
DIV("/", 2),
/* array operators */
SELECT("select", 2),
STORE("store", 3),
/* if-then-else on terms */
ITE("ite", 3),
UFUNC("extrafun", -1),
UPRED("extrapred", -1);
protected String string;
protected int arity; /* -1 is used to indicate n-ary operators */
SMTNodeKind (String string, int arity){
this.string = string;
this.arity = arity;
}
public String getString(){
return this.string;
}
public int getArity() {
return this.arity;
}
}