one step close to use one solver instatiation to solve several queries

This commit is contained in:
Tiago Gomes 2012-11-14 23:13:46 +00:00
parent b673dfd462
commit 4522850cd6
7 changed files with 35 additions and 10 deletions

View File

@ -4,8 +4,8 @@
#include "LiftedOperations.h"
LiftedBp::LiftedBp (const ParfactorList& pfList)
: LiftedSolver (pfList), pfList_(pfList)
LiftedBp::LiftedBp (const ParfactorList& parfactorList)
: LiftedSolver (parfactorList)
{
refineParfactors();
createFactorGraph();
@ -82,6 +82,7 @@ LiftedBp::printSolverFlags (void) const
void
LiftedBp::refineParfactors (void)
{
pfList_ = parfactorList;
while (iterate() == false);
if (Globals::verbosity > 2) {

View File

@ -16,7 +16,9 @@ LiftedKc::~LiftedKc (void)
Params
LiftedKc::solveQuery (const Grounds& query)
{
pfList_ = parfactorList;
LiftedOperations::shatterAgainstQuery (pfList_, query);
LiftedOperations::runWeakBayesBall (pfList_, query);
lwcnf_ = new LiftedWCNF (pfList_);
circuit_ = new LiftedCircuit (lwcnf_);
vector<PrvGroup> groups;

View File

@ -12,7 +12,7 @@ class LiftedKc : public LiftedSolver
{
public:
LiftedKc (const ParfactorList& pfList)
: LiftedSolver(pfList), pfList_(pfList) { }
: LiftedSolver(pfList) { }
~LiftedKc (void);
@ -23,7 +23,6 @@ class LiftedKc : public LiftedSolver
private:
LiftedWCNF* lwcnf_;
LiftedCircuit* circuit_;
ParfactorList pfList_;
};

View File

@ -631,6 +631,7 @@ Params
LiftedVe::solveQuery (const Grounds& query)
{
assert (query.empty() == false);
pfList_ = parfactorList;
runSolver (query);
(*pfList_.begin())->normalize();
Params params = (*pfList_.begin())->params();

View File

@ -136,7 +136,7 @@ class LiftedVe : public LiftedSolver
{
public:
LiftedVe (const ParfactorList& pfList)
: LiftedSolver(pfList), pfList_(pfList) { }
: LiftedSolver(pfList) { }
Params solveQuery (const Grounds&);

View File

@ -10,7 +10,6 @@ ParfactorList::ParfactorList (const ParfactorList& pfList)
addShattered (new Parfactor (**it));
++ it;
}
}
@ -126,6 +125,27 @@ ParfactorList::print (void) const
ParfactorList&
ParfactorList::operator= (const ParfactorList& pfList)
{
if (this != &pfList) {
ParfactorList::const_iterator it0 = pfList_.begin();
while (it0 != pfList_.end()) {
delete *it0;
++ it0;
}
pfList_.clear();
ParfactorList::const_iterator it = pfList.begin();
while (it != pfList.end()) {
addShattered (new Parfactor (**it));
++ it;
}
}
return *this;
}
bool
ParfactorList::isShattered (const Parfactor* g) const
{

View File

@ -57,6 +57,8 @@ class ParfactorList
void print (void) const;
ParfactorList& operator= (const ParfactorList& pfList);
private:
bool isShattered (const Parfactor*) const;