#ifndef YAP_PACKAGES_CLPBN_HORUS_LIFTEDWCNF_H_ #define YAP_PACKAGES_CLPBN_HORUS_LIFTEDWCNF_H_ #include #include #include #include #include "ConstraintTree.h" #include "ProbFormula.h" #include "LiftedUtils.h" namespace Horus { class ParfactorList; enum LogVarType { fullLvt, posLvt, negLvt }; typedef long LiteralId; typedef std::vector LogVarTypes; class Literal { public: Literal (LiteralId lid, const LogVars& lvs) : lid_(lid), logVars_(lvs), negated_(false) { } Literal (const Literal& lit, bool negated) : lid_(lit.lid_), logVars_(lit.logVars_), negated_(negated) { } LiteralId lid (void) const { return lid_; } LogVars logVars (void) const { return logVars_; } size_t nrLogVars (void) const { return logVars_.size(); } LogVarSet logVarSet (void) const { return LogVarSet (logVars_); } void complement (void) { negated_ = !negated_; } bool isPositive (void) const { return negated_ == false; } bool isNegative (void) const { return negated_; } bool isGround (ConstraintTree constr, const LogVarSet& ipgLogVars) const; size_t indexOfLogVar (LogVar X) const; std::string toString ( LogVarSet ipgLogVars = LogVarSet(), LogVarSet posCountedLvs = LogVarSet(), LogVarSet negCountedLvs = LogVarSet()) const; private: friend std::ostream& operator<< (std::ostream&, const Literal&); LiteralId lid_; LogVars logVars_; bool negated_; }; typedef std::vector Literals; class Clause { public: Clause (const ConstraintTree& ct = ConstraintTree({})) : constr_(ct) { } Clause (std::vector> names) : constr_(ConstraintTree (names)) { } void addLiteral (const Literal& l) { literals_.push_back (l); } const Literals& literals (void) const { return literals_; } Literals& literals (void) { return literals_; } size_t nrLiterals (void) const { return literals_.size(); } const ConstraintTree& constr (void) const { return constr_; } ConstraintTree constr (void) { return constr_; } bool isUnit (void) const { return literals_.size() == 1; } LogVarSet ipgLogVars (void) const { return ipgLvs_; } void addIpgLogVar (LogVar X) { ipgLvs_.insert (X); } void addPosCountedLogVar (LogVar X) { posCountedLvs_.insert (X); } void addNegCountedLogVar (LogVar X) { negCountedLvs_.insert (X); } LogVarSet posCountedLogVars (void) const { return posCountedLvs_; } LogVarSet negCountedLogVars (void) const { return negCountedLvs_; } unsigned nrPosCountedLogVars (void) const { return posCountedLvs_.size(); } unsigned nrNegCountedLogVars (void) const { return negCountedLvs_.size(); } void addLiteralComplemented (const Literal& lit); bool containsLiteral (LiteralId lid) const; bool containsPositiveLiteral (LiteralId lid, const LogVarTypes&) const; bool containsNegativeLiteral (LiteralId lid, const LogVarTypes&) const; void removeLiterals (LiteralId lid); void removePositiveLiterals (LiteralId lid, const LogVarTypes&); void removeNegativeLiterals (LiteralId lid, const LogVarTypes&); bool isCountedLogVar (LogVar X) const; bool isPositiveCountedLogVar (LogVar X) const; bool isNegativeCountedLogVar (LogVar X) const; bool isIpgLogVar (LogVar X) const; TinySet lidSet (void) const; LogVarSet ipgCandidates (void) const; LogVarTypes logVarTypes (size_t litIdx) const; void removeLiteral (size_t litIdx); static bool independentClauses (Clause& c1, Clause& c2); static std::vector copyClauses ( const std::vector& clauses); static void printClauses (const std::vector& clauses); static void deleteClauses (std::vector& clauses); private: LogVarSet getLogVarSetExcluding (size_t idx) const; friend std::ostream& operator<< (std::ostream&, const Clause&); Literals literals_; LogVarSet ipgLvs_; LogVarSet posCountedLvs_; LogVarSet negCountedLvs_; ConstraintTree constr_; DISALLOW_ASSIGN (Clause); }; typedef std::vector Clauses; class LitLvTypes { public: LitLvTypes (LiteralId lid, const LogVarTypes& lvTypes) : lid_(lid), lvTypes_(lvTypes) { } LiteralId lid (void) const { return lid_; } const LogVarTypes& logVarTypes (void) const { return lvTypes_; } void setAllFullLogVars (void); private: friend std::ostream& operator<< (std::ostream&, const LitLvTypes&); LiteralId lid_; LogVarTypes lvTypes_; }; struct CmpLitLvTypes { bool operator() ( const LitLvTypes& types1, const LitLvTypes& types2) const { if (types1.lid() < types2.lid()) { return true; } if (types1.lid() == types2.lid()){ return types1.logVarTypes() < types2.logVarTypes(); } return false; } }; typedef TinySet LitLvTypesSet; class LiftedWCNF { public: LiftedWCNF (const ParfactorList& pfList); ~LiftedWCNF (void); const Clauses& clauses (void) const { return clauses_; } void addWeight (LiteralId lid, double posW, double negW); double posWeight (LiteralId lid) const; double negWeight (LiteralId lid) const; std::vector prvGroupLiterals (PrvGroup prvGroup); Clause* createClause (LiteralId lid) const; void printFormulaIndicators (void) const; void printWeights (void) const; void printClauses (void) const; private: LiteralId getLiteralId (PrvGroup prvGroup, unsigned range); void addIndicatorClauses (const ParfactorList& pfList); void addParameterClauses (const ParfactorList& pfList); Clauses clauses_; LiteralId freeLiteralId_; const ParfactorList& pfList_; std::unordered_map> map_; std::unordered_map> weights_; DISALLOW_COPY_AND_ASSIGN (LiftedWCNF); }; } // namespace Horus #endif // YAP_PACKAGES_CLPBN_HORUS_LIFTEDWCNF_H_