修复了所有问题

This commit is contained in:
YuhangQ 2023-03-02 08:17:53 +00:00
parent 589eeb7432
commit 1a93b8a8a3
4 changed files with 49 additions and 17 deletions

BIN
atpg

Binary file not shown.

View File

@ -19,8 +19,6 @@ public:
bool isPI; bool isPI;
bool isPO; bool isPO;
std::unordered_map<Gate*, std::pair<int, int>> sa_by_out;
std::vector<Gate*> pre_stems; std::vector<Gate*> pre_stems;
std::vector<Gate*> suc_stems; std::vector<Gate*> suc_stems;
@ -29,6 +27,7 @@ public:
bool is_propagated(); bool is_propagated();
int cal_value(); int cal_value();
bool cal_sa(bool x);
}; };
class Fault { class Fault {

View File

@ -6,6 +6,32 @@ bool Gate::is_propagated() {
return sa[0] || sa[1]; return sa[0] || sa[1];
} }
bool Gate::cal_sa(bool x) {
if(isPO) {
if(x == 0) return value;
else return !value;
}
bool sa0 = 0;
bool sa1 = 0;
for(Gate* out : outputs) {
if(!out->is_propagated()) continue;
if(out->cal_value() != out->value) continue;
this->value = !this->value;
bool detect = out->cal_value() != out->value;
this->value = !this->value;
if(!detect) continue;
sa0 |= this->value;
sa1 |= !this->value;
}
if(x == 0) return sa0;
else return sa1;
}
int Gate::cal_value() { int Gate::cal_value() {
int res; int res;

37
ls.cpp
View File

@ -402,12 +402,32 @@ void Circuit::ls_block_recal(Gate* stem) {
stem_satisfied[stem->id] = true; stem_satisfied[stem->id] = true;
stem_total_weight -= stem_weight[stem->id]; stem_total_weight -= stem_weight[stem->id];
stem_total_cnt += 1; stem_total_cnt += 1;
for(Gate* pre : stem->pre_stems) {
if(flip_need_update[pre->id]) continue;
flip_need_update[pre->id] = true;
flip_update_queue.push_back(pre);
flip_total_weight += flip_weight[pre->id];
flip_total_cnt += 1;
}
} }
if(stem->cal_value() != stem->value && stem_satisfied[stem->id]) { if(stem->cal_value() != stem->value && stem_satisfied[stem->id]) {
stem_satisfied[stem->id] = false; stem_satisfied[stem->id] = false;
stem_total_weight += stem_weight[stem->id]; stem_total_weight += stem_weight[stem->id];
stem_total_cnt -= 1; stem_total_cnt -= 1;
for(Gate* pre : stem->pre_stems) {
if(flip_need_update[pre->id]) continue;
flip_need_update[pre->id] = true;
flip_update_queue.push_back(pre);
flip_total_weight += flip_weight[pre->id];
flip_total_cnt += 1;
}
} }
} }
@ -417,27 +437,14 @@ void Circuit::ls_block_recal(Gate* stem) {
used[g] = false; used[g] = false;
bool right_value = (g->cal_value() == g->value);
for(Gate* in : g->inputs) { for(Gate* in : g->inputs) {
in->value = !in->value;
bool input_detected = (g->cal_value() != g->value);
in->value = !in->value;
bool sa0 = right_value && input_detected && g->sa[!g->value] && in->value;
bool sa1 = right_value && input_detected && g->sa[!g->value] && !in->value;
in->sa_by_out[g] = std::make_pair(sa0, sa1);
bool old_sa[2]; bool old_sa[2];
old_sa[0] = in->sa[0]; old_sa[0] = in->sa[0];
old_sa[1] = in->sa[1]; old_sa[1] = in->sa[1];
in->sa[0] = in->sa[1] = 0; in->sa[0] = in->cal_sa(0);
for(Gate* out : in->outputs) { in->sa[1] = in->cal_sa(1);
auto &p = in->sa_by_out[out];
in->sa[0] |= p.first;
in->sa[1] |= p.second;
}
if(in->stem && !in->isPI && (in->sa[0] != old_sa[0] || in->sa[1] != old_sa[1])) { if(in->stem && !in->isPI && (in->sa[0] != old_sa[0] || in->sa[1] != old_sa[1])) {