-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwolworklist.cpp
111 lines (88 loc) · 2.07 KB
/
wolworklist.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
* wolworklist.cpp
*
* Created on: Sep 24, 2014
* Author: user
*/
#include "wolworklist.h"
#include "wollog.h"
#include "wolexp.h"
#include <functional>
namespace wolver {
std::size_t
expHashW::operator()(WolNodeSptr const& x) const
{
return x->getId();
}
bool
expEqualToW::operator()(WolNodeSptr const& x, WolNodeSptr const& y) const
{
return x->getId() == y->getId();
}
std::string
WolWorkList::str() {
std::stringstream sstm;
for (auto i : _workList) {
sstm << " " << i->getId();
}
return sstm.str();
}
void
WolWorkList::addNode(WolNodeSptr node) {
_workList.insert(node);
}
void
WolWorkList::addNodes(nodeL &nodes) {
_workList.insert(nodes.begin(), nodes.end());
}
void
WolWorkList::addNodes(std::vector<WolNodeSptr> &nodes) {
_workList.insert(nodes.begin(), nodes.end());
}
void
WolWorkList::setImplyFlag() {
std::for_each(_workList.begin(), _workList.end(),
std::mem_fn(&WolNode::setImplyFlag));
}
void
WolWorkList::unsetImplyFlag() {
std::for_each(_workList.begin(), _workList.end(),
std::mem_fn(&WolNode::unsetImplyFlag));
}
bool
WolWorkList::performImplication(nodeL &changes, WolWorkList &wl) {
for(auto i : _workList) {
DEBUG1_MSG << "Peforming implication on node " << i->getId();
int output = i->performImplication();
// conflict
if (output == -1) return false;
if (output == 1) {
// enable backward implication
if (i->getChild(0)) wl.addNode(i->getChild(0));
if (i->getChild(1)) wl.addNode(i->getChild(1));
if (i->getChild(2)) wl.addNode(i->getChild(2));
}
else if (output == 2) {
// enable forward and backward implication
std::vector<WolNodeSptr> neighbors;
neighbors = i->getNeighbors();
wl.addNodes(neighbors);
changes.insert(i);
}
else {
assert(output == 0);
}
}
return true;
}
WolWorkList
WolWorkList::getNeighbors() {
WolWorkList retValue;
std::vector<WolNodeSptr> neighbors;
for(auto i : _workList) {
neighbors = i->getNeighbors();
retValue.addNodes(neighbors);
}
return retValue;
}
}