修改项目结构,更新makefile

This commit is contained in:
YuhangQ 2023-03-21 08:14:37 +00:00
parent c3efc6aafb
commit f02012ea75
36 changed files with 9531 additions and 14165 deletions

2
.gitignore vendored
View File

@ -1,3 +1,3 @@
*.o *.o
*.d*
output.txt output.txt
build

2
.vscode/launch.json vendored
View File

@ -9,7 +9,7 @@
"type": "cppdbg", "type": "cppdbg",
"request": "launch", "request": "launch",
"program": "${workspaceFolder}/atpg", "program": "${workspaceFolder}/atpg",
"args": ["c432.bench"], "args": ["${workspaceFolder}/benchmark/c432.bench"],
"stopAtEntry": false, "stopAtEntry": false,
"cwd": "${fileDirname}", "cwd": "${fileDirname}",
"environment": [], "environment": [],

View File

@ -24,6 +24,9 @@
"string_view": "cpp", "string_view": "cpp",
"tuple": "cpp", "tuple": "cpp",
"type_traits": "cpp", "type_traits": "cpp",
"typeinfo": "cpp" "typeinfo": "cpp",
"sstream": "cpp",
"ostream": "cpp",
"iostream": "cpp"
} }
} }

515
.vscode/test.cnf vendored Normal file
View File

@ -0,0 +1,515 @@
p cnf 196 514
-37 -1 0
37 1 0
-38 -2 0
38 2 0
-39 -4 0
39 4 0
-40 -6 0
40 6 0
-41 -8 0
41 8 0
-42 -10 0
42 10 0
-43 -12 0
43 12 0
-44 -14 0
44 14 0
-45 -16 0
45 16 0
-46 -18 0
46 18 0
-47 -20 0
47 20 0
-48 -22 0
48 22 0
-49 -24 0
49 24 0
-50 -26 0
50 26 0
-51 -28 0
51 28 0
-52 -30 0
52 30 0
-53 -32 0
53 32 0
-54 -34 0
54 34 0
55 37 0
55 2 0
-37 -2 -55 0
3 38 56 0
-56 -3 0
-56 -38 0
5 38 57 0
-57 -5 0
-57 -38 0
58 39 0
58 6 0
-39 -6 -58 0
61 41 0
61 10 0
-41 -10 -61 0
64 43 0
64 14 0
-43 -14 -64 0
67 45 0
67 18 0
-45 -18 -67 0
70 47 0
70 22 0
-47 -22 -70 0
73 49 0
73 26 0
-49 -26 -73 0
76 51 0
76 30 0
-51 -30 -76 0
79 53 0
79 34 0
-53 -34 -79 0
7 40 59 0
-59 -7 0
-59 -40 0
9 40 60 0
-60 -9 0
-60 -40 0
11 42 62 0
-62 -11 0
-62 -42 0
13 42 63 0
-63 -13 0
-63 -42 0
15 44 65 0
-65 -15 0
-65 -44 0
17 44 66 0
-66 -17 0
-66 -44 0
19 46 68 0
-68 -19 0
-68 -46 0
21 46 69 0
-69 -21 0
-69 -46 0
23 48 71 0
-71 -23 0
-71 -48 0
25 48 72 0
-72 -25 0
-72 -48 0
27 50 74 0
-74 -27 0
-74 -50 0
29 50 75 0
-75 -29 0
-75 -50 0
31 52 77 0
-77 -31 0
-77 -52 0
33 52 78 0
-78 -33 0
-78 -52 0
35 54 80 0
-80 -35 0
-80 -54 0
36 54 81 0
-81 -36 0
-81 -54 0
-82 55 0
-82 58 0
-82 61 0
-82 64 0
-82 67 0
-82 70 0
-82 73 0
-82 76 0
-82 79 0
-55 -58 -61 -64 -67 -70 -73 -76 -79 82 0
-83 -82 0
83 82 0
-84 -82 0
84 82 0
-85 -82 0
85 82 0
-86 -83 -55 0
-86 83 55 0
86 -83 55 0
86 83 -55 0
-87 -83 -58 0
-87 83 58 0
87 -83 58 0
87 83 -58 0
-88 -83 -61 0
-88 83 61 0
88 -83 61 0
88 83 -61 0
-89 -83 -64 0
-89 83 64 0
89 -83 64 0
89 83 -64 0
-90 -83 -67 0
-90 83 67 0
90 -83 67 0
90 83 -67 0
-91 -83 -70 0
-91 83 70 0
91 -83 70 0
91 83 -70 0
95 1 0
95 84 0
-1 -84 -95 0
-92 -83 -73 0
-92 83 73 0
92 -83 73 0
92 83 -73 0
96 84 0
96 4 0
-84 -4 -96 0
-93 -83 -76 0
-93 83 76 0
93 -83 76 0
93 83 -76 0
97 84 0
97 8 0
-84 -8 -97 0
-94 -83 -79 0
-94 83 79 0
94 -83 79 0
94 83 -79 0
98 84 0
98 12 0
-84 -12 -98 0
99 84 0
99 16 0
-84 -16 -99 0
100 84 0
100 20 0
-84 -20 -100 0
101 84 0
101 24 0
-84 -24 -101 0
102 84 0
102 28 0
-84 -28 -102 0
103 84 0
103 32 0
-84 -32 -103 0
104 86 0
104 56 0
-86 -56 -104 0
105 86 0
105 57 0
-86 -57 -105 0
106 87 0
106 59 0
-87 -59 -106 0
108 88 0
108 62 0
-88 -62 -108 0
110 89 0
110 65 0
-89 -65 -110 0
112 90 0
112 68 0
-90 -68 -112 0
114 91 0
114 71 0
-91 -71 -114 0
116 92 0
116 74 0
-92 -74 -116 0
118 93 0
118 77 0
-93 -77 -118 0
120 94 0
120 80 0
-94 -80 -120 0
107 87 0
107 60 0
-87 -60 -107 0
109 88 0
109 63 0
-88 -63 -109 0
111 89 0
111 66 0
-89 -66 -111 0
113 90 0
113 69 0
-90 -69 -113 0
115 91 0
115 72 0
-91 -72 -115 0
117 92 0
117 75 0
-92 -75 -117 0
119 93 0
119 78 0
-93 -78 -119 0
121 94 0
121 81 0
-94 -81 -121 0
-130 104 0
-130 106 0
-130 108 0
-130 110 0
-130 112 0
-130 114 0
-130 116 0
-130 118 0
-130 120 0
-104 -106 -108 -110 -112 -114 -116 -118 -120 130 0
-122 -105 0
122 105 0
-123 -107 0
123 107 0
-124 -109 0
124 109 0
-125 -111 0
125 111 0
-126 -113 0
126 113 0
-127 -115 0
127 115 0
-128 -117 0
128 117 0
-129 -119 0
129 119 0
-131 -121 0
131 121 0
-132 -130 0
132 130 0
-133 -130 0
133 130 0
-134 -130 0
134 130 0
-135 -132 -104 0
-135 132 104 0
135 -132 104 0
135 132 -104 0
-136 -132 -106 0
-136 132 106 0
136 -132 106 0
136 132 -106 0
-137 -132 -108 0
-137 132 108 0
137 -132 108 0
137 132 -108 0
-138 -132 -110 0
-138 132 110 0
138 -132 110 0
138 132 -110 0
144 3 0
144 133 0
-3 -133 -144 0
-139 -132 -112 0
-139 132 112 0
139 -132 112 0
139 132 -112 0
145 133 0
145 7 0
-133 -7 -145 0
-140 -132 -114 0
-140 132 114 0
140 -132 114 0
140 132 -114 0
146 133 0
146 11 0
-133 -11 -146 0
-141 -132 -116 0
-141 132 116 0
141 -132 116 0
141 132 -116 0
147 133 0
147 15 0
-133 -15 -147 0
-142 -132 -118 0
-142 132 118 0
142 -132 118 0
142 132 -118 0
148 133 0
148 19 0
-133 -19 -148 0
-143 -132 -120 0
-143 132 120 0
143 -132 120 0
143 132 -120 0
149 133 0
149 23 0
-133 -23 -149 0
150 133 0
150 27 0
-133 -27 -150 0
151 133 0
151 31 0
-133 -31 -151 0
152 133 0
152 35 0
-133 -35 -152 0
153 135 0
153 122 0
-135 -122 -153 0
154 136 0
154 123 0
-136 -123 -154 0
155 137 0
155 124 0
-137 -124 -155 0
156 138 0
156 125 0
-138 -125 -156 0
157 139 0
157 126 0
-139 -126 -157 0
158 140 0
158 127 0
-140 -127 -158 0
159 141 0
159 128 0
-141 -128 -159 0
160 142 0
160 129 0
-142 -129 -160 0
161 143 0
161 131 0
-143 -131 -161 0
-162 153 0
-162 154 0
-162 155 0
-162 156 0
-162 157 0
-162 158 0
-162 159 0
-162 160 0
-162 161 0
-153 -154 -155 -156 -157 -158 -159 -160 -161 162 0
-163 -162 0
163 162 0
-164 -162 0
164 162 0
165 5 0
165 163 0
-5 -163 -165 0
166 163 0
166 9 0
-163 -9 -166 0
167 163 0
167 13 0
-163 -13 -167 0
168 163 0
168 17 0
-163 -17 -168 0
169 163 0
169 21 0
-163 -21 -169 0
170 163 0
170 25 0
-163 -25 -170 0
171 163 0
171 29 0
-163 -29 -171 0
172 163 0
172 33 0
-163 -33 -172 0
173 163 0
173 36 0
-163 -36 -173 0
174 2 0
174 95 0
174 144 0
174 165 0
-2 -95 -144 -165 -174 0
175 96 0
175 145 0
175 166 0
175 6 0
-96 -145 -166 -6 -175 0
176 97 0
176 146 0
176 167 0
176 10 0
-97 -146 -167 -10 -176 0
177 98 0
177 147 0
177 168 0
177 14 0
-98 -147 -168 -14 -177 0
178 99 0
178 148 0
178 169 0
178 18 0
-99 -148 -169 -18 -178 0
179 100 0
179 149 0
179 170 0
179 22 0
-100 -149 -170 -22 -179 0
180 101 0
180 150 0
180 171 0
180 26 0
-101 -150 -171 -26 -180 0
181 102 0
181 151 0
181 172 0
181 30 0
-102 -151 -172 -30 -181 0
182 103 0
182 152 0
182 173 0
182 34 0
-103 -152 -173 -34 -182 0
-183 -174 0
183 174 0
-188 175 0
-188 176 0
-188 177 0
-188 178 0
-188 179 0
-188 180 0
-188 181 0
-188 182 0
-175 -176 -177 -178 -179 -180 -181 -182 188 0
-184 -177 0
184 177 0
-185 -179 0
185 179 0
-186 -180 0
186 180 0
-187 -181 0
187 181 0
183 188 193 0
-193 -183 0
-193 -188 0
189 176 0
189 184 0
-176 -184 -189 0
190 176 0
190 177 0
190 185 0
190 178 0
-176 -177 -185 -178 -190 0
191 178 0
191 177 0
191 186 0
-178 -177 -186 -191 0
192 176 0
192 177 0
192 180 0
192 187 0
-176 -177 -180 -187 -192 0
194 175 0
194 176 0
194 189 0
194 178 0
-175 -176 -189 -178 -194 0
195 175 0
195 176 0
195 190 0
195 191 0
-175 -176 -190 -191 -195 0
196 175 0
196 189 0
196 190 0
196 192 0
-175 -189 -190 -192 -196 0

BIN
CCAnr/CCAnr Executable file

Binary file not shown.

Binary file not shown.

View File

@ -1,3 +1,2 @@
all: basis.hpp basis.cpp cnc.hpp cnc.cpp indusLS.hpp indusLS.cpp main.cpp CCAnr: cca.cpp cca.h basis.h cw.h preprocessor.h
g++ -s -O3 -DNDEBUG -static *.cpp -o CCAnr+cnc g++ cca.cpp -O3 -static -o CCAnr

View File

@ -1,269 +0,0 @@
#include "basis.hpp"
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cmath>
#include <sys/times.h> //these two h files are for linux
#include <unistd.h>
#include "cnc.hpp" // cnc_unit_last
using namespace std;
int cutoff_time;
bool shouldPrint = false;
/*parameters of the instance*/
int num_vars;
int num_clauses;
/* literal arrays */
lit* var_lit[MAX_VARS];
int var_lit_count[MAX_VARS];
lit* clause_lit[MAX_CLAUSES];
int clause_lit_count[MAX_CLAUSES];
lit clause_xor_org[MAX_CLAUSES];
int score1[MAX_VARS];
int score0[MAX_VARS];
int tries;
struct _the_best_s the_best;
static struct tms start;
double get_runtime(void) {
struct tms stop;
times(&stop);
return (double) (stop.tms_utime - start.tms_utime +stop.tms_stime - start.tms_stime) / sysconf(_SC_CLK_TCK);
}
void record_runtime(void) {
times(&start);
}
/*
* Read in the problem.
*/
int build_instance(const char *filename)
{
char *line = new char[1000000];
int *temp_lit = new int[MAX_VARS];
char tempstr1[10];
char tempstr2[10];
int cur_lit;
int i;
int v,c;//var, clause
ifstream infile(filename);
if(!infile)
return 0;
/*** build problem data structures of the instance ***/
infile.getline(line,1000000);
while (line[0] != 'p')
infile.getline(line,1000000);
sscanf(line, "%s %s %d %d", tempstr1, tempstr2, &num_vars, &num_clauses);
//cout << num_vars << '\t' << num_clauses << "\n";
if(num_vars>=MAX_VARS || num_clauses>=MAX_CLAUSES)
{
//cout<<"c the size of instance exceeds out limitation, please enlarge MAX_VARS and (or) MAX_CLAUSES."<<endl;
exit(1);
}
for (c = 0; c < num_clauses; c++)
{
clause_lit_count[c] = 0;
clause_lit[c]=NULL;
}
for (v=1; v<=num_vars; ++v)
{
var_lit_count[v] = 0;
var_lit[v]=NULL;
}
//Now, read the clauses, one at a time.
int lit_redundent, clause_redundent;
int redundent_clause_count = 0;
for (c = 0; c < num_clauses; )
{
clause_redundent = 0;
clause_lit_count[c] = 0;
infile>>cur_lit;
while (cur_lit != 0) {
lit_redundent = 0;
for(int p = 0; p < clause_lit_count[c]; p++)
{
if(cur_lit == temp_lit[p]){
//cout << "c " << filename << ": WARNING! literal " << cur_lit << " redundent in clause " << c + redundent_clause_count << endl;
lit_redundent = 1;
break;
}
else if(cur_lit == -temp_lit[p]){
//cout << "c " << filename << ": WARNING! conflict variable " << abs(cur_lit) << " detected in the clause " << c + redundent_clause_count << endl;
clause_redundent = 1;
break;
}
}
if(lit_redundent == 0)
{
temp_lit[clause_lit_count[c]] = cur_lit;
clause_lit_count[c]++;
}
infile>>cur_lit;
}
if(clause_redundent == 0)
{
clause_lit[c] = new lit[clause_lit_count[c]+1];
clause_xor_org[c].reset();
for(i=0; i<clause_lit_count[c]; ++i)
{
clause_lit[c][i].clause_num = c;
clause_lit[c][i].var_num = abs(temp_lit[i]);
if (temp_lit[i] > 0) clause_lit[c][i].sense = 1;
else clause_lit[c][i].sense = 0;
clause_xor_org[c] ^= clause_lit[c][i];
var_lit_count[clause_lit[c][i].var_num]++;
}
clause_lit[c][i].var_num=0;
clause_lit[c][i].clause_num = -1;
c++;
}
else
{
num_clauses--;
clause_lit_count[c] = 0;
redundent_clause_count++;
}
}
//creat var literal arrays
for (v=1; v<=num_vars; ++v)
{
var_lit[v] = new lit[var_lit_count[v] + 1];
var_lit_count[v] = 0; //reset to 0, for build up the array
}
//scan all clauses to build up var literal arrays
for (c = 0; c < num_clauses; ++c)
{
for(i=0; i<clause_lit_count[c]; ++i)
{
v = clause_lit[c][i].var_num;
var_lit[v][var_lit_count[v]] = clause_lit[c][i];
++var_lit_count[v];
if(clause_lit[c][i].sense==1) score1[v]++;
else score0[v]++;
}
}
for (v=1; v<=num_vars; ++v) //set boundary
var_lit[v][var_lit_count[v]].clause_num=-1;
the_best.soln = new int[num_vars + 1];
the_best.opt_unsat = num_clauses;
the_best.opt_time = -1;
the_best.opt_try = 0;
the_best.source = 0;
delete [] temp_lit;
delete [] line;
return 1;
}
void update_best_soln(const int opt, const int *soln, const int source) {
for(int v = 1; v <= num_vars; v++)
the_best.soln[v] = soln[v];
//if (!shouldPrint)
// cout << "o " << opt << endl;
the_best.opt_unsat = opt;
the_best.opt_time = get_runtime();
the_best.opt_try = tries;
the_best.source = source;
//cout << "c optInfo\t" << opt << "\t" << the_best.opt_time << "\t" << tries << "\t" << source << endl;
}
void update_best_value(const int opt) {
//if (!shouldPrint)
// cout << "o " << opt << endl;
the_best.opt_unsat = opt;
}
void print_best_solution(void) {
//cout << "c SOLN_BEGIN\t" << get_runtime() << endl;;
cout << "v";
for (int i = 1; i <= num_vars; i++) {
cout << " " << i * ((the_best.soln[i] << 1) - 1);
}
cout << endl;
//cout << "c SOLN_END\t" << get_runtime() << endl;
cout << flush;
}
bool verify_sol(void) {
int c, j;
int flag;
for (c = 0; c < num_clauses; ++c) {
flag = 0;
for(j = 0; j < clause_lit_count[c]; ++j) {
if (the_best.soln[clause_lit[c][j].var_num] == clause_lit[c][j].sense) {
flag = 1;
break;
}
}
if(flag ==0){
cout<<"c Error: the assignment is not a solution."<<endl;
return false;
}
}
return true;
/*if (verify_unsat == the_best.opt_unsat) {
return 1;
} else {
cout << "c ERROR: find opt=" << the_best.opt_unsat << ", but verified opt=" << verify_unsat << endl;
cout << "o " << verify_unsat << endl;
the_best.opt_unsat = verify_unsat;
return 0;
}*/
}

378
CCAnr/basis.h Normal file
View File

@ -0,0 +1,378 @@
#ifndef _BASIS_H_
#define _BASIS_H_
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cmath>
using namespace std;
enum type{SAT3, SAT5, SAT7, strSAT} probtype;
/* limits on the size of the problem. */
#define MAX_VARS 4000010
#define MAX_CLAUSES 20000000
// Define a data structure for a literal in the SAT problem.
struct lit {
int clause_num; //clause num, begin with 0
int var_num; //variable num, begin with 1
int sense; //is 1 for true literals, 0 for false literals.
};
/*parameters of the instance*/
int num_vars; //var index from 1 to num_vars
int num_clauses; //clause index from 0 to num_clauses-1
int max_clause_len;
int min_clause_len;
int formula_len=0;
double avg_clause_len;
double ratio;
/* literal arrays */
lit* var_lit[MAX_VARS]; //var_lit[i][j] means the j'th literal of var i.
int var_lit_count[MAX_VARS]; //amount of literals of each var
lit* clause_lit[MAX_CLAUSES]; //clause_lit[i][j] means the j'th literal of clause i.
int clause_lit_count[MAX_CLAUSES]; // amount of literals in each clause
lit* org_clause_lit[MAX_CLAUSES]; //clause_lit[i][j] means the j'th literal of clause i.
int org_clause_lit_count[MAX_CLAUSES]; // amount of literals in each clause
int simplify=0;
/* Information about the variables. */
int score[MAX_VARS];
int time_stamp[MAX_VARS];
int conf_change[MAX_VARS];
int* var_neighbor[MAX_VARS];
int var_neighbor_count[MAX_VARS];
//int pscore[MAX_VARS];
int fix[MAX_VARS];
/* Information about the clauses */
int clause_weight[MAX_CLAUSES];
int sat_count[MAX_CLAUSES];
int sat_var[MAX_CLAUSES];
//int sat_var2[MAX_CLAUSES];
//unsat clauses stack
int unsat_stack[MAX_CLAUSES]; //store the unsat clause number
int unsat_stack_fill_pointer;
int index_in_unsat_stack[MAX_CLAUSES];//which position is a clause in the unsat_stack
int this_try_best_unsat_stack_fill_pointer;
//variables in unsat clauses
int unsatvar_stack[MAX_VARS];
int unsatvar_stack_fill_pointer;
int index_in_unsatvar_stack[MAX_VARS];
int unsat_app_count[MAX_VARS]; //a varible appears in how many unsat clauses
//configuration changed decreasing variables (score>0 and confchange=1)
int goodvar_stack[MAX_VARS];
int goodvar_stack_fill_pointer;
int already_in_goodvar_stack[MAX_VARS];
//unit clauses preprocess
lit unitclause_queue[MAX_VARS];
int unitclause_queue_beg_pointer=0;
int unitclause_queue_end_pointer=0;
int clause_delete[MAX_CLAUSES];
/* Information about solution */
int cur_soln[MAX_VARS]; //the current solution, with 1's for True variables, and 0's for False variables
//cutoff
int max_tries = 10000;
int tries;
int max_flips = 2000000000;
int step;
void setup_datastructure();
void free_memory();
int build_instance(char *filename);
void build_neighbor_relation();
void free_memory()
{
int i;
for (i = 0; i < num_clauses; i++)
{
delete[] clause_lit[i];
}
for(i=1; i<=num_vars; ++i)
{
delete[] var_lit[i];
delete[] var_neighbor[i];
}
}
/*
* Read in the problem.
*/
int temp_lit[MAX_VARS]; //the max length of a clause can be MAX_VARS
int build_instance(char *filename)
{
char line[1000000];
char tempstr1[10];
char tempstr2[10];
int cur_lit;
int i,j;
int v,c;//var, clause
ifstream infile(filename);
if(!infile.is_open())
return 0;
/*** build problem data structures of the instance ***/
infile.getline(line,1000000);
while (line[0] != 'p')
infile.getline(line,1000000);
sscanf(line, "%s %s %d %d", tempstr1, tempstr2, &num_vars, &num_clauses);
ratio = double(num_clauses)/num_vars;
if(num_vars>=MAX_VARS || num_clauses>=MAX_CLAUSES)
{
cout<<"the size of instance exceeds out limitation, please enlarge MAX_VARS and (or) MAX_CLAUSES."<<endl;
exit(-1);
}
for (c = 0; c < num_clauses; c++)
{
clause_lit_count[c] = 0;
clause_delete[c] = 0;
}
for (v=1; v<=num_vars; ++v)
{
var_lit_count[v] = 0;
fix[v] = 0;
}
max_clause_len = 0;
min_clause_len = num_vars;
//Now, read the clauses, one at a time.
for (c = 0; c < num_clauses; c++)
{
infile>>cur_lit;
while (cur_lit != 0) {
temp_lit[clause_lit_count[c]] = cur_lit;
clause_lit_count[c]++;
infile>>cur_lit;
}
clause_lit[c] = new lit[clause_lit_count[c]+1];
for(i=0; i<clause_lit_count[c]; ++i)
{
clause_lit[c][i].clause_num = c;
clause_lit[c][i].var_num = abs(temp_lit[i]);
if (temp_lit[i] > 0) clause_lit[c][i].sense = 1;
else clause_lit[c][i].sense = 0;
var_lit_count[clause_lit[c][i].var_num]++;
}
clause_lit[c][i].var_num=0;
clause_lit[c][i].clause_num = -1;
//unit clause
if(clause_lit_count[c]==1)
{
unitclause_queue[unitclause_queue_end_pointer++] = clause_lit[c][0];
clause_delete[c]=1;
}
if(clause_lit_count[c] > max_clause_len)
max_clause_len = clause_lit_count[c];
else if(clause_lit_count[c] < min_clause_len)
min_clause_len = clause_lit_count[c];
formula_len += clause_lit_count[c];
}
infile.close();
avg_clause_len = (double)formula_len/num_clauses;
if(unitclause_queue_end_pointer>0)
{
simplify = 1;
for (c = 0; c < num_clauses; c++)
{
org_clause_lit_count[c] = clause_lit_count[c];
org_clause_lit[c] = new lit[clause_lit_count[c]+1];
for(i=0; i<org_clause_lit_count[c]; ++i)
{
org_clause_lit[c][i] = clause_lit[c][i];
}
}
}
//creat var literal arrays
for (v=1; v<=num_vars; ++v)
{
var_lit[v] = new lit[var_lit_count[v]+1];
var_lit_count[v] = 0; //reset to 0, for build up the array
}
//scan all clauses to build up var literal arrays
for (c = 0; c < num_clauses; ++c)
{
for(i=0; i<clause_lit_count[c]; ++i)
{
v = clause_lit[c][i].var_num;
var_lit[v][var_lit_count[v]] = clause_lit[c][i];
++var_lit_count[v];
}
}
for (v=1; v<=num_vars; ++v) //set boundary
var_lit[v][var_lit_count[v]].clause_num=-1;
return 1;
}
void build_neighbor_relation()
{
int* neighbor_flag = new int[num_vars+1];
int i,j,count;
int v,c;
for(v=1; v<=num_vars; ++v)
{
var_neighbor_count[v] = 0;
if(fix[v]==1) continue;
for(i=1; i<=num_vars; ++i)
neighbor_flag[i] = 0;
neighbor_flag[v] = 1;
for(i=0; i<var_lit_count[v]; ++i)
{
c = var_lit[v][i].clause_num;
if(clause_delete[c]==1) continue;
for(j=0; j<clause_lit_count[c]; ++j)
{
if(neighbor_flag[clause_lit[c][j].var_num]==0)
{
var_neighbor_count[v]++;
neighbor_flag[clause_lit[c][j].var_num] = 1;
}
}
}
neighbor_flag[v] = 0;
var_neighbor[v] = new int[var_neighbor_count[v]+1];
count = 0;
for(i=1; i<=num_vars; ++i)
{
if(fix[i]==1) continue;
if(neighbor_flag[i]==1)
{
var_neighbor[v][count] = i;
count++;
}
}
var_neighbor[v][count]=0;
}
delete[] neighbor_flag; neighbor_flag=NULL;
}
void print_solution()
{
int i;
cout<<"v ";
for (i=1; i<=num_vars; i++) {
if(cur_soln[i]==0) cout<<"-";
cout<<i;
if(i%10==0) cout<<endl<<"v ";
else cout<<' ';
}
cout<<"0"<<endl;
}
int verify_sol()
{
int c,j;
int flag;
if(simplify==0)
{
for (c = 0; c<num_clauses; ++c)
{
flag = 0;
for(j=0; j<clause_lit_count[c]; ++j)
if (cur_soln[clause_lit[c][j].var_num] == clause_lit[c][j].sense) {flag = 1; break;}
if(flag ==0){//output the clause unsatisfied by the solution
cout<<"c clause "<<c<<" is not satisfied"<<endl;
cout<<"c ";
for(j=0; j<clause_lit_count[c]; ++j)
{
if(clause_lit[c][j].sense==0)cout<<"-";
cout<<clause_lit[c][j].var_num<<" ";
}
cout<<endl;
for(j=0; j<clause_lit_count[c]; ++j)
cout<<cur_soln[clause_lit[c][j].var_num]<<" ";
cout<<endl;
return 0;
}
}
}
if(simplify==1)
{
for (c = 0; c<num_clauses; ++c)
{
flag = 0;
for(j=0; j<org_clause_lit_count[c]; ++j)
if (cur_soln[org_clause_lit[c][j].var_num] == org_clause_lit[c][j].sense) {flag = 1; break;}
if(flag ==0){//output the clause unsatisfied by the solution
cout<<"c clause "<<c<<" is not satisfied"<<endl;
if(clause_delete[c]==1)cout<<"c this clause is deleted by UP."<<endl;
cout<<"c ";
for(j=0; j<org_clause_lit_count[c]; ++j)
{
if(org_clause_lit[c][j].sense==0)cout<<"-";
cout<<org_clause_lit[c][j].var_num<<" ";
}
cout<<endl;
for(j=0; j<org_clause_lit_count[c]; ++j)
cout<<cur_soln[org_clause_lit[c][j].var_num]<<" ";
cout<<endl;
return 0;
}
}
}
return 1;
}
#endif

View File

@ -1,76 +0,0 @@
#ifndef _BASIS_H_
#define _BASIS_H_
/* limits on the size of the problem. */
#define MAX_VARS 5000010
#define MAX_CLAUSES 20000000
extern bool shouldPrint;
// Define a data structure for a literal in the SAT problem.
struct lit {
unsigned char sense:1; //is 1 for true literals, 0 for false literals.
int clause_num:31; //clause num, begin with 0
int var_num; //variable num, begin with 1
struct lit& operator^=(const struct lit &l) {
sense ^= l.sense;
clause_num ^= l.clause_num;
var_num ^= l.var_num;
return *this;
}
void reset(void) {
sense = 0;
clause_num = 0;
var_num = 0;
}
bool operator==(const struct lit &l) const {
return sense == l.sense && clause_num == l.clause_num && var_num == l.var_num;
}
bool operator!=(const struct lit &l) const {
return !(*this == l);
}
};
/*parameters of the instance*/
extern int num_vars; //var index from 1 to num_vars
extern int num_clauses; //clause index from 0 to num_clauses-1
/* literal arrays */
extern lit* var_lit[MAX_VARS]; //var_lit[i][j] means the j'th literal of var i.
extern int var_lit_count[MAX_VARS]; //amount of literals of each var
extern lit* clause_lit[MAX_CLAUSES]; //clause_lit[i][j] means the j'th literal of clause i.
extern int clause_lit_count[MAX_CLAUSES]; // amount of literals in each clause
// Used by CNC, but since it is hard to update, just put it here...
extern lit clause_xor_org[MAX_CLAUSES];
extern int score1[MAX_VARS];
extern int score0[MAX_VARS];
extern int tries;
extern int cutoff_time;
struct _the_best_s {
int *soln;
int opt_unsat;
double opt_time;
int opt_try;
int source;
};
extern struct _the_best_s the_best;
int build_instance(const char *filename);
void print_best_solution(void);
void update_best_soln(const int opt, const int *soln, const int source);
void update_best_value(const int opt);
bool verify_sol(void);
void record_runtime(void);
double get_runtime(void);
#endif

292
CCAnr/cca.cpp Normal file
View File

@ -0,0 +1,292 @@
#include "basis.h"
#include "cca.h"
#include "cw.h"
#include "preprocessor.h"
#include <string.h>
#include <sys/times.h> //these two h files are for linux
#include <unistd.h>
#include "ccanr.h"
char * inst;
int seed;
long long ls_no_improv_times;
bool aspiration_active;
static int pick_var(void)
{
int i,k,c,v;
int best_var;
lit* clause_c;
/**Greedy Mode**/
/*CCD (configuration changed decreasing) mode, the level with configuation chekcing*/
if(goodvar_stack_fill_pointer>0)
{
//if(goodvar_stack_fill_pointer<balancePar)
//{
best_var = goodvar_stack[0];
for(i=1; i<goodvar_stack_fill_pointer; ++i)
{
v=goodvar_stack[i];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var])
{
//if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
if(time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
//}
/*else
{
best_var = goodvar_stack[rand()%goodvar_stack_fill_pointer];
for(int j=1;j<balancePar;++j)
{
v = goodvar_stack[rand()%goodvar_stack_fill_pointer];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var])
{
//if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
if(time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
}*/
}
/*aspiration*/
if (aspiration_active)
{
best_var = 0;
for(i=0; i<unsatvar_stack_fill_pointer; ++i)
{
if(score[unsatvar_stack[i]]>ave_weight)
{
best_var = unsatvar_stack[i];
break;
}
}
for(++i; i<unsatvar_stack_fill_pointer; ++i)
{
v=unsatvar_stack[i];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var] && time_stamp[v]<time_stamp[best_var]) best_var = v;
}
if(best_var!=0) return best_var;
}
/*****end aspiration*******************/
update_clause_weights();
/*focused random walk*/
c = unsat_stack[rand()%unsat_stack_fill_pointer];
clause_c = clause_lit[c];
best_var = clause_c[0].var_num;
for(k=1; k<clause_lit_count[c]; ++k)
{
v=clause_c[k].var_num;
//using score
//if(score[v]>score[best_var]) best_var = v;
//else if(score[v]==score[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
//using unweighted make
if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var] && time_stamp[v]<time_stamp[best_var]) best_var = v;
else if(unsat_app_count[v]==unsat_app_count[best_var])
{
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
}
//set functions in the algorithm
void settings()
{
//set_clause_weighting();
//aspiration_active = false; //
}
/*
void local_search(int max_flips)
{
int flipvar;
for (step = 0; step<max_flips; step++)
{
//find a solution
if(unsat_stack_fill_pointer==0) return;
flipvar = pick_var();
flip(flipvar);
time_stamp[flipvar] = step;
}
}
*/
void local_search(long long no_improv_times)
{
int flipvar;
long long notime = 1 + no_improv_times;
// printf("cur_sol: ");
// for(int i=1; i<=num_vars; i++) {
// printf("%d ", cur_soln[i]);
// }
// printf("\n");
while(--notime)
{
flipvar = pick_var();
flip(flipvar);
time_stamp[flipvar] = step;
step++;
if(unsat_stack_fill_pointer < this_try_best_unsat_stack_fill_pointer)
{
this_try_best_unsat_stack_fill_pointer = unsat_stack_fill_pointer;
notime = 1 + no_improv_times;
}
if(unsat_stack_fill_pointer == 0)
{
return;
}
}
return;
}
void default_settings()
{
seed = 1;
ls_no_improv_times = 200000;
p_scale = 0.3;
q_scale = 0.7;
threshold = 50;
aspiration_active = false; //
}
int CCAnr::module_pick_var() {
return pick_var();
}
void CCAnr::module_flip_var(int flipvar) {
flip(flipvar);
time_stamp[flipvar] = step;
step++;
if(unsat_stack_fill_pointer < this_try_best_unsat_stack_fill_pointer)
{
this_try_best_unsat_stack_fill_pointer = unsat_stack_fill_pointer;
}
if(unsat_stack_fill_pointer == 0)
{
printf("[CCAnr] find solution!\n");
if(verify_sol()!=1) {
cout<<"c Sorry, something is wrong."<<endl;
exit(-1);
}
}
}
int* CCAnr::module_cur_soln() {
return cur_soln;
}
void CCAnr::module_reset() {
settings();
init();
}
void CCAnr::module_init()
{
int seed,i;
int satisfy_flag=0;
struct tms start, stop;
cout<<"c This is CCAnr 2.0 [Version: 2018.01.28] [Author: Shaowei Cai]."<<endl;
times(&start);
default_settings();
build_instance("test.cnf");
srand(seed);
//if(unitclause_queue_end_pointer > 0) preprocess();
build_neighbor_relation();
scale_ave=(threshold+1)*q_scale; //
cout<<"c Instance: Number of variables = "<<num_vars<<endl;
cout<<"c Instance: Number of clauses = "<<num_clauses<<endl;
cout<<"c Instance: Ratio = "<<ratio<<endl;
cout<<"c Instance: Formula length = "<<formula_len<<endl;
cout<<"c Instance: Avg (Min,Max) clause length = "<<avg_clause_len<<" ("<<min_clause_len<<","<<max_clause_len<<")"<<endl;
cout<<"c Algorithmic: Random seed = "<<seed<<endl;
cout<<"c Algorithmic: ls_no_improv_steps = " << ls_no_improv_times << endl;
cout<<"c Algorithmic: swt_p = " << p_scale << endl;
cout<<"c Algorithmic: swt_q = " << q_scale << endl;
cout<<"c Algorithmic: swt_threshold = " << threshold << endl;
cout<<"c Algorithmic: scale_ave = " << scale_ave << endl;
if(aspiration_active) cout<<"c Algorithmic: aspiration_active = true" << endl;
else cout<<"c Algorithmic: aspiration_active = false" << endl;
// for (tries = 0; tries <= max_tries; tries++)
// {
// settings();
// init();
// local_search(ls_no_improv_times);
// if (unsat_stack_fill_pointer==0)
// {
// if(verify_sol()==1) {satisfy_flag = 1; break;}
// else cout<<"c Sorry, something is wrong."<<endl;/////
// }
// }
// times(&stop);
// double comp_time = double(stop.tms_utime - start.tms_utime +stop.tms_stime - start.tms_stime) / sysconf(_SC_CLK_TCK);
// if(satisfy_flag==1)
// {
// cout<<"s SATISFIABLE"<<endl;
// //print_solution();
// }
// else cout<<"s UNKNOWN"<<endl;
// cout<<"c solveSteps = "<<tries<<" tries + "<<step<<" steps (each try has "<<max_flips<<" steps)."<<endl;
// cout<<"c solveTime = "<<comp_time<<endl;
// free_memory();
return;
}

295
CCAnr/cca.h Normal file
View File

@ -0,0 +1,295 @@
/************************************=== CCAnr ===***************************************
** CCAnr is a local search solver for the Boolean Satisfiability (SAT) problem,
** which is especially designed for non-random instances.
** CCAnr is designed and implemented by Shaowei Cai (email: shaoweicai.cs@gmail.com),
*****************************************************************************************/
/*****************************=== Develpment history ===*************************************
** 2011.5
** SWCC (Smoothed Weighting and Configuration Checking) by Shaowei Cai
** New Idea: Configuration Checking (CC)
** A variable is configuration changed, if since its last flip, at least one of its
** neighboring var has been flipped.
** In the greedy mode, Swcc picks the best Configuration Changed Decreasing var to flip.
** In the random mode, it updates weights, and flips the oldest var in a random unsat clause.
** 2011.9
** SWCCA (Smoothed Weighting and Configuration Checking with Aspiration) by Shaowei Cai
** New Idea: CC with Aspiration (CCA)
** Modification: in greedy mode, it first prefers to flip the best CCD var. If there is
** no CCD variable, then flip the best significant decreasing var, i.e., with a great
** positive score (in Swcca, bigger than averaged clause weight), if there exsit such vars.
** 2013.4
** CCAnr (CCA for non-random SAT)
** Modifications: Generalize the smoothig fomula as w(ci)=w(ci)*p+ave_w*q; pick the greediest
** variable in the diversification mode.
************************************************************************************************/
#ifndef _CCA_H_
#define _CCA_H_
#include "basis.h"
#define pop(stack) stack[--stack ## _fill_pointer]
#define push(item, stack) stack[stack ## _fill_pointer++] = item
inline void unsat(int clause)
{
index_in_unsat_stack[clause] = unsat_stack_fill_pointer;
push(clause,unsat_stack);
//update appreance count of each var in unsat clause and update stack of vars in unsat clauses
int v;
for(lit* p=clause_lit[clause]; (v=p->var_num)!=0; p++)
{
unsat_app_count[v]++;
if(unsat_app_count[v]==1)
{
index_in_unsatvar_stack[v] = unsatvar_stack_fill_pointer;
push(v,unsatvar_stack);
}
}
}
inline void sat(int clause)
{
int index,last_unsat_clause;
//since the clause is satisfied, its position can be reused to store the last_unsat_clause
last_unsat_clause = pop(unsat_stack);
index = index_in_unsat_stack[clause];
unsat_stack[index] = last_unsat_clause;
index_in_unsat_stack[last_unsat_clause] = index;
//update appreance count of each var in unsat clause and update stack of vars in unsat clauses
int v,last_unsat_var;
for(lit* p=clause_lit[clause]; (v=p->var_num)!=0; p++)
{
unsat_app_count[v]--;
if(unsat_app_count[v]==0)
{
last_unsat_var = pop(unsatvar_stack);
index = index_in_unsatvar_stack[v];
unsatvar_stack[index] = last_unsat_var;
index_in_unsatvar_stack[last_unsat_var] = index;
}
}
}
//initiation of the algorithm
void init()
{
int v,c;
int i,j;
int clause;
//Initialize edge weights
for (c = 0; c<num_clauses; c++)
clause_weight[c] = 1;
//init unsat_stack
unsat_stack_fill_pointer = 0;
unsatvar_stack_fill_pointer = 0;
//init solution
for (v = 1; v <= num_vars; v++) {
if(fix[v]==0){
if(rand()%2==1) cur_soln[v] = 1;
else cur_soln[v] = 0;
time_stamp[v] = 0;
conf_change[v] = 1;
unsat_app_count[v] = 0;
//pscore[v] = 0;
}
}
/* figure out sat_count, and init unsat_stack */
for (c=0; c<num_clauses; ++c)
{
if(clause_delete[c]==1) continue;
sat_count[c] = 0;
for(j=0; j<clause_lit_count[c]; ++j)
{
if (cur_soln[clause_lit[c][j].var_num] == clause_lit[c][j].sense)
{
sat_count[c]++;
sat_var[c] = clause_lit[c][j].var_num;
}
}
if (sat_count[c] == 0)
unsat(c);
}
/*figure out var score*/
int lit_count;
for (v=1; v<=num_vars; v++)
{
if(fix[v]==1)
{
score[v] = -100000;
continue;
}
score[v] = 0;
lit_count = var_lit_count[v];
for(i=0; i<lit_count; ++i)
{
c = var_lit[v][i].clause_num;
if (sat_count[c]==0) score[v]++;
else if (sat_count[c]==1 && var_lit[v][i].sense==cur_soln[v]) score[v]--;
}
}
/*
int flag;
//compute pscore and record sat_var and sat_var2 for 2sat clauses
for (c=0; c<num_clauses; ++c)
{
if(clause_delete[c]==1) continue;
if (sat_count[c]==1)
{
for(j=0;j<clause_lit_count[c];++j)
{
v=clause_lit[c][j].var_num;
if(v!=sat_var[c])pscore[v]++;
}
}
else if(sat_count[c]==2)
{
flag=0;
for(j=0;j<clause_lit_count[c];++j)
{
v=clause_lit[c][j].var_num;
if(clause_lit[c][j].sense == cur_soln[v])
{
pscore[v]--;
if(flag==0){sat_var[c] = v; flag=1;}
else {sat_var2[c] = v; break;}
}
}
}
}
*/
//init goodvars stack
goodvar_stack_fill_pointer = 0;
for (v=1; v<=num_vars; v++)
{
if(fix[v]==1) continue;
if(score[v]>0)// && conf_change[v]==1)
{
already_in_goodvar_stack[v] = 1;
push(v,goodvar_stack);
}
else already_in_goodvar_stack[v] = 0;
}
//setting for the virtual var 0
time_stamp[0]=0;
//pscore[0]=0;
this_try_best_unsat_stack_fill_pointer = unsat_stack_fill_pointer;
}
void flip(int flipvar)
{
cur_soln[flipvar] = 1 - cur_soln[flipvar];
int i,j;
int v,c;
lit* clause_c;
int org_flipvar_score = score[flipvar];
//update related clauses and neighbor vars
for(lit *q = var_lit[flipvar]; (c=q->clause_num)>=0; q++)
{
clause_c = clause_lit[c];
if(cur_soln[flipvar] == q->sense)
{
++sat_count[c];
if (sat_count[c] == 2) //sat_count from 1 to 2
score[sat_var[c]] += clause_weight[c];
else if (sat_count[c] == 1) // sat_count from 0 to 1
{
sat_var[c] = flipvar;//record the only true lit's var
for(lit* p=clause_c; (v=p->var_num)!=0; p++) score[v] -= clause_weight[c];
sat(c);
}
}
else // cur_soln[flipvar] != cur_lit.sense
{
--sat_count[c];
if (sat_count[c] == 1) //sat_count from 2 to 1
{
for(lit* p=clause_c; (v=p->var_num)!=0; p++)
{
if(p->sense == cur_soln[v] )
{
score[v] -= clause_weight[c];
sat_var[c] = v;
break;
}
}
}
else if (sat_count[c] == 0) //sat_count from 1 to 0
{
for(lit* p=clause_c; (v=p->var_num)!=0; p++) score[v] += clause_weight[c];
unsat(c);
}//end else if
}//end else
}
score[flipvar] = -org_flipvar_score;
/*update CCD */
int index;
conf_change[flipvar] = 0;
//remove the vars no longer goodvar in goodvar stack
for(index=goodvar_stack_fill_pointer-1; index>=0; index--)
{
v = goodvar_stack[index];
if(score[v]<=0)
{
goodvar_stack[index] = pop(goodvar_stack);
already_in_goodvar_stack[v] = 0;
}
}
//update all flipvar's neighbor's conf_change to be 1, add goodvar
int* p;
for(p=var_neighbor[flipvar]; (v=*p)!=0; p++)
{
conf_change[v] = 1;
if(score[v]>0 && already_in_goodvar_stack[v] ==0)
{
push(v,goodvar_stack);
already_in_goodvar_stack[v] = 1;
}
}
}
#endif

9
CCAnr/ccanr.h Normal file
View File

@ -0,0 +1,9 @@
namespace CCAnr {
void module_init();
int module_pick_var();
void module_flip_var(int var);
void module_reset();
int* module_cur_soln();
}

View File

@ -1,594 +0,0 @@
#include "cnc.hpp"
#include "basis.hpp"
#include "indusLS.hpp"
#include <assert.h>
#include <algorithm>
#include <cstdlib>
#include <iostream>
using std::rand;
using std::swap;
using std::cout;
using std::endl;
static inline bool with_prob(double p) {
return (rand() % 10000000) * 0.0000001 < p;
}
static lit org_unitclause_queue[MAX_VARS];
static int org_unitclause_count;
static lit unitclause_queue[MAX_VARS];
static char sense_in_queue[MAX_VARS];
static int unitclause_queue_beg_pointer, unitclause_queue_end_pointer;
static char clause_delete[MAX_CLAUSES];
static int cp_clause_lit_count[MAX_CLAUSES];
static lit clause_xor[MAX_CLAUSES];
static int fix_soln[MAX_VARS];
static int unassigned_var[MAX_VARS];
static int index_in_unassigned_var[MAX_VARS];
static int unassigned_count;
static int clause_delete_count;
static int conflict;
static float prob;
static void (* unit_propagation) ();
static bool (* choose_sense) (int);
double cnc_unit_last;
static long long cnc_slot_age; // reset on the beginning of the slot
static long long cnc_age;
static long long vage[MAX_VARS], vage_pos[MAX_VARS], vage_cnt[MAX_VARS];
static inline void vage_touch(int v, bool sense) {
vage[v] = cnc_age * num_vars + unassigned_count;
vage_pos[v] += sense;
vage_cnt[v]++;
}
struct _canbest_s {
int opt_unsat;
int *soln;
};
static struct _canbest_s *canbest;
static int canbest_cap;
static int canbest_count = 0;
static int canbest_max_opt;
static void canbest_make_space(void) {
if (canbest_count < canbest_cap)
return;
for (int i = canbest_count - 1; i >= 0; --i) {
if (canbest[i].opt_unsat == canbest_max_opt) {
swap(canbest[i], canbest[--canbest_count]);
return;
}
}
assert(0);
}
static void canbest_update_max_opt(void) {
if (canbest_count < canbest_cap) {
canbest_max_opt = num_clauses;
} else {
canbest_max_opt = 0;
for (int i = 0; i < canbest_count; ++i)
if (canbest_max_opt < canbest[i].opt_unsat)
canbest_max_opt = canbest[i].opt_unsat;
}
}
void cnc_init(int cb_cap) {
for (int c = 0; c < num_clauses; ++c)
if (1 == clause_lit_count[c])
org_unitclause_queue[org_unitclause_count++] = clause_lit[c][0];
canbest_cap = cb_cap;
canbest = new _canbest_s[canbest_cap];
for (int i = 0; i < canbest_cap; ++i)
canbest[i].soln = new int[num_vars + 1];
canbest_max_opt = num_clauses;
}
static inline void remove_unassigned_var(int var)
{
int index, last_unassigned_var;
last_unassigned_var = unassigned_var[--unassigned_count];
index = index_in_unassigned_var[var];
unassigned_var[index] = last_unassigned_var;
index_in_unassigned_var[last_unassigned_var]=index;
}
static void assign(int var, bool sense)
{
assert(var > 0 && var <= num_vars);
assert(1 == sense || 0 == sense);
int c;
int i;
lit cur;
vage_touch(var, sense);
fix_soln[var] = sense;
remove_unassigned_var(var);
for(i = 0; i<var_lit_count[var]; ++i)
{
cur = var_lit[var][i];
c = cur.clause_num;
if(clause_delete[c]==1) continue;
if(cur.sense == sense)//then remove the clause from the formula (by marking it as deleted).
{
clause_delete[c]=1; clause_delete_count++;
}
else
{
if (cp_clause_lit_count[c]==1)//then it becomes an empty clause
{
clause_delete[c]=1;
clause_delete_count++;
conflict++;
cp_clause_lit_count[c]=0;
}
else
{
--cp_clause_lit_count[c];
clause_xor[c] ^= cur;
if (cp_clause_lit_count[c]==1)//newly generated unit clause
{
lit tmplit = clause_xor[c];
/*
{ // Check if clause_xor is point to the only unit literal
bool found = false;
for(int j=0; j<clause_lit_count[c]; ++j) {
// if fix_soln[v]==-2, v must be in unit queue
// we won't reach here if the unit clause is being assigning
if(fix_soln[clause_lit[c][j].var_num] < 0) {
if (found || clause_xor[c] != clause_lit[c][j]) {
cout << "error: xor value is invalid" << endl;
abort();
}
found = true;
}
}
if (!found) {
cout << "error: xor value is point to unknown literal" << endl;
abort();
}
}
*/
int tmpvar=tmplit.var_num;
if (sense_in_queue[tmpvar] == -1)
{
unitclause_queue[unitclause_queue_end_pointer++] = tmplit;
sense_in_queue[tmpvar] = tmplit.sense;
}
else
{
if (sense_in_queue[tmpvar]!=tmplit.sense)
{
fix_soln[tmpvar]=-2;//mark this var as a conflicting var
//clause_delete[c]=1; clause_delete_count++;
}
}
}
}
}
}
}
void unit_propagation_order()
{
lit uc_lit;
int uc_var;
bool uc_sense;
//while (unitclause_queue_beg_pointer < unitclause_queue_end_pointer)
//{
uc_lit = unitclause_queue[unitclause_queue_beg_pointer++];
uc_var = uc_lit.var_num;
uc_sense = uc_lit.sense;
if(fix_soln[uc_var]==0 || fix_soln[uc_var]==1) return;
if (fix_soln[uc_var]==-2) {
choose_sense(uc_var);
}
assign(uc_var, uc_sense);
//}
}
void unit_propagation_random()
{
lit uc_lit;
int uc_var;
bool uc_sense;
int index;
//while (unitclause_queue_beg_pointer < unitclause_queue_end_pointer)
//{
if(unitclause_queue_end_pointer==unitclause_queue_beg_pointer+1)
{
uc_lit = unitclause_queue[--unitclause_queue_end_pointer];
}
else{
//index = unitclause_queue_beg_pointer+rand()%(unitclause_queue_end_pointer-unitclause_queue_beg_pointer);
index = rand()%unitclause_queue_end_pointer;
uc_lit = unitclause_queue[index];
unitclause_queue[index] = unitclause_queue[--unitclause_queue_end_pointer];
}
//uc_lit = unitclause_queue[unitclause_queue_beg_pointer++];
uc_var = uc_lit.var_num;
uc_sense = uc_lit.sense;
if(fix_soln[uc_var]==0 || fix_soln[uc_var]==1) return;
if (fix_soln[uc_var]==-2) {
uc_sense = choose_sense(uc_var);
}
assign(uc_var, uc_sense);
//}
}
void unit_propagation_vers_order()
{
lit uc_lit;
int uc_var;
bool uc_sense;
//while (unitclause_queue_beg_pointer < unitclause_queue_end_pointer)
//{
uc_lit = unitclause_queue[--unitclause_queue_end_pointer];
uc_var = uc_lit.var_num;
uc_sense = uc_lit.sense;
if(fix_soln[uc_var]==0 || fix_soln[uc_var]==1) return;
if (fix_soln[uc_var]==-2) {
choose_sense(uc_var);
}
assign(uc_var, uc_sense);
//}
}
bool choose_greedy_sense0(int var)
{
if(score1[var]>score0[var]) return 1;
else if(score0[var]>score1[var]) return 0;
else return rand()%2;
}
//greedy
bool choose_greedy_sense(int var)
{
int i,c;
lit cur;
int count1=0, count0=0;
for(i = 0; i<var_lit_count[var]; ++i)
{
cur = var_lit[var][i];
c = cur.clause_num;
if(clause_delete[c]==1) continue;
if(cur.sense == 1)
count1++;
else
count0++;
}
if(count1>count0) return 1;
else if(count1<count0) return 0;
else return rand()%2;
}
//weighted greedy
bool choose_greedy_sense2(int var)
{
int i,c;
lit cur;
int count1=0, count0=0;
int large_number=100;
for(i = 0; i<var_lit_count[var]; ++i)
{
cur = var_lit[var][i];
c = cur.clause_num;
if(clause_delete[c]==1) continue;
if(cur.sense == 1)
count1 += large_number/cp_clause_lit_count[c];
//count1++;
else
count0 += large_number/cp_clause_lit_count[c];
//count0++;
}
if(count1>count0) return 1;
else if(count1<count0) return 0;
else return rand()%2;
}
//random
bool choose_random_sense(int var)
{
(void) var;
return rand()%2;
}
bool choose_sense_prob0(int var)
{
if (with_prob(prob))
return choose_random_sense(var);
else return choose_greedy_sense0(var);
}
bool choose_sense_prob(int var)
{
if (with_prob(prob))
return choose_random_sense(var);
else return choose_greedy_sense(var);
}
bool choose_sense_prob2(int var)
{
if (with_prob(prob))
return choose_random_sense(var);
else return choose_greedy_sense2(var);
}
int vage_window;
void unit_propagation_age()
{
lit uc_lit;
int uc_var;
bool uc_sense;
// don't go through all var in queue, its too slow.
const int unitlen = unitclause_queue_end_pointer - unitclause_queue_beg_pointer;
int besti = (rand() % unitlen) + unitclause_queue_beg_pointer;
for (int j = 0; j < vage_window; j++) {
int i = (rand() % unitlen) + unitclause_queue_beg_pointer;
if (vage[unitclause_queue[i].var_num] < vage[unitclause_queue[besti].var_num]) {
besti = i;
}
}
uc_lit = unitclause_queue[besti];
uc_var = uc_lit.var_num;
uc_sense = uc_lit.sense;
unitclause_queue[besti] = unitclause_queue[--unitclause_queue_end_pointer];
if(fix_soln[uc_var]==0 || fix_soln[uc_var]==1) return;
if (fix_soln[uc_var]==-2) {
uc_sense = choose_sense(uc_var);
}
assign(uc_var, uc_sense);
}
double lb_last_prob;
static bool choose_sense_lb(int var) {
if (with_prob(lb_last_prob))
return lb_get_last(var);
else
return lb_get_prob(var);
}
static void set_functions(void)
{
// int rand_res = rand() % 3;
// if (0 == rand_res) unit_propagation = unit_propagation_order; //ord
// else if (1 == rand_res) unit_propagation = unit_propagation_vers_order;//ver
// else unit_propagation = unit_propagation_random;//random
// Rand can take 1% lower wrong ratio than others
//unit_propagation = unit_propagation_order;
//unit_propagation = unit_propagation_vers_order;
//unit_propagation = unit_propagation_random;
unit_propagation = unit_propagation_age;
//choose_sense = choose_greedy_sense;
//choose_sense = choose_greedy_sense2;
//choose_sense = choose_random_sense;
choose_sense = choose_sense_lb;
}
static void cnc_process_one(void)
{
int as_var;
bool as_sense;
int c,v,i;
++cnc_slot_age;
++cnc_age;
set_functions();
for (i=0; i<num_vars; ++i)
{
v=i+1;
unassigned_var[i]=v;
index_in_unassigned_var[v]=i;
fix_soln[v]=-1;
sense_in_queue[v]=-1;
}
unassigned_count = num_vars;
for (c = 0; c < num_clauses; c++)
{
cp_clause_lit_count[c] = clause_lit_count[c];
clause_delete[c]=0;
clause_xor[c] = clause_xor_org[c];
}
clause_delete_count=0;
conflict=0;
unitclause_queue_beg_pointer=0;
unitclause_queue_end_pointer=0;
for(i = 0; i<org_unitclause_count; ++i)
{
lit tmplit = org_unitclause_queue[i];
int tmpvar = tmplit.var_num;
if (sense_in_queue[tmpvar] == -1)
{
sense_in_queue[tmpvar] = tmplit.sense;
unitclause_queue[unitclause_queue_end_pointer++] = tmplit;
}
else
{
if (sense_in_queue[tmpvar]!=tmplit.sense)
fix_soln[tmpvar]=-2;//mark this var as conflicting
}
}
/*
if (tries > 1 && with_prob(cnc_unit_last)) {
int var;
for (int i = 0; i < unitclause_queue_end_pointer; ++i) {
if (unitclause_queue[i].sense != lb_get_last(unitclause_queue[i].var_num)) {
unitclause_queue[i].sense = 1 - unitclause_queue[i].sense;
var = unitclause_queue[i].var_num;
sense_in_queue[var] = unitclause_queue[i].sense;
assert(unitclause_queue[i].sense == lb_get_last(unitclause_queue[i].var_num));
}
}
}
*/
while (unassigned_count>0)
{
if (clause_delete_count==num_clauses)
{
for (int i=0; i<unassigned_count; ++i)
fix_soln[unassigned_var[i]]=rand()%2;
unassigned_count=0;
break;
}
if (unitclause_queue_beg_pointer < unitclause_queue_end_pointer)
{
unit_propagation();
}
else {
as_var = unassigned_var[rand()%unassigned_count];
as_sense = choose_sense(as_var);
assign(as_var, as_sense);
}
if (conflict >= canbest_max_opt) break;
}
if (conflict < canbest_max_opt) {
if (the_best.opt_try != tries && conflict < the_best.opt_unsat) {
// Best solution has been searched by LS, or init
update_best_soln(conflict, fix_soln, 1);
//cout << "c CNC_UPDATE_AT\t" << cnc_slot_age << "\t" << cnc_age << "\t" << tries << endl;
} else if (the_best.opt_try == tries && conflict < the_best.opt_unsat) {
// We have updated the best soln in this time slot
// We found a better soln than the_best, and this the_best has not been searched by LS.
// So move the_best to canbest, and update the_best by this new soln
canbest_make_space();
swap(the_best.soln, canbest[canbest_count].soln);
canbest[canbest_count].opt_unsat = the_best.opt_unsat;
canbest_count++;
update_best_soln(conflict, fix_soln, 1);
//cout << "c CNC_UPDATE_AT\t" << cnc_slot_age << "\t" << cnc_age << "\t" << tries << endl;
} else {
canbest_make_space();
canbest[canbest_count].opt_unsat = conflict;
for (int v = 1; v <= num_vars; ++v)
canbest[canbest_count].soln[v] = fix_soln[v];
canbest_count++;
}
canbest_update_max_opt();
}
}
bool cnc_get_canbest(const int* &soln, int &opt) {
if (0 == canbest_count)
return false;
opt = canbest[0].opt_unsat;
int pos = 0;
for (int i = 1; i < canbest_count; ++i) {
if (opt > canbest[i].opt_unsat) {
opt = canbest[i].opt_unsat;
pos = i;
}
}
soln = canbest[pos].soln;
swap(canbest[pos], canbest[--canbest_count]);
canbest_update_max_opt();
return true;
}
void cnc_process(long long step_num) {
cnc_slot_age = 0;
++step_num;
while (--step_num) {
cnc_process_one();
}
}

View File

@ -1,13 +0,0 @@
#ifndef _CNC_H_
#define _CNC_H_
extern double cnc_unit_last;
extern double lb_last_prob;
extern double refer_gbest_prob;
extern int vage_window;
void cnc_init(int cb_cap);
void cnc_process(const long long step_num);
bool cnc_get_canbest(const int* &soln, int &opt);
#endif

103
CCAnr/cw.h Normal file
View File

@ -0,0 +1,103 @@
#ifndef _CW_H_
#define _CW_H_
#include "basis.h"
#define sigscore ave_weight //significant score needed for aspiration
int ave_weight=1;
int delta_total_weight=0;
/**************************************** clause weighting for 3sat **************************************************/
int threshold;
float p_scale;//w=w*p+ave_w*q
float q_scale=0;
int scale_ave;//scale_ave==ave_weight*q_scale
int q_init=0;
void smooth_clause_weights()
{
int i,j,c,v;
int new_total_weight=0;
for (v=1; v<=num_vars; ++v)
score[v] = 0;
//smooth clause score and update score of variables
for (c = 0; c<num_clauses; ++c)
{
clause_weight[c] = clause_weight[c]*p_scale+scale_ave;
if(clause_weight[c]<1) clause_weight[c] = 1;
new_total_weight+=clause_weight[c];
//update score of variables in this clause
if (sat_count[c]==0)
{
for(j=0; j<clause_lit_count[c]; ++j)
{
score[clause_lit[c][j].var_num] += clause_weight[c];
}
}
else if(sat_count[c]==1)
score[sat_var[c]]-=clause_weight[c];
}
ave_weight=new_total_weight/num_clauses;
}
void update_clause_weights()
{
int i,v;
for(i=0; i < unsat_stack_fill_pointer; ++i)
clause_weight[unsat_stack[i]]++;
for(i=0; i<unsatvar_stack_fill_pointer; ++i)
{
v = unsatvar_stack[i];
score[v] += unsat_app_count[v];
if(score[v]>0 && conf_change[v]==1 && already_in_goodvar_stack[v] ==0)
{
push(v,goodvar_stack);
already_in_goodvar_stack[v] =1;
}
}
delta_total_weight+=unsat_stack_fill_pointer;
if(delta_total_weight>=num_clauses)
{
ave_weight+=1;
delta_total_weight -= num_clauses;
//smooth weights
if(ave_weight>threshold)
smooth_clause_weights();
}
}
void set_clause_weighting()
{
threshold=300;
p_scale=0.3;
if(q_init==0)
{
if(ratio<=15) q_scale=0;
else q_scale=0.7;
}
else
{
if(q_scale<0.5) //0
q_scale = 0.7;
else
q_scale = 0;
}
scale_ave=(threshold+1)*q_scale;
q_init = 1;
}
#endif

View File

@ -1,676 +0,0 @@
#include "basis.hpp"
#include <cerrno>
#include <cstdlib>
#include <iostream>
#include <assert.h>
using namespace std;
#define pop(stack) stack[--stack ## _fill_pointer]
#define push(item, stack) stack[stack ## _fill_pointer++] = item
#define sigscore ave_weight //significant score needed for aspiration
/* Information about the variables. */
static int score[MAX_VARS];
static int conf_change[MAX_VARS];
static long long time_stamp[MAX_VARS];
static int* var_neighbor[MAX_VARS];
/* Information about the clauses */
static int clause_weight[MAX_CLAUSES];
static int sat_count[MAX_CLAUSES];
static int sat_var[MAX_CLAUSES];
//unsat clauses stack
static int unsat_stack[MAX_CLAUSES]; //store the unsat clause number
static int unsat_stack_fill_pointer; // NEED TO UPDATE IN RESTART PROCEDURE
static int index_in_unsat_stack[MAX_CLAUSES];//which position is a clause in the unsat_stack
//variables in unsat clauses
static int unsatvar_stack[MAX_VARS];
static int unsatvar_stack_fill_pointer; // NEED TO UPDATE IN RESTART PROCEDURE
static int index_in_unsatvar_stack[MAX_VARS];
static int unsat_app_count[MAX_VARS]; //a varible appears in how many unsat clauses
//configuration changed decreasing variables (score>0 and confchange=1)
static int goodvar_stack[MAX_VARS];
static int goodvar_stack_fill_pointer; // NEED TO UPDATE IN RESTART PROCEDURE
static int already_in_goodvar_stack[MAX_VARS];
/* Information about solution */
static int cur_soln[MAX_VARS]; //the current solution, with 1's for True variables, and 0's for False variables
//cutoff
static long long step; // LS私有step每次init之后置为零
int balancePar;
bool aspiration_active;
// local search local best
// which is the best soln in this time slot
static int lb_soln[MAX_VARS];
static int lb_opt;
static void lb_copy(void) {
for (int v = 1; v <= num_vars; v++)
lb_soln[v] = cur_soln[v];
}
static int lb_pos[MAX_VARS], lb_neg[MAX_VARS];
static void lb_update(int mut) {
for (int v = 1; v <= num_vars; v++) {
assert(0 == lb_soln[v] || 1 == lb_soln[v]);
lb_pos[v] += lb_soln[v] * mut;
lb_neg[v] += !lb_soln[v] * mut;
}
}
bool lb_get_prob(int v) {
int sum = lb_pos[v] + lb_neg[v];
if (0 == sum) {
//return lb_soln[v];
return rand() & 1;
} else {
return (rand() % sum) < lb_pos[v];
}
}
bool lb_get_last(int v) {
if (lb_neg[v] + lb_pos[v])
return lb_soln[v];
else
return rand() & 1;
}
void build_neighbor_relation(void)
{
int *neighbor_flag = new int[MAX_VARS];
int *temp_neighbor = new int[MAX_VARS];
int temp_neighbor_count;
int i,j,count;
int v,c,n;
for(v=1; v<=num_vars; ++v)
{
//if(fix[v]==1) continue;
neighbor_flag[v] = 1;
temp_neighbor_count = 0;
for(i=0; i<var_lit_count[v]; ++i)
{
c = var_lit[v][i].clause_num;
//if(clause_delete[c]==1) continue;
for(j=0; j<clause_lit_count[c]; ++j)
{
n=clause_lit[c][j].var_num;
if(neighbor_flag[n]!=1)
{
neighbor_flag[n] = 1;
temp_neighbor[temp_neighbor_count++] = n;
}
}
}
neighbor_flag[v] = 0;
var_neighbor[v] = new int[temp_neighbor_count+1];
count = 0;
for(i=0; i<temp_neighbor_count; i++)
{
var_neighbor[v][count++] = temp_neighbor[i];
neighbor_flag[temp_neighbor[i]] = 0;
}
var_neighbor[v][count]=0;
}
delete [] neighbor_flag;
delete [] temp_neighbor;
}
static inline void ls_update_best_soln(void) {
update_best_soln(unsat_stack_fill_pointer, cur_soln, 2);
//cout << "c LS_UPDATE_AT\t" << step << "\t" << tries << endl;
}
static inline void unsat(int clause)
{
index_in_unsat_stack[clause] = unsat_stack_fill_pointer;
push(clause,unsat_stack);
//update appreance count of each var in unsat clause and update stack of vars in unsat clauses
int v;
for(lit* p=clause_lit[clause]; (v=p->var_num)!=0; p++)
{
unsat_app_count[v]++;
if(unsat_app_count[v]==1)
{
index_in_unsatvar_stack[v] = unsatvar_stack_fill_pointer;
push(v,unsatvar_stack);
}
}
}
static inline void sat(int clause)
{
int index,last_unsat_clause;
//since the clause is satisfied, its position can be reused to store the last_unsat_clause
last_unsat_clause = pop(unsat_stack);
index = index_in_unsat_stack[clause];
unsat_stack[index] = last_unsat_clause;
index_in_unsat_stack[last_unsat_clause] = index;
//update appreance count of each var in unsat clause and update stack of vars in unsat clauses
int v,last_unsat_var;
for(lit* p=clause_lit[clause]; (v=p->var_num)!=0; p++)
{
unsat_app_count[v]--;
if(unsat_app_count[v]==0)
{
last_unsat_var = pop(unsatvar_stack);
index = index_in_unsatvar_stack[v];
unsatvar_stack[index] = last_unsat_var;
index_in_unsatvar_stack[last_unsat_var] = index;
}
}
}
static void flip(int flipvar)
{
cur_soln[flipvar] = 1 - cur_soln[flipvar];
int v,c;
lit* clause_c;
int org_flipvar_score = score[flipvar];
//update related clauses and neighbor vars
for(lit *q = var_lit[flipvar]; (c=q->clause_num)>=0; q++)
{
clause_c = clause_lit[c];
if(cur_soln[flipvar] == q->sense)
{
++sat_count[c];
if (sat_count[c] == 2) //sat_count from 1 to 2
score[sat_var[c]] += clause_weight[c];
else if (sat_count[c] == 1) // sat_count from 0 to 1
{
sat_var[c] = flipvar;//record the only true lit's var
for(lit* p=clause_c; (v=p->var_num)!=0; p++) score[v] -= clause_weight[c];
sat(c);
}
}
else // cur_soln[flipvar] != cur_lit.sense
{
--sat_count[c];
if (sat_count[c] == 1) //sat_count from 2 to 1
{
for(lit* p=clause_c; (v=p->var_num)!=0; p++)
{
if(p->sense == cur_soln[v] )
{
score[v] -= clause_weight[c];
sat_var[c] = v;
break;
}
}
}
else if (sat_count[c] == 0) //sat_count from 1 to 0
{
for(lit* p=clause_c; (v=p->var_num)!=0; p++) score[v] += clause_weight[c];
unsat(c);
}//end else if
}//end else
}
score[flipvar] = -org_flipvar_score;
/*update CCD */
int index;
conf_change[flipvar] = 0;
//remove the vars no longer goodvar in goodvar stack
for(index=goodvar_stack_fill_pointer-1; index>=0; index--)
{
v = goodvar_stack[index];
if(score[v]<=0)
{
goodvar_stack[index] = pop(goodvar_stack);
already_in_goodvar_stack[v] = 0;
}
}
//update all flipvar's neighbor's conf_change to be 1, add goodvar
int* p;
for(p=var_neighbor[flipvar]; (v=*p)!=0; p++)
{
conf_change[v] = 1;
if(score[v]>0 && already_in_goodvar_stack[v] ==0)
{
push(v,goodvar_stack);
already_in_goodvar_stack[v] = 1;
}
}
}
/*************weighting ************************************************/
// swt
static int ave_weight=1;
static int delta_total_weight=0;
int threshold;
float p_scale;//w=w*p+ave_w*q
float q_scale;
int scale_ave;//scale_ave==ave_weight*q_scale
static void smooth_clause_weights_swt(void)
{
int j,c,v;
int new_total_weight=0;
for (v=1; v<=num_vars; ++v)
score[v] = 0;
//smooth clause score and update score of variables
for (c = 0; c<num_clauses; ++c)
{
clause_weight[c] = clause_weight[c]*p_scale+scale_ave;
if(clause_weight[c]<1) clause_weight[c] = 1;
new_total_weight+=clause_weight[c];
//update score of variables in this clause
if (sat_count[c]==0)
{
for(j=0; j<clause_lit_count[c]; ++j)
{
score[clause_lit[c][j].var_num] += clause_weight[c];
}
}
else if(sat_count[c]==1)
score[sat_var[c]]-=clause_weight[c];
}
goodvar_stack_fill_pointer = 0;
for (v = 1; v <= num_vars; v++) {
if(score[v]>0 && conf_change[v]==1) {
already_in_goodvar_stack[v] = 1;
push(v,goodvar_stack);
} else {
already_in_goodvar_stack[v] = 0;
}
}
ave_weight=new_total_weight/num_clauses;
}
static void weighting_swt(void)
{
int i,v;
for(i=0; i < unsat_stack_fill_pointer; ++i)
clause_weight[unsat_stack[i]]++;
for(i=0; i<unsatvar_stack_fill_pointer; ++i)
{
v = unsatvar_stack[i];
score[v] += unsat_app_count[v];
//if(score[v]>0 && conf_change[v]==1 && already_in_goodvar_stack[v] ==0)
if(score[v]>0 && already_in_goodvar_stack[v] ==0)
{
push(v,goodvar_stack);
already_in_goodvar_stack[v] =1;
}
}
delta_total_weight+=unsat_stack_fill_pointer;
if(delta_total_weight>=num_clauses)
{
ave_weight+=1;
delta_total_weight -= num_clauses;
//smooth weights
if(ave_weight>threshold)
smooth_clause_weights_swt();
}
}
/**********************************PAWS weighting*************************************************/
const int dec_weight =1;
const float MY_RAND_MAX_FLOAT = 10000000.0;
const int MY_RAND_MAX_INT = 10000000;
const float BASIC_SCALE = 0.0000001; //1.0f/MY_RAND_MAX_FLOAT;
float smooth_probability;
int large_clause_count_threshold;
//for PAWS (for large ksat)
int large_weight_clauses[MAX_CLAUSES];
int large_weight_clauses_count=0;
void inc_clause_weights_paws()
{
int i, j, c, v;
for(i=0; i < unsat_stack_fill_pointer; ++i)
{
c = unsat_stack[i];
clause_weight[c]++;
if(clause_weight[c] == 2)
{
large_weight_clauses[large_weight_clauses_count++] = c;
}
}
for(i=0; i<unsatvar_stack_fill_pointer; ++i)
{
v = unsatvar_stack[i];
score[v] += unsat_app_count[v];
if(score[v]>0 && conf_change[v]>0 && already_in_goodvar_stack[v] ==0)//
{
push(v,goodvar_stack);
already_in_goodvar_stack[v] =1;
}
}
}
void smooth_clause_weights_paws()
{
int i, j,clause, var;
for(i=0; i<large_weight_clauses_count; i++)
{
clause = large_weight_clauses[i];
if(sat_count[clause]>0)
{
clause_weight[clause]-=dec_weight;
if(clause_weight[clause]==1)
{
large_weight_clauses[i] = large_weight_clauses[--large_weight_clauses_count];
i--;
}
if(sat_count[clause] == 1)
{
var = sat_var[clause];
score[var]+=dec_weight;
if(score[var]>0 && conf_change[var]>0 && already_in_goodvar_stack[var]==0)
{
push(var,goodvar_stack);
already_in_goodvar_stack[var]=1;
}
}
}
}
}
void weighting_paws()
{
if( ((rand()%MY_RAND_MAX_INT)*BASIC_SCALE)<smooth_probability && large_weight_clauses_count>large_clause_count_threshold )
smooth_clause_weights_paws();
else
inc_clause_weights_paws();
}
/**************************setting clause weighting scheme***********************/
void (* update_clause_weights)();
void default_clause_weighting(int weighting_type)
{
if(weighting_type==1)
{
//swt
update_clause_weights = weighting_swt;
threshold=50;//560; // 500
p_scale=0.3;//0.52;
q_scale=0.7;//0.42;
scale_ave=(threshold+1)*q_scale;
}
else
{
//paws
update_clause_weights = weighting_paws;
smooth_probability = 0.1;
large_clause_count_threshold = 10;//do we need this parameter?
}
}
/********************************************end weighting************************************/
static int pick_var(void)
{
int i,k,c,v;
int best_var;
lit* clause_c;
/**Greedy Mode**/
/*CCD (configuration changed decreasing) mode, the level with configuation chekcing*/
if(goodvar_stack_fill_pointer>0)
{
//if(goodvar_stack_fill_pointer<balancePar)
//{
best_var = goodvar_stack[0];
for(i=1; i<goodvar_stack_fill_pointer; ++i)
{
v=goodvar_stack[i];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var])
{
//if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
if(time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
//}
/*else
{
best_var = goodvar_stack[rand()%goodvar_stack_fill_pointer];
for(int j=1;j<balancePar;++j)
{
v = goodvar_stack[rand()%goodvar_stack_fill_pointer];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var])
{
//if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
if(time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
}*/
}
/*aspiration*/
if (aspiration_active)
{
best_var = 0;
for(i=0; i<unsatvar_stack_fill_pointer; ++i)
{
if(score[unsatvar_stack[i]]>ave_weight)
{
best_var = unsatvar_stack[i];
break;
}
}
for(++i; i<unsatvar_stack_fill_pointer; ++i)
{
v=unsatvar_stack[i];
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var] && time_stamp[v]<time_stamp[best_var]) best_var = v;
}
if(best_var!=0) return best_var;
}
/*****end aspiration*******************/
update_clause_weights();
/*focused random walk*/
c = unsat_stack[rand()%unsat_stack_fill_pointer];
clause_c = clause_lit[c];
best_var = clause_c[0].var_num;
for(k=1; k<clause_lit_count[c]; ++k)
{
v=clause_c[k].var_num;
//using score
//if(score[v]>score[best_var]) best_var = v;
//else if(score[v]==score[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
//using unweighted make
if(unsat_app_count[v]>unsat_app_count[best_var]) best_var = v;
//else if(unsat_app_count[v]==unsat_app_count[best_var] && time_stamp[v]<time_stamp[best_var]) best_var = v;
else if(unsat_app_count[v]==unsat_app_count[best_var])
{
if(score[v]>score[best_var]) best_var = v;
else if(score[v]==score[best_var]&&time_stamp[v]<time_stamp[best_var]) best_var = v;
}
}
return best_var;
}
//set functions in the algorithm
void ls_init(void) {
build_neighbor_relation();
}
void ls_restart(const int *soln, const int opt) {
int v, c, i;
for (c = 0; c<num_clauses; c++)
clause_weight[c] = 1;
for (v = 1; v <= num_vars; ++v) {
assert(0 == soln[v] || 1 == soln[v]);
cur_soln[v] = soln[v];
}
unsat_stack_fill_pointer = 0;
unsatvar_stack_fill_pointer = 0;
step = 0;
for (v = 1; v <= num_vars; v++) {
time_stamp[v] = 0;
conf_change[v] = 1;
unsat_app_count[v] = 0;
}
/* figure out sat_count, and init unsat_stack */
for (c = 0; c < num_clauses; ++c) {
sat_count[c] = 0;
for(i = 0; i < clause_lit_count[c]; ++i) {
if (cur_soln[clause_lit[c][i].var_num] == clause_lit[c][i].sense) {
sat_count[c]++;
sat_var[c] = clause_lit[c][i].var_num;
}
}
if (sat_count[c] == 0)
unsat(c);
}
/*figure out var score*/
int lit_count;
for (v = 1; v <= num_vars; v++) {
score[v] = 0;
lit_count = var_lit_count[v];
for(i = 0; i < lit_count; ++i) {
c = var_lit[v][i].clause_num;
if (sat_count[c] == 0)
score[v]++;
else if (sat_count[c] == 1 && var_lit[v][i].sense == cur_soln[v])
score[v]--;
}
}
//init goodvars stack
goodvar_stack_fill_pointer = 0;
for (v = 1; v <= num_vars; v++) {
if(score[v]>0) {
already_in_goodvar_stack[v] = 1;
push(v,goodvar_stack);
} else {
already_in_goodvar_stack[v] = 0;
}
}
//setting for the virtual var 0
time_stamp[0] = 0;
lb_opt = opt;
lb_copy();
}
int lb_update_reduce;
void ls_process(long long no_improv_times) {
int flipvar;
long long notime = 1 + no_improv_times;
while (--notime) {
step++;
flipvar = pick_var();
flip(flipvar);
time_stamp[flipvar] = step;
if (unsat_stack_fill_pointer < lb_opt) {
lb_opt = unsat_stack_fill_pointer;
lb_copy();
notime = 1 + no_improv_times;
}
if (unsat_stack_fill_pointer < the_best.opt_unsat) {
update_best_value(unsat_stack_fill_pointer);
lb_update(tries);
if(the_best.opt_unsat==0) {
ls_update_best_soln();
return;
}
}
if (get_runtime() >= cutoff_time) {
return;
}
}
int b = tries / lb_update_reduce;
if (0 == b)
b = 1;
lb_update(b);
}

View File

@ -1,21 +0,0 @@
#ifndef _INDUSLS_HPP_
#define _INDUSLS_HPP_
extern int balancePar;
extern int lb_update_reduce;
extern bool aspiration_active;
extern int threshold;
extern float p_scale;//w=w*p+ave_w*q
extern float q_scale;
void ls_init(void);
void ls_process(long long no_improv_times);
void ls_restart(const int *soln, const int opt);
void default_clause_weighting(int weighting_type);
bool lb_get_prob(int v);
bool lb_get_last(int v);
#endif

View File

@ -1,48 +0,0 @@
MiniSat -- Copyright (c) 2003-2006, Niklas Een, Niklas Sorensson
Copyright (c) 2007-2010 Niklas Sorensson
Glucose -- Copyright (c) 2009-2012, Gilles Audemard, Laurent Simon
Coprocessor -- Copyright (c) 2012-2014, Norbert Manthey
CCAnr+cnc -- Copyright (c) 2021, Shaowei Cai, Chuan Luo
Permission is hereby granted, free of charge, to use this software for
evaluation and research purposes.
The permission to use the code of Coprocessor within the submission
of the solver CPSparrow version sc14 for the SAT Competition 2014
has been granted.
This license does not allow this software to be used in a commercial context.
It is further prohibited to use this software or a substantial portion of it
in a competition or a similar competetive event, such as the SAT, SMT or QBF,
MaxSAT or HWMCC competitions or evaluations, without explicit written
permission by the copyright holder.
However, competition organizers are allowed to use this software as part of
the evaluation process of a particular competition, evaluation or
competetive event, if the copyright holder of this software submitted this
software to this particular competition, evaluation or event explicitly.
This permission of using the software as part of a submission by the
copyright holder to a competition, evaluation or competive event is only
granted for one year and only for one particular instance of the competition
to which this software was submitted by the copyright holder.
If a competition, evaluation or competetive event has multiple tracks,
categories or sub-competitions, this license is only granted for the tracks
respectively categories or sub-competitions, to which the software was
explicitly submitted by the copyright holder.
All other usage is reserved.
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
IN THE SOFTWARE.

View File

@ -1,274 +0,0 @@
#include "basis.hpp"
#include "cnc.hpp"
#include "indusLS.hpp"
#include <sstream>
#include <cstdlib>
#include <iostream>
#include <stdio.h>
#include<string.h>
#include "indusLS.hpp"
using namespace std;
static void doLS_dynamic(void);
static void doLS_static(void);
char * inst;
int seed;
static int cnc_times, ls_no_improv_times;
static int cb_cap;
static void (*doLS) (void);
int weighting_type;
static void default_settings(void) {
ios::sync_with_stdio(false);
cnc_times = 5;
ls_no_improv_times = 50000000;
doLS = doLS_dynamic;
cb_cap = 50;
balancePar = 40;// no use;
lb_last_prob = 1;
lb_update_reduce = 1;
vage_window = 10;
aspiration_active = false;
weighting_type = 1; //1->SWT; 2->PAWS
default_clause_weighting(weighting_type);
seed = 1;
cutoff_time = 3600;
}
static void doLsRestartToCanBest(void) {
const int *soln;
int opt;
if (cnc_get_canbest(soln, opt)) {
//cout << "c LS force restart to opt=" << opt << " at " << get_runtime() << endl;
ls_restart(soln, opt);
}
}
static void doLsRestartToBest(void) {
ls_restart(the_best.soln, the_best.opt_unsat);
}
static void doCNC(void) {
cnc_process(cnc_times);
//if (the_best.opt_try == tries)
// cout << "c CNC update: " << the_best.opt_unsat << " at " << the_best.opt_time << endl;
}
int max_no_improv_times=20000000;
static void doLS_dynamic(void) {
if (ls_no_improv_times*tries<max_no_improv_times)
ls_process(ls_no_improv_times*tries);
else
ls_process(max_no_improv_times);
}
static void doLS_static(void) {
ls_process(ls_no_improv_times);
}
/*
* About shouldPrint:
*
* At the beginning, shouldPrint = false. o line is printed immediately by update_best_soln() in basis.cpp, while v line is not printed.
* When there's 90s left, shouldPrint = true. o line will not be printed in update_best_soln(). These lines should be printed by main().
* The reason is that, v line takes too much time. If doLS() updates solution too frequently, doLS() may take so much time on printing and left an incomplete v line.
*
* In conclusion, v line has to be printed by main() in any situation, and o line will be printed immediately in first 210s by update_best_soln().
* In last 90s, update_best_soln() does not print o line, and which should be printed by main().
* */
bool parse_arguments(int argc, char ** argv)
{
bool flag_inst = false;
default_settings();
for (int i=1; i<argc; i++)
{
if(strcmp(argv[i],"-inst")==0)
{
i++;
if(i>=argc) return false;
inst = argv[i];
flag_inst = true;
continue;
}
else if(strcmp(argv[i],"-seed")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%d", &seed);
continue;
}
else if(strcmp(argv[i],"-cutoff_time")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%d", &cutoff_time);
continue;
}
else if(strcmp(argv[i],"-aspiration")==0)
{
i++;
if(i>=argc) return false;
int tmp;
sscanf(argv[i], "%d", &tmp);
if (tmp==1)
aspiration_active = true;
else aspiration_active = false;
continue;
}
else if(strcmp(argv[i],"-swt_threshold")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%d", &threshold);
continue;
}
else if(strcmp(argv[i],"-swt_p")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%f", &p_scale);
continue;
}
else if(strcmp(argv[i],"-swt_q")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%f", &q_scale);
continue;
}
else if(strcmp(argv[i],"-dynamic")==0)
{
i++;
if(i>=argc) return false;
if(strcmp(argv[i], "0")==0)
{
doLS = doLS_static;
continue;
}
else if(strcmp(argv[i], "1")==0)
{
doLS = doLS_dynamic;
continue;
}
else return false;
}
else if(strcmp(argv[i],"-cnctimes")==0)
{
i++;
if(i>=argc) return false;
sscanf(argv[i], "%d", &cnc_times);
continue;
}
else if(strcmp(argv[i],"-ls_no_improv_steps")==0){
i++;
if(i>=argc) return false;
sscanf(argv[i], "%d", &ls_no_improv_times);
continue;
}
else return false;
}
if (flag_inst) return true;
else return false;
}
int main(int argc, char* argv[]) {
int ret;
ret = parse_arguments(argc, argv);
if(!ret) {cout<<"c Arguments Error!"<<endl; return -1;}
ret = build_instance(inst);
if (0 == ret) {
cout << "c Invalid filename: " << argv[1] << endl;
return 1;
}
record_runtime();
cnc_init(cb_cap);
ls_init();
srand(seed);
for (tries = 1; ; tries++) {
doCNC();
/*if (shouldPrint && the_best.opt_try == tries) {
cout << "o " << the_best.opt_unsat << endl;
print_best_solution();
}*/
if(the_best.opt_unsat==0) break;
if (the_best.opt_try == tries)
doLsRestartToBest();
else
doLsRestartToCanBest();
doLS();
if(the_best.opt_unsat==0) break;
/*if (shouldPrint && the_best.opt_try == tries && 2 == the_best.source) {
cout << "o " << the_best.opt_unsat << endl;
print_best_solution();
}
if (!shouldPrint) {
if (get_runtime() >= cutoff_time - 90) {
shouldPrint = true;
print_best_solution();
}
} else {
const double now = get_runtime();
double left = 2 * now / tries; // the time needed for two `CNC-LS' rounds
if (left < 10.0)
left = 10.0;
// 6s to 10s are left.
if (now >= cutoff_time - left) {
break;
}
}*/
const double now = get_runtime();
if (now >= cutoff_time) {
break;
}
}
//cout << "c TotalTry=" << tries << endl;
//cout << "c Finished at " << get_runtime() << endl;
//cout << "c " << inst << "\t" << the_best.opt_unsat << '\t' << the_best.opt_time << endl;
cout<<"s ";
if (0==the_best.opt_unsat && verify_sol() ) {
cout<<"SATISFIABLE"<<endl;
print_best_solution();
}
else cout<<"UNKNOWN"<<endl;
return 0;
}

133
CCAnr/preprocessor.h Normal file
View File

@ -0,0 +1,133 @@
#include "basis.h"
//preprocess
void unit_propagation()
{
lit uc_lit;
int uc_clause;
int uc_var;
bool uc_sense;
int c,v;
int i,j;
lit cur, cur_c;
//while (unitclause_queue_beg_pointer < unitclause_queue_end_pointer)
for(unitclause_queue_beg_pointer=0; unitclause_queue_beg_pointer < unitclause_queue_end_pointer; unitclause_queue_beg_pointer++)
{
uc_lit = unitclause_queue[unitclause_queue_beg_pointer];
uc_var = uc_lit.var_num;
uc_sense = uc_lit.sense;
if(fix[uc_var]==1) {if(uc_sense!=cur_soln[uc_var])cout<<"c wants to fix a variable twice, forbid."<<endl; continue;}
cur_soln[uc_var] = uc_sense;//fix the variable in unit clause
fix[uc_var] = 1;
for(i = 0; i<var_lit_count[uc_var]; ++i)
{
cur = var_lit[uc_var][i];
c = cur.clause_num;
if(clause_delete[c]==1) continue;
if(cur.sense == uc_sense)//then remove the clause from var's var_lit[] array
{
clause_delete[c]=1;
}
else
{
if(clause_lit_count[c]==2)
{
if(clause_lit[c][0].var_num == uc_var)
{
unitclause_queue[unitclause_queue_end_pointer++] = clause_lit[c][1];
}
else
{
unitclause_queue[unitclause_queue_end_pointer++] = clause_lit[c][0];
}
clause_delete[c]=1;
}
else
{
for(j=0; j<clause_lit_count[c]; ++j)
{
if(clause_lit[c][j].var_num == uc_var)
{
clause_lit[c][j]=clause_lit[c][clause_lit_count[c]-1];
clause_lit_count[c]--;
break;
}
}//for
}
}
}//for
}//begpointer to endpointer for
}
void preprocess()
{
int c,v,i;
int delete_clause_count=0;
int fix_var_count=0;
unit_propagation();
//rescan all clauses to build up var literal arrays
for (v=1; v<=num_vars; ++v)
var_lit_count[v] = 0;
max_clause_len = 0;
min_clause_len = num_vars;
int formula_len=0;
for (c = 0; c < num_clauses; ++c)
{
if(clause_delete[c]==1) {
delete_clause_count++;
continue;
}
for(i=0; i<clause_lit_count[c]; ++i)
{
v = clause_lit[c][i].var_num;
var_lit[v][var_lit_count[v]] = clause_lit[c][i];
++var_lit_count[v];
}
clause_lit[c][i].var_num=0; //new clause boundary
clause_lit[c][i].clause_num = -1;
//about clause length
formula_len += clause_lit_count[c];
if(clause_lit_count[c] > max_clause_len)
max_clause_len = clause_lit_count[c];
else if(clause_lit_count[c] < min_clause_len)
min_clause_len = clause_lit_count[c];
}
avg_clause_len = (double)formula_len/num_clauses;
for (v=1; v<=num_vars; ++v)
{
if(fix[v]==1)
{
fix_var_count++;
}
var_lit[v][var_lit_count[v]].clause_num=-1;//new var_lit boundary
}
cout<<"c unit propagation fixes "<<fix_var_count<<" variables, and delets "<<delete_clause_count<<" clauses"<<endl;
}

View File

@ -1,16 +0,0 @@
Instructions about how to compile and run CCAnr+cnc:
Compile CCAnr+cnc:
make
Run CCAnr+cnc:
./CCAnr+cnc
-inst <cnf_instance>
-seed <seed>
-cutoff_time <cutoff_time>
-dynamic {0,1} ##0 indicates performing non-dynamic method; 1 indicates performing dynamic method
-cnctimes <cnc_times> ##indicate the value of cnc_times underlying CCAnr+cnc
-ls_no_improv_steps <MaxNoImprSteps> ##indicate the value of MaxNoImprSteps underlying CCAnr+cnc
-swt_p <\rho> ##indicate the value of \rho underlying CCAnr
-swt_q <q> ##indicate the value of q underlying CCAnr
-swt_threshold <\gamma> ##indicate the value of \gamma underlying CCAnr

515
CCAnr/test.cnf Normal file
View File

@ -0,0 +1,515 @@
p cnf 196 514
-37 -1 0
37 1 0
-38 -2 0
38 2 0
-39 -4 0
39 4 0
-40 -6 0
40 6 0
-41 -8 0
41 8 0
-42 -10 0
42 10 0
-43 -12 0
43 12 0
-44 -14 0
44 14 0
-45 -16 0
45 16 0
-46 -18 0
46 18 0
-47 -20 0
47 20 0
-48 -22 0
48 22 0
-49 -24 0
49 24 0
-50 -26 0
50 26 0
-51 -28 0
51 28 0
-52 -30 0
52 30 0
-53 -32 0
53 32 0
-54 -34 0
54 34 0
55 37 0
55 2 0
-37 -2 -55 0
3 38 56 0
-56 -3 0
-56 -38 0
5 38 57 0
-57 -5 0
-57 -38 0
58 39 0
58 6 0
-39 -6 -58 0
61 41 0
61 10 0
-41 -10 -61 0
64 43 0
64 14 0
-43 -14 -64 0
67 45 0
67 18 0
-45 -18 -67 0
70 47 0
70 22 0
-47 -22 -70 0
73 49 0
73 26 0
-49 -26 -73 0
76 51 0
76 30 0
-51 -30 -76 0
79 53 0
79 34 0
-53 -34 -79 0
7 40 59 0
-59 -7 0
-59 -40 0
9 40 60 0
-60 -9 0
-60 -40 0
11 42 62 0
-62 -11 0
-62 -42 0
13 42 63 0
-63 -13 0
-63 -42 0
15 44 65 0
-65 -15 0
-65 -44 0
17 44 66 0
-66 -17 0
-66 -44 0
19 46 68 0
-68 -19 0
-68 -46 0
21 46 69 0
-69 -21 0
-69 -46 0
23 48 71 0
-71 -23 0
-71 -48 0
25 48 72 0
-72 -25 0
-72 -48 0
27 50 74 0
-74 -27 0
-74 -50 0
29 50 75 0
-75 -29 0
-75 -50 0
31 52 77 0
-77 -31 0
-77 -52 0
33 52 78 0
-78 -33 0
-78 -52 0
35 54 80 0
-80 -35 0
-80 -54 0
36 54 81 0
-81 -36 0
-81 -54 0
-82 55 0
-82 58 0
-82 61 0
-82 64 0
-82 67 0
-82 70 0
-82 73 0
-82 76 0
-82 79 0
-55 -58 -61 -64 -67 -70 -73 -76 -79 82 0
-83 -82 0
83 82 0
-84 -82 0
84 82 0
-85 -82 0
85 82 0
-86 -83 -55 0
-86 83 55 0
86 -83 55 0
86 83 -55 0
-87 -83 -58 0
-87 83 58 0
87 -83 58 0
87 83 -58 0
-88 -83 -61 0
-88 83 61 0
88 -83 61 0
88 83 -61 0
-89 -83 -64 0
-89 83 64 0
89 -83 64 0
89 83 -64 0
-90 -83 -67 0
-90 83 67 0
90 -83 67 0
90 83 -67 0
-91 -83 -70 0
-91 83 70 0
91 -83 70 0
91 83 -70 0
95 1 0
95 84 0
-1 -84 -95 0
-92 -83 -73 0
-92 83 73 0
92 -83 73 0
92 83 -73 0
96 84 0
96 4 0
-84 -4 -96 0
-93 -83 -76 0
-93 83 76 0
93 -83 76 0
93 83 -76 0
97 84 0
97 8 0
-84 -8 -97 0
-94 -83 -79 0
-94 83 79 0
94 -83 79 0
94 83 -79 0
98 84 0
98 12 0
-84 -12 -98 0
99 84 0
99 16 0
-84 -16 -99 0
100 84 0
100 20 0
-84 -20 -100 0
101 84 0
101 24 0
-84 -24 -101 0
102 84 0
102 28 0
-84 -28 -102 0
103 84 0
103 32 0
-84 -32 -103 0
104 86 0
104 56 0
-86 -56 -104 0
105 86 0
105 57 0
-86 -57 -105 0
106 87 0
106 59 0
-87 -59 -106 0
108 88 0
108 62 0
-88 -62 -108 0
110 89 0
110 65 0
-89 -65 -110 0
112 90 0
112 68 0
-90 -68 -112 0
114 91 0
114 71 0
-91 -71 -114 0
116 92 0
116 74 0
-92 -74 -116 0
118 93 0
118 77 0
-93 -77 -118 0
120 94 0
120 80 0
-94 -80 -120 0
107 87 0
107 60 0
-87 -60 -107 0
109 88 0
109 63 0
-88 -63 -109 0
111 89 0
111 66 0
-89 -66 -111 0
113 90 0
113 69 0
-90 -69 -113 0
115 91 0
115 72 0
-91 -72 -115 0
117 92 0
117 75 0
-92 -75 -117 0
119 93 0
119 78 0
-93 -78 -119 0
121 94 0
121 81 0
-94 -81 -121 0
-130 104 0
-130 106 0
-130 108 0
-130 110 0
-130 112 0
-130 114 0
-130 116 0
-130 118 0
-130 120 0
-104 -106 -108 -110 -112 -114 -116 -118 -120 130 0
-122 -105 0
122 105 0
-123 -107 0
123 107 0
-124 -109 0
124 109 0
-125 -111 0
125 111 0
-126 -113 0
126 113 0
-127 -115 0
127 115 0
-128 -117 0
128 117 0
-129 -119 0
129 119 0
-131 -121 0
131 121 0
-132 -130 0
132 130 0
-133 -130 0
133 130 0
-134 -130 0
134 130 0
-135 -132 -104 0
-135 132 104 0
135 -132 104 0
135 132 -104 0
-136 -132 -106 0
-136 132 106 0
136 -132 106 0
136 132 -106 0
-137 -132 -108 0
-137 132 108 0
137 -132 108 0
137 132 -108 0
-138 -132 -110 0
-138 132 110 0
138 -132 110 0
138 132 -110 0
144 3 0
144 133 0
-3 -133 -144 0
-139 -132 -112 0
-139 132 112 0
139 -132 112 0
139 132 -112 0
145 133 0
145 7 0
-133 -7 -145 0
-140 -132 -114 0
-140 132 114 0
140 -132 114 0
140 132 -114 0
146 133 0
146 11 0
-133 -11 -146 0
-141 -132 -116 0
-141 132 116 0
141 -132 116 0
141 132 -116 0
147 133 0
147 15 0
-133 -15 -147 0
-142 -132 -118 0
-142 132 118 0
142 -132 118 0
142 132 -118 0
148 133 0
148 19 0
-133 -19 -148 0
-143 -132 -120 0
-143 132 120 0
143 -132 120 0
143 132 -120 0
149 133 0
149 23 0
-133 -23 -149 0
150 133 0
150 27 0
-133 -27 -150 0
151 133 0
151 31 0
-133 -31 -151 0
152 133 0
152 35 0
-133 -35 -152 0
153 135 0
153 122 0
-135 -122 -153 0
154 136 0
154 123 0
-136 -123 -154 0
155 137 0
155 124 0
-137 -124 -155 0
156 138 0
156 125 0
-138 -125 -156 0
157 139 0
157 126 0
-139 -126 -157 0
158 140 0
158 127 0
-140 -127 -158 0
159 141 0
159 128 0
-141 -128 -159 0
160 142 0
160 129 0
-142 -129 -160 0
161 143 0
161 131 0
-143 -131 -161 0
-162 153 0
-162 154 0
-162 155 0
-162 156 0
-162 157 0
-162 158 0
-162 159 0
-162 160 0
-162 161 0
-153 -154 -155 -156 -157 -158 -159 -160 -161 162 0
-163 -162 0
163 162 0
-164 -162 0
164 162 0
165 5 0
165 163 0
-5 -163 -165 0
166 163 0
166 9 0
-163 -9 -166 0
167 163 0
167 13 0
-163 -13 -167 0
168 163 0
168 17 0
-163 -17 -168 0
169 163 0
169 21 0
-163 -21 -169 0
170 163 0
170 25 0
-163 -25 -170 0
171 163 0
171 29 0
-163 -29 -171 0
172 163 0
172 33 0
-163 -33 -172 0
173 163 0
173 36 0
-163 -36 -173 0
174 2 0
174 95 0
174 144 0
174 165 0
-2 -95 -144 -165 -174 0
175 96 0
175 145 0
175 166 0
175 6 0
-96 -145 -166 -6 -175 0
176 97 0
176 146 0
176 167 0
176 10 0
-97 -146 -167 -10 -176 0
177 98 0
177 147 0
177 168 0
177 14 0
-98 -147 -168 -14 -177 0
178 99 0
178 148 0
178 169 0
178 18 0
-99 -148 -169 -18 -178 0
179 100 0
179 149 0
179 170 0
179 22 0
-100 -149 -170 -22 -179 0
180 101 0
180 150 0
180 171 0
180 26 0
-101 -150 -171 -26 -180 0
181 102 0
181 151 0
181 172 0
181 30 0
-102 -151 -172 -30 -181 0
182 103 0
182 152 0
182 173 0
182 34 0
-103 -152 -173 -34 -182 0
-183 -174 0
183 174 0
-188 175 0
-188 176 0
-188 177 0
-188 178 0
-188 179 0
-188 180 0
-188 181 0
-188 182 0
-175 -176 -177 -178 -179 -180 -181 -182 188 0
-184 -177 0
184 177 0
-185 -179 0
185 179 0
-186 -180 0
186 180 0
-187 -181 0
187 181 0
183 188 193 0
-193 -183 0
-193 -188 0
189 176 0
189 184 0
-176 -184 -189 0
190 176 0
190 177 0
190 185 0
190 178 0
-176 -177 -185 -178 -190 0
191 178 0
191 177 0
191 186 0
-178 -177 -186 -191 0
192 176 0
192 177 0
192 180 0
192 187 0
-176 -177 -180 -187 -192 0
194 175 0
194 176 0
194 189 0
194 178 0
-175 -176 -189 -178 -194 0
195 175 0
195 176 0
195 190 0
195 191 0
-175 -176 -190 -191 -195 0
196 175 0
196 189 0
196 190 0
196 192 0
-175 -189 -190 -192 -196 0

8829
_c6288.txt

File diff suppressed because it is too large Load Diff

BIN
atpg

Binary file not shown.

View File

@ -1,207 +0,0 @@
# c432
INPUT(1)
INPUT(4)
INPUT(8)
INPUT(11)
INPUT(14)
INPUT(17)
INPUT(21)
INPUT(24)
INPUT(27)
INPUT(30)
INPUT(34)
INPUT(37)
INPUT(40)
INPUT(43)
INPUT(47)
INPUT(50)
INPUT(53)
INPUT(56)
INPUT(60)
INPUT(63)
INPUT(66)
INPUT(69)
INPUT(73)
INPUT(76)
INPUT(79)
INPUT(82)
INPUT(86)
INPUT(89)
INPUT(92)
INPUT(95)
INPUT(99)
INPUT(102)
INPUT(105)
INPUT(108)
INPUT(112)
INPUT(115)
OUTPUT(223)
OUTPUT(329)
OUTPUT(370)
OUTPUT(421)
OUTPUT(430)
OUTPUT(431)
OUTPUT(432)
118 = NOT(1)
119 = NOT(4)
122 = NOT(11)
123 = NOT(17)
126 = NOT(24)
127 = NOT(30)
130 = NOT(37)
131 = NOT(43)
134 = NOT(50)
135 = NOT(56)
138 = NOT(63)
139 = NOT(69)
142 = NOT(76)
143 = NOT(82)
146 = NOT(89)
147 = NOT(95)
150 = NOT(102)
151 = NOT(108)
154 = NAND(118, 4)
157 = NOR(8, 119)
158 = NOR(14, 119)
159 = NAND(122, 17)
162 = NAND(126, 30)
165 = NAND(130, 43)
168 = NAND(134, 56)
171 = NAND(138, 69)
174 = NAND(142, 82)
177 = NAND(146, 95)
180 = NAND(150, 108)
183 = NOR(21, 123)
184 = NOR(27, 123)
185 = NOR(34, 127)
186 = NOR(40, 127)
187 = NOR(47, 131)
188 = NOR(53, 131)
189 = NOR(60, 135)
190 = NOR(66, 135)
191 = NOR(73, 139)
192 = NOR(79, 139)
193 = NOR(86, 143)
194 = NOR(92, 143)
195 = NOR(99, 147)
196 = NOR(105, 147)
197 = NOR(112, 151)
198 = NOR(115, 151)
199 = AND(154, 159, 162, 165, 168, 171, 174, 177, 180)
203 = NOT(199)
213 = NOT(199)
223 = NOT(199)
224 = XOR(203, 154)
227 = XOR(203, 159)
230 = XOR(203, 162)
233 = XOR(203, 165)
236 = XOR(203, 168)
239 = XOR(203, 171)
242 = NAND(1, 213)
243 = XOR(203, 174)
246 = NAND(213, 11)
247 = XOR(203, 177)
250 = NAND(213, 24)
251 = XOR(203, 180)
254 = NAND(213, 37)
255 = NAND(213, 50)
256 = NAND(213, 63)
257 = NAND(213, 76)
258 = NAND(213, 89)
259 = NAND(213, 102)
260 = NAND(224, 157)
263 = NAND(224, 158)
264 = NAND(227, 183)
267 = NAND(230, 185)
270 = NAND(233, 187)
273 = NAND(236, 189)
276 = NAND(239, 191)
279 = NAND(243, 193)
282 = NAND(247, 195)
285 = NAND(251, 197)
288 = NAND(227, 184)
289 = NAND(230, 186)
290 = NAND(233, 188)
291 = NAND(236, 190)
292 = NAND(239, 192)
293 = NAND(243, 194)
294 = NAND(247, 196)
295 = NAND(251, 198)
296 = AND(260, 264, 267, 270, 273, 276, 279, 282, 285)
300 = NOT(263)
301 = NOT(288)
302 = NOT(289)
303 = NOT(290)
304 = NOT(291)
305 = NOT(292)
306 = NOT(293)
307 = NOT(294)
308 = NOT(295)
309 = NOT(296)
319 = NOT(296)
329 = NOT(296)
330 = XOR(309, 260)
331 = XOR(309, 264)
332 = XOR(309, 267)
333 = XOR(309, 270)
334 = NAND(8, 319)
335 = XOR(309, 273)
336 = NAND(319, 21)
337 = XOR(309, 276)
338 = NAND(319, 34)
339 = XOR(309, 279)
340 = NAND(319, 47)
341 = XOR(309, 282)
342 = NAND(319, 60)
343 = XOR(309, 285)
344 = NAND(319, 73)
345 = NAND(319, 86)
346 = NAND(319, 99)
347 = NAND(319, 112)
348 = NAND(330, 300)
349 = NAND(331, 301)
350 = NAND(332, 302)
351 = NAND(333, 303)
352 = NAND(335, 304)
353 = NAND(337, 305)
354 = NAND(339, 306)
355 = NAND(341, 307)
356 = NAND(343, 308)
357 = AND(348, 349, 350, 351, 352, 353, 354, 355, 356)
360 = NOT(357)
370 = NOT(357)
371 = NAND(14, 360)
372 = NAND(360, 27)
373 = NAND(360, 40)
374 = NAND(360, 53)
375 = NAND(360, 66)
376 = NAND(360, 79)
377 = NAND(360, 92)
378 = NAND(360, 105)
379 = NAND(360, 115)
380 = NAND(4, 242, 334, 371)
381 = NAND(246, 336, 372, 17)
386 = NAND(250, 338, 373, 30)
393 = NAND(254, 340, 374, 43)
399 = NAND(255, 342, 375, 56)
404 = NAND(256, 344, 376, 69)
407 = NAND(257, 345, 377, 82)
411 = NAND(258, 346, 378, 95)
414 = NAND(259, 347, 379, 108)
415 = NOT(380)
416 = AND(381, 386, 393, 399, 404, 407, 411, 414)
417 = NOT(393)
418 = NOT(404)
419 = NOT(407)
420 = NOT(411)
421 = NOR(415, 416)
422 = NAND(386, 417)
425 = NAND(386, 393, 418, 399)
428 = NAND(399, 393, 419)
429 = NAND(386, 393, 407, 420)
430 = NAND(381, 386, 422, 399)
431 = NAND(381, 386, 425, 428)
432 = NAND(381, 422, 425, 429)

View File

@ -1,10 +0,0 @@
gates: 160
primary input: 36
primary output: 7
simulate patterns: 0
final patterns: 77
faults: 524
detect faults: 520
redundant faults: 0
test coverage:0.992
time: 0.00859

File diff suppressed because it is too large Load Diff

View File

@ -1,26 +0,0 @@
[1/26] 任务 ./benchmark/c17.bench
[2/26] 任务 ./benchmark/b06.bench
[3/26] 任务 ./benchmark/b01.bench
[4/26] 任务 ./benchmark/b03.bench
[5/26] 任务 ./benchmark/b09.bench
[6/26] 任务 ./benchmark/c880.bench
[7/26] 任务 ./benchmark/b10.bench
[8/26] 任务 ./benchmark/b08.bench
[9/26] 任务 ./benchmark/c499.bench
[10/26] 任务 ./benchmark/c1355.bench
[11/26] 任务 ./benchmark/c3540.bench
[12/26] 任务 ./benchmark/c1908.bench
[13/26] 任务 ./benchmark/b11.bench
[14/26] 任务 ./benchmark/c6288.bench
[15/26] 任务 ./benchmark/c2670.bench
[16/26] 任务 ./benchmark/b21.bench
[17/26] 任务 ./benchmark/b13.bench
[18/26] 任务 ./benchmark/b22.bench
[19/26] 任务 ./benchmark/b17.bench
[20/26] 任务 ./benchmark/b20.bench
[21/26] 任务 ./benchmark/c7552.bench
[22/26] 任务 ./benchmark/b12.bench
[23/26] 任务 ./benchmark/c5315.bench
[24/26] 任务 ./benchmark/b04.bench
[25/26] 任务 ./benchmark/b07.bench
[26/26] 任务 ./benchmark/c432.bench

View File

@ -59,28 +59,10 @@ void write_cnf() {
} }
f.close(); f.close();
} }
void flip(int var) { void flip(int var) {
// printf("value: [ ");
// for(int i=1; i<=num_vars; i++) {
// printf("%d ", lit_value[i]);
// }
// printf("]\n");
// for(auto& c : clauses) {
// printf("lits: [ ");
// for(auto& lit : c->lits) {
// printf("%d ", lit);
// }
// printf(" ] satifs_cnt: %d\n", c->satisfied_lit_count);
// }
lit_value[var] = !lit_value[var]; lit_value[var] = !lit_value[var];
for(auto& clause : lit_related_clauses[var]) { for(auto& clause : lit_related_clauses[var]) {
@ -89,8 +71,8 @@ void flip(int var) {
CC[abs(lit)] = 1; CC[abs(lit)] = 1;
} }
} }
CC[var] = 0;
CC[var] = 0;
} }
void add_to_tmp_clause(int x) { void add_to_tmp_clause(int x) {

View File

@ -24,6 +24,7 @@ namespace ClauseLS {
extern std::vector<Clause*> *lit_related_clauses; extern std::vector<Clause*> *lit_related_clauses;
extern int *lit_value; extern int *lit_value;
extern int *CC; extern int *CC;
extern int *score;
extern std::unordered_set<Clause*> satisfied_clauses; extern std::unordered_set<Clause*> satisfied_clauses;
extern std::unordered_set<Clause*> falsified_clauses; extern std::unordered_set<Clause*> falsified_clauses;
@ -35,4 +36,5 @@ namespace ClauseLS {
void write_cnf(); void write_cnf();
void flip(int var); void flip(int var);
} }

2
crun
View File

@ -8,6 +8,6 @@ if [ $? -ne 0 ]; then
echo "compile failed." echo "compile failed."
else else
echo "========================" echo "========================"
time ./atpg $1 time ./atpg $1 2>&1 | tee output.txt
fi fi

34
ls.cpp
View File

@ -8,6 +8,7 @@
#include <chrono> #include <chrono>
#include "clause.h" #include "clause.h"
#include "CCAnr/ccanr.h"
bool Circuit::local_search() { bool Circuit::local_search() {
@ -17,14 +18,17 @@ bool Circuit::local_search() {
ls_init_weight(); ls_init_weight();
//CCAnr::module_reset();
ls_random_circuit(); ls_random_circuit();
for(int i=0; i<MAX_STEPS; i++) { for(int i=0; i<MAX_STEPS; i++) {
auto start = std::chrono::system_clock::now(); auto start = std::chrono::system_clock::now();
printf("[FLIP] stem: %lld, fault:%lld, stem_cnt: %lld, fault_cnt:%lld, fpl_score: %lld citcuit-score: %lld\n", stem_total_cost, fault_total_weight, stems.size() - stem_total_cnt, fault_total_cnt, fault_propagate_score, ls_circuit_score());
//printf("[FLIP] stem: %lld, fault:%lld, stem_cnt: %lld, fault_cnt:%lld, fpl_score: %lld citcuit-score: %lld\n", stem_total_cost, fault_total_weight, stems.size() - stem_total_cnt, fault_total_cnt, fault_propagate_score, ls_circuit_score());
int id = ls_pick(); int id = ls_pick();
ls_flip_var(id); ls_flip_var(id);
@ -33,7 +37,7 @@ bool Circuit::local_search() {
break; break;
} }
assert(is_valid_circuit()); //assert(is_valid_circuit());
auto end = std::chrono::system_clock::now(); auto end = std::chrono::system_clock::now();
std::chrono::duration<double> elapsed_seconds = end - start; std::chrono::duration<double> elapsed_seconds = end - start;
@ -136,7 +140,7 @@ int Circuit::ls_pick() {
if(var == -1) { if(var == -1) {
ls_update_weight(); ls_update_weight();
printf("[UP] stem: %lld, fault:%lld, stem_cnt: %lld, fault_cnt:%lld, fpl_score: %lld citcuit-score: %lld\n", stem_total_cost, fault_total_weight, stems.size() - stem_total_cnt, fault_total_cnt, fault_propagate_score, ls_circuit_score()); //printf("[UP] stem: %lld, fault:%lld, stem_cnt: %lld, fault_cnt:%lld, fpl_score: %lld citcuit-score: %lld\n", stem_total_cost, fault_total_weight, stems.size() - stem_total_cnt, fault_total_cnt, fault_propagate_score, ls_circuit_score());
if(ClauseLS::falsified_clauses.size() == 0) { if(ClauseLS::falsified_clauses.size() == 0) {
print_circuit(); print_circuit();
@ -150,9 +154,20 @@ int Circuit::ls_pick() {
var = abs(lits[rand()%lits.size()]); var = abs(lits[rand()%lits.size()]);
} }
int var_score = ls_pick_score(var);
assert(var != -1); assert(var != -1);
return var; return var;
// int ccanr_var = CCAnr::module_pick_var();
// int ccanr_score = ls_pick_score(ccanr_var);
// if(var_score > 0 && rand() % 100 <= 10) {
// return var;
// } else {
// return ccanr_var;
// }
} }
void Circuit::ls_init_stems() { void Circuit::ls_init_stems() {
@ -218,6 +233,7 @@ void Circuit::ls_init_stems() {
} }
void Circuit::ls_flip_var(int var) { void Circuit::ls_flip_var(int var) {
//CCAnr::module_flip_var(var);
ClauseLS::flip(var); ClauseLS::flip(var);
if(id2gate.count(var) && id2gate[var]->stem) { if(id2gate.count(var) && id2gate[var]->stem) {
@ -235,14 +251,14 @@ ll Circuit::ls_pick_score(int var) {
ls_flip_var(var); ls_flip_var(var);
assert(old_score == ls_circuit_score()); //assert(old_score == ls_circuit_score());
return new_score - old_score; return new_score - old_score;
} }
ll Circuit::ls_circuit_score() { ll Circuit::ls_circuit_score() {
//ll score = - Clause::total_cost + fault_propagate_score + fault_total_weight; ll score = - Clause::total_cost + fault_propagate_score + fault_total_weight;
ll score = - Clause::total_cost; //ll score = - Clause::total_cost;
return score; return score;
} }
@ -308,7 +324,7 @@ void Circuit::ls_random_circuit() {
} }
assert(is_valid_circuit()); //assert(is_valid_circuit());
} }
void Circuit::ls_reset_data() { void Circuit::ls_reset_data() {
@ -341,6 +357,8 @@ void Circuit::ls_reset_data() {
void Circuit::ls_flip_stem(Gate* stem) { void Circuit::ls_flip_stem(Gate* stem) {
printf("flip-stem: %s\n", stem->name.c_str());
stem->value = !stem->value; stem->value = !stem->value;
// update CC // update CC

View File

@ -4,6 +4,7 @@
#include "circuit.h" #include "circuit.h"
#include "clause.h" #include "clause.h"
#include "CCAnr/ccanr.h"
int main(int args, char* argv[]) { int main(int args, char* argv[]) {
@ -40,7 +41,6 @@ int main(int args, char* argv[]) {
printf(" result: %d.\n", is_valid); printf(" result: %d.\n", is_valid);
if(!ls) break; if(!ls) break;
if(!is_valid) break; if(!is_valid) break;
if(circuit->global_fault_undetected_count == 0) break; if(circuit->global_fault_undetected_count == 0) break;
} }

105
makefile
View File

@ -1,72 +1,35 @@
#一个实用的makefile能自动编译当前目录下所有.c/.cpp源文件支持二者混合编译 # 定义源文件列表
#并且当某个.c/.cpp、.h或依赖的源文件被修改后仅重编涉及到的源文件未涉及的不编译 SOURCES := $(wildcard *.c) $(wildcard *.cpp)
#详解文档http://blog.csdn.net/huyansoft/article/details/8924624
#author胡彦 2013-5-21
#----------------------------------------------------------
#编译工具用g++以同时支持C和C++程序,以及二者的混合编译
CC=g++
CPPFLAGS=-O3 -std=c++17 # 将源文件列表转换为目标文件列表
OBJECTS := $(addprefix build/,$(SOURCES:%=%.o))
#使用$(winldcard *.c)来获取工作目录下的所有.c文件的列表
#sources:=main.cpp command.c # 声明编译器和编译选项
CC := gcc
#变量sources得到当前目录下待编译的.c/.cpp文件的列表两次调用winldcard、结果连在一起即可 CXX := g++
sources:=$(wildcard *.c) $(wildcard *.cpp) $(wildcard CCAnr/*.cpp) CFLAGS := -Wall -Wextra -MMD -MP
CXXFLAGS := -Wall -Wextra -MMD -MP
#变量objects得到待生成的.o文件的列表把sources中每个文件的扩展名换成.o即可。这里两次调用patsubst函数第1次把sources中所有.cpp换成.o第2次把第1次结果里所有.c换成.o
objects:=$(patsubst %.c,%.o,$(patsubst %.cpp,%.o,$(sources))) # 默认目标,编译所有目标文件
atpg: $(OBJECTS)
#变量dependence得到待生成的.d文件的列表把objects中每个扩展名.o换成.d即可。也可写成$(patsubst %.o,%.d,$(objects)) $(CXX) $(CXXFLAGS) $^ -o $@
dependence:=$(objects:.o=.d)
# 生成目标文件的规则
#---------------------------------------------------------- build/%.o: % | build
#当$(objects)列表里所有文件都生成后,便可调用这里的 $(CC) $^ -o $@ 命令生成最终目标all了 $(CC) $(CFLAGS) -c $< -o $@
#把all定义成第1个规则使得可以把make all命令简写成make
atpg: $(objects) build/%.o: %.cpp | build
$(CC) $(CPPFLAGS) $^ -o $@ $(CXX) $(CXXFLAGS) -c $< -o $@
# @./$@ #编译后立即执行
# 包含依赖文件
#这段使用make的模式规则指示如何由.c文件生成.o即对每个.c文件调用gcc -c XX.c -o XX.o命令生成对应的.o文件 -include $(OBJECTS:.o=.d)
#如果不写这段也可以因为make的隐含规则可以起到同样的效果
%.o: %.c # 如果需要,则递归创建源文件的目录结构
$(CC) $(CPPFLAGS) -c $< -o $@ build:
mkdir -p $(sort $(dir $(OBJECTS)))
#同上,指示如何由.cpp生成.o可省略
%.o: %.cpp # 清除所有目标文件和build目录
$(CC) $(CPPFLAGS) -c $< -o $@ clean:
rm -rf build $(OBJECTS)
#----------------------------------------------------------
include $(dependence) #注意该句要放在终极目标all的规则之后否则.d文件里的规则会被误当作终极规则了 .PHONY: clean all
#因为这4行命令要多次凋用定义成命令包以简化书写
define gen_dep
set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
endef
#指示如何由.c生成其依赖规则文件.d
#这段使用make的模式规则指示对每个.c文件如何生成其依赖规则文件.d调用上面的命令包即可
%.d: %.c
$(gen_dep)
#同上,指示对每个.cpp如何生成其依赖规则文件.d
%.d: %.cpp
$(gen_dep)
#----------------------------------------------------------
#清除所有临时文件(所有.o和.d。之所以把clean定义成伪目标是因为这个目标并不对应实际的文件
.PHONY: clean
clean: #.$$已在每次使用后立即删除。-f参数表示被删文件不存在时不报错
rm -f all $(objects) $(dependence)
echo: #调试时显示一些变量的值
@echo sources=$(sources)
@echo objects=$(objects)
@echo dependence=$(dependence)
@echo CPPFLAGS=$(CPPFLAGS)
#提醒:当混合编译.c/.cpp时为了能够在C++程序里调用C函数必须把每一个要调用的C函数其声明都包括在extern "C"{}块里面这样C++链接时才能成功链接它们。

7732
test.cnf

File diff suppressed because it is too large Load Diff