2013-02-07 17:50:02 +00:00
|
|
|
#ifndef YAP_PACKAGES_CLPBN_HORUS_CONSTRAINTTREE_H_
|
|
|
|
#define YAP_PACKAGES_CLPBN_HORUS_CONSTRAINTTREE_H_
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
#include <cassert>
|
|
|
|
|
2013-02-07 20:09:10 +00:00
|
|
|
#include <vector>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <string>
|
|
|
|
#include <ostream>
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
#include "TinySet.h"
|
|
|
|
#include "LiftedUtils.h"
|
|
|
|
|
|
|
|
|
2013-02-08 21:12:46 +00:00
|
|
|
namespace Horus {
|
2013-02-07 23:53:13 +00:00
|
|
|
|
2012-05-23 14:56:01 +01:00
|
|
|
class CTNode;
|
|
|
|
class ConstraintTree;
|
2013-02-07 22:37:45 +00:00
|
|
|
|
|
|
|
|
2013-02-08 01:11:18 +00:00
|
|
|
typedef std::vector<CTNode*> CTNodes;
|
|
|
|
typedef std::vector<ConstraintTree*> ConstraintTrees;
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
|
2013-02-13 14:26:47 +00:00
|
|
|
class CTNode {
|
2012-05-23 14:56:01 +01:00
|
|
|
private:
|
2013-02-07 22:37:45 +00:00
|
|
|
struct CmpSymbol {
|
|
|
|
bool operator() (const CTNode* n1, const CTNode* n2) const {
|
|
|
|
return n1->symbol() < n2->symbol();
|
|
|
|
}};
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
public:
|
2013-02-07 22:37:45 +00:00
|
|
|
typedef TinySet<CTNode*, CmpSymbol> CTChilds;
|
|
|
|
|
|
|
|
CTNode (const CTNode& n, const CTChilds& chs = CTChilds())
|
2012-05-23 14:56:01 +01:00
|
|
|
: symbol_(n.symbol()), childs_(chs), level_(n.level()) { }
|
|
|
|
|
2013-02-07 22:37:45 +00:00
|
|
|
CTNode (Symbol s, unsigned l, const CTChilds& chs = CTChilds())
|
2012-05-23 14:56:01 +01:00
|
|
|
: symbol_(s), childs_(chs), level_(l) { }
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
unsigned level() const { return level_; }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
void setLevel (unsigned level) { level_ = level; }
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
Symbol symbol() const { return symbol_; }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-13 23:47:00 +00:00
|
|
|
void setSymbol (Symbol s) { symbol_ = s; }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
CTChilds& childs() { return childs_; }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
const CTChilds& childs() const { return childs_; }
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
size_t nrChilds() const { return childs_.size(); }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
bool isRoot() const { return level_ == 0; }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
bool isLeaf() const { return childs_.empty(); }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-07 22:37:45 +00:00
|
|
|
CTChilds::iterator findSymbol (Symbol symb);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
void mergeSubtree (CTNode*, bool = true);
|
|
|
|
|
|
|
|
void removeChild (CTNode*);
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
void removeChilds();
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
void removeAndDeleteChild (CTNode*);
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
void removeAndDeleteAllChilds();
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
SymbolSet childSymbols() const;
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
static CTNode* copySubtree (const CTNode*);
|
|
|
|
|
|
|
|
static void deleteSubtree (CTNode*);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void updateChildLevels (CTNode*, unsigned);
|
|
|
|
|
2012-12-27 22:25:45 +00:00
|
|
|
Symbol symbol_;
|
2013-02-16 16:17:14 +00:00
|
|
|
CTChilds childs_;
|
2012-12-27 22:25:45 +00:00
|
|
|
unsigned level_;
|
|
|
|
|
|
|
|
DISALLOW_ASSIGN (CTNode);
|
2012-05-23 14:56:01 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-02-07 22:37:45 +00:00
|
|
|
typedef CTNode::CTChilds CTChilds;
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
|
2013-02-06 00:24:02 +00:00
|
|
|
inline CTChilds::iterator
|
|
|
|
CTNode::findSymbol (Symbol symb)
|
|
|
|
{
|
|
|
|
CTNode tmp (symb, 0);
|
|
|
|
return childs_.find (&tmp);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-02-07 22:37:45 +00:00
|
|
|
std::ostream& operator<< (std::ostream&, const CTNode&);
|
2013-02-06 00:24:02 +00:00
|
|
|
|
|
|
|
|
2013-02-13 14:26:47 +00:00
|
|
|
class ConstraintTree {
|
2012-05-23 14:56:01 +01:00
|
|
|
public:
|
|
|
|
ConstraintTree (unsigned);
|
|
|
|
|
|
|
|
ConstraintTree (const LogVars&);
|
|
|
|
|
|
|
|
ConstraintTree (const LogVars&, const Tuples&);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2013-02-07 13:37:15 +00:00
|
|
|
ConstraintTree (std::vector<std::vector<std::string>> names);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
ConstraintTree (const ConstraintTree&);
|
|
|
|
|
2013-02-06 00:24:02 +00:00
|
|
|
ConstraintTree (const CTChilds& rootChilds, const LogVars& logVars);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
~ConstraintTree();
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
CTNode* root() const { return root_; }
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
bool empty() const { return root_->childs().empty(); }
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
const LogVars& logVars() const;
|
2012-05-23 14:56:01 +01:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
const LogVarSet& logVarSet() const;
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
size_t nrLogVars() const;
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-05-23 14:56:01 +01:00
|
|
|
void addTuple (const Tuple&);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-05-23 14:56:01 +01:00
|
|
|
bool containsTuple (const Tuple&);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-05-23 14:56:01 +01:00
|
|
|
void moveToTop (const LogVars&);
|
|
|
|
|
|
|
|
void moveToBottom (const LogVars&);
|
|
|
|
|
|
|
|
void join (ConstraintTree*, bool oneTwoOne = false);
|
|
|
|
|
|
|
|
unsigned getLevel (LogVar) const;
|
|
|
|
|
|
|
|
void rename (LogVar, LogVar);
|
|
|
|
|
|
|
|
void applySubstitution (const Substitution&);
|
|
|
|
|
|
|
|
void project (const LogVarSet&);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-10-29 21:37:58 +00:00
|
|
|
ConstraintTree projectedCopy (const LogVarSet&);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
void remove (const LogVarSet&);
|
|
|
|
|
|
|
|
bool isSingleton (LogVar);
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
LogVarSet singletons();
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
TupleSet tupleSet (unsigned = 0) const;
|
|
|
|
|
|
|
|
TupleSet tupleSet (const LogVars&);
|
|
|
|
|
2013-02-28 19:45:37 +00:00
|
|
|
unsigned size() const;
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
unsigned nrSymbols (LogVar);
|
|
|
|
|
|
|
|
void exportToGraphViz (const char*, bool = false) const;
|
|
|
|
|
|
|
|
bool isCountNormalized (const LogVarSet&);
|
|
|
|
|
|
|
|
unsigned getConditionalCount (const LogVarSet&);
|
|
|
|
|
|
|
|
TinySet<unsigned> getConditionalCounts (const LogVarSet&);
|
|
|
|
|
|
|
|
bool isCartesianProduct (const LogVarSet&);
|
|
|
|
|
|
|
|
std::pair<ConstraintTree*, ConstraintTree*> split (const Tuple&);
|
|
|
|
|
|
|
|
std::pair<ConstraintTree*, ConstraintTree*> split (
|
|
|
|
const LogVars&, ConstraintTree*, const LogVars&);
|
|
|
|
|
|
|
|
ConstraintTrees countNormalize (const LogVarSet&);
|
|
|
|
|
|
|
|
ConstraintTrees jointCountNormalize (
|
|
|
|
ConstraintTree*, ConstraintTree*, LogVar, LogVar, LogVar);
|
|
|
|
|
|
|
|
LogVars expand (LogVar);
|
|
|
|
|
|
|
|
ConstraintTrees ground (LogVar);
|
|
|
|
|
2012-12-18 23:51:51 +00:00
|
|
|
void cloneLogVar (LogVar, LogVar);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-10-30 00:15:40 +00:00
|
|
|
ConstraintTree& operator= (const ConstraintTree& ct);
|
2012-12-17 18:39:42 +00:00
|
|
|
|
2012-05-23 14:56:01 +01:00
|
|
|
private:
|
|
|
|
unsigned countTuples (const CTNode*) const;
|
|
|
|
|
|
|
|
CTNodes getNodesBelow (CTNode*) const;
|
|
|
|
|
|
|
|
CTNodes getNodesAtLevel (unsigned) const;
|
|
|
|
|
|
|
|
unsigned nrNodes (const CTNode* n) const;
|
|
|
|
|
|
|
|
void appendOnBottom (CTNode* n1, const CTChilds&);
|
|
|
|
|
|
|
|
void swapLogVar (LogVar);
|
|
|
|
|
2012-05-24 22:55:20 +01:00
|
|
|
bool join (CTNode*, const Tuple&, size_t, CTNode*);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
void getTuples (CTNode*, Tuples, unsigned, Tuples&, CTNodes&) const;
|
|
|
|
|
2013-02-07 13:37:15 +00:00
|
|
|
std::vector<std::pair<CTNode*, unsigned>> countNormalize (
|
2012-05-23 14:56:01 +01:00
|
|
|
const CTNode*, unsigned);
|
|
|
|
|
2013-02-13 14:26:47 +00:00
|
|
|
static void split (CTNode*, CTNode*, CTChilds&, CTChilds&, unsigned);
|
2012-05-23 14:56:01 +01:00
|
|
|
|
|
|
|
CTNode* root_;
|
|
|
|
LogVars logVars_;
|
|
|
|
LogVarSet logVarSet_;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-02-06 00:24:02 +00:00
|
|
|
|
|
|
|
inline const LogVars&
|
2013-02-28 19:45:37 +00:00
|
|
|
ConstraintTree::logVars() const
|
2013-02-06 00:24:02 +00:00
|
|
|
{
|
|
|
|
assert (LogVarSet (logVars_) == logVarSet_);
|
|
|
|
return logVars_;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inline const LogVarSet&
|
2013-02-28 19:45:37 +00:00
|
|
|
ConstraintTree::logVarSet() const
|
2013-02-06 00:24:02 +00:00
|
|
|
{
|
|
|
|
assert (LogVarSet (logVars_) == logVarSet_);
|
|
|
|
return logVarSet_;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inline size_t
|
2013-02-28 19:45:37 +00:00
|
|
|
ConstraintTree::nrLogVars() const
|
2013-02-06 00:24:02 +00:00
|
|
|
{
|
|
|
|
assert (LogVarSet (logVars_) == logVarSet_);
|
2013-02-13 23:47:00 +00:00
|
|
|
return logVars_.size();
|
2013-02-06 00:24:02 +00:00
|
|
|
}
|
|
|
|
|
2013-02-08 21:12:46 +00:00
|
|
|
} // namespace Horus
|
2013-02-07 23:53:13 +00:00
|
|
|
|
2013-02-08 00:20:01 +00:00
|
|
|
#endif // YAP_PACKAGES_CLPBN_HORUS_CONSTRAINTTREE_H_
|
2012-05-23 14:56:01 +01:00
|
|
|
|