forked from pjt33/MiniSAT.cs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.cs
109 lines (93 loc) · 2.09 KB
/
main.cs
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
using System;
using System.IO;
using System.Text;
using System.Diagnostics;
using System.Collections.Generic;
using MiniSatCS;
class MainClass {
static string ReadWord(StreamReader s)
{
StringBuilder sb = new StringBuilder();
for (;;) {
int ch = s.Read();
if (ch == -1) break;
char c = (char)ch;
if (char.IsWhiteSpace(c)) {
if (sb.Length > 0) break;
} else {
if (c == 'p' || c == 'c')
{
do {
ch = s.Read();
} while (ch != -1 && (char)ch != '\n');
if (sb.Length > 0) break;
} else
sb.Append(c);
}
}
if (sb.Length == 0) return null;
else return sb.ToString();
}
public static void Main (string[] args)
{
if (args.Length < 1) {
Console.Error.WriteLine("usage: minisat [-s|-u] <file1.cnf> ...");
return;
}
bool expect = false;
bool expect_res = false;
int pos = 0;
if (args[pos] == "-s") {
expect = true;
expect_res = true;
pos++;
}
if (args[pos] == "-u") {
expect = true;
expect_res = false;
pos++;
}
for (; pos < args.Length; pos++) {
StreamReader sr = File.OpenText(args[pos]);
vec<Solver.Lit> lits = new vec<Solver.Lit>();
Solver S = new Solver();
for (;;)
{
lits.clear();
string w;
while ((w = ReadWord(sr)) != null)
{
if (w == "%") break;
int parsed_lit = int.Parse(w);
if (parsed_lit == 0)
break;
int var = Math.Abs(parsed_lit)-1;
while (var >= S.nVars()) S.newVar();
lits.push( (parsed_lit > 0) ? new Solver.Lit(var) : ~new Solver.Lit(var) );
}
if (w == null) break;
S.addClause(lits);
}
if (expect) {
S.verbosity = 0;
S.solve();
if (S.okay() == expect_res)
Solver.reportf(".");
else
Solver.reportf("\nproblem: {0}\n", args[pos]);
} else {
S.verbosity = 1;
S.solve();
Solver.reportf(S.okay() ? "SATISFIABLE\n" : "UNSATISFIABLE\n");
S.printStats();
}
#if false
if (S.okay()) {
for (int i = 0; i < S.nVars(); i++)
if (S.model[i] != l_Undef)
Solver.reportf("{0}{1}\n", (S.model[i]==l_True)?" ":"-", i+1);
}
#endif
}
}
} // class MiniSat