make independent partial ground suck less

This commit is contained in:
Tiago Gomes 2012-10-29 20:49:21 +00:00
parent c2b1434969
commit 324ea1a96c
4 changed files with 73 additions and 29 deletions

View File

@ -329,35 +329,52 @@ LiftedCircuit::tryIndepPartialGrounding (
// assumes that all literals have logical variables
// else, shannon decomp was possible
LogVarSet lvs = clauses[0].constr().logVarSet();
lvs -= clauses[0].ipgLogVars();
for (unsigned i = 0; i < lvs.size(); i++) {
LogVar X = lvs[i];
vector<unsigned> lvIndices;
LogVarSet lvs = clauses[0].ipgCandidates();
for (size_t i = 0; i < lvs.size(); i++) {
lvIndices.clear();
lvIndices.push_back (i);
ConstraintTree ct = clauses[0].constr();
ct.project ({X});
for (size_t j = 0; j < clauses.size(); j++) {
if (clauses[j].constr().logVars().size() == 1) {
if (ct.tupleSet() != clauses[j].constr().tupleSet()) {
return false;
}
} else {
return false;
}
}
}
// FIXME this is so broken ...
ct.project ({lvs[i]});
if (tryIndepPartialGroundingAux (clauses, ct, lvIndices)) {
Clauses newClauses = clauses;
for (size_t i = 0; i < clauses.size(); i++) {
newClauses[i].addIpgLogVar (clauses[i].constr().logVars()[0]);
LogVar lv = clauses[i].ipgCandidates()[lvIndices[i]];
newClauses[i].addIpgLogVar (lv);
}
// FIXME
SetAndNode* node = new SetAndNode (2, clauses);
SetAndNode* node = new SetAndNode (ct.size(), clauses);
*follow = node;
compile (node->follow(), newClauses);
return true;
}
}
return false;
}
bool
LiftedCircuit::tryIndepPartialGroundingAux (
Clauses& clauses,
ConstraintTree& ct,
vector<unsigned>& lvIndices)
{
for (size_t j = 1; j < clauses.size(); j++) {
LogVarSet lvs2 = clauses[j].ipgCandidates();
for (size_t k = 0; k < lvs2.size(); k++) {
ConstraintTree ct2 = clauses[j].constr();
ct2.project ({lvs2[k]});
if (ct.tupleSet() == ct2.tupleSet()) {
lvIndices.push_back (k);
break;
}
}
if (lvIndices.size() != j+1) {
return false;
}
}
return true;
}
@ -414,8 +431,8 @@ LiftedCircuit::smoothCircuit (CircuitNode* node)
}
SmoothNode* smoothNode = new SmoothNode (clauses);
CircuitNode** prev = casted->leftBranch();
string explanation = " smoothing" ;
AndNode* andNode = new AndNode ((*prev)->clauses(), smoothNode, *prev, explanation);
AndNode* andNode = new AndNode ((*prev)->clauses(),
smoothNode, *prev, " smoothing");
*prev = andNode;
}
if (missingRight.empty() == false) {
@ -427,8 +444,8 @@ LiftedCircuit::smoothCircuit (CircuitNode* node)
}
SmoothNode* smoothNode = new SmoothNode (clauses);
CircuitNode** prev = casted->rightBranch();
string explanation = " smoothing" ;
AndNode* andNode = new AndNode ((*prev)->clauses(), smoothNode, *prev, explanation);
AndNode* andNode = new AndNode ((*prev)->clauses(), smoothNode,
*prev, " smoothing");
*prev = andNode;
}
propagatingLids |= lids1;

View File

@ -109,7 +109,7 @@ class SetAndNode : public CircuitNode
{
public:
SetAndNode (unsigned nrGroundings, const Clauses& clauses)
: CircuitNode (clauses, ""), nrGroundings_(nrGroundings),
: CircuitNode (clauses, "IPG"), nrGroundings_(nrGroundings),
follow_(0) { }
double weight (void) const;
@ -191,6 +191,8 @@ class LiftedCircuit
bool tryIndependence (CircuitNode** follow, Clauses& clauses);
bool tryShannonDecomp (CircuitNode** follow, Clauses& clauses);
bool tryIndepPartialGrounding (CircuitNode** follow, Clauses& clauses);
bool tryIndepPartialGroundingAux (Clauses& clauses, ConstraintTree& ct,
vector<unsigned>& indices);
bool tryGrounding (CircuitNode** follow, Clauses& clauses);
TinySet<LiteralId> smoothCircuit (CircuitNode* node);

View File

@ -136,6 +136,29 @@ Clause::removeNegativeLiterals (LiteralId lid)
LogVarSet
Clause::ipgCandidates (void) const
{
LogVarSet candidates;
LogVarSet allLvs = constr_.logVarSet();
allLvs -= ipgLogVars_;
for (size_t i = 0; i < allLvs.size(); i++) {
bool valid = true;
for (size_t j = 0; j < literals_.size(); j++) {
if (Util::contains (literals_[j].logVars(), allLvs[i]) == false) {
valid = false;
break;
}
}
if (valid) {
candidates.insert (allLvs[i]);
}
}
return candidates;
}
TinySet<LiteralId>
Clause::lidSet (void) const
{

View File

@ -90,6 +90,8 @@ class Clause
void addIpgLogVar (LogVar X) { ipgLogVars_.insert (X); }
LogVarSet ipgCandidates (void) const;
TinySet<LiteralId> lidSet (void) const;
friend std::ostream& operator<< (ostream &os, const Clause& clause);