20 #include <boost/make_shared.hpp> 21 #include <boost/bind.hpp> 34 template<
class BAYESNET,
class GRAPH>
36 EliminationTree<BAYESNET,GRAPH>::Node::eliminate(
37 const boost::shared_ptr<BayesNetType>& output,
38 const Eliminate&
function,
const FastVector<sharedFactor>& childrenResults)
const 42 assert(childrenResults.size() ==
children.size());
48 gatheredFactors.push_back(childrenResults.begin(), childrenResults.end());
52 auto eliminationResult =
function(gatheredFactors, Ordering(keyAsVector));
55 output->push_back(eliminationResult.first);
58 return eliminationResult.second;
62 template<
class BAYESNET,
class GRAPH>
63 void EliminationTree<BAYESNET,GRAPH>::Node::print(
64 const std::string& str,
const KeyFormatter& keyFormatter)
const 66 std::cout << str <<
"(" << keyFormatter(key) <<
")\n";
71 std::cout << str <<
"null factor\n";
77 template<
class BAYESNET,
class GRAPH>
81 gttic(EliminationTree_Contructor);
85 const size_t m = graph.size();
86 const size_t n = order.size();
88 static const size_t none = std::numeric_limits<size_t>::max();
91 FastVector<sharedNode> nodes(n);
92 FastVector<size_t> parents(n, none);
93 FastVector<size_t> prevCol(m, none);
94 FastVector<bool> factorUsed(m,
false);
98 for (
size_t j = 0; j < n; j++)
101 const VariableIndex::Factors& factors = structure[order[j]];
102 const sharedNode node = boost::make_shared<Node>();
103 node->key = order[j];
106 node->children.reserve(factors.size());
107 node->factors.reserve(factors.size());
108 for(
const size_t i: factors) {
114 if (prevCol[i] != none) {
115 size_t k = prevCol[i];
119 while (parents[r] != none)
126 node->children.push_back(nodes[r]);
130 node->factors.push_back(graph[i]);
131 factorUsed[i] =
true;
137 }
catch(std::invalid_argument& e) {
141 throw std::invalid_argument(
"EliminationTree: given ordering contains variables that are not involved in the factor graph");
147 assert(parents.empty() || parents.back() == none);
148 for(
size_t j = 0; j < n; ++j)
149 if(parents[j] == none)
150 roots_.push_back(nodes[j]);
153 for(
size_t i = 0; i < m; ++i)
154 if(!factorUsed[i] && graph[i])
155 remainingFactors_.push_back(graph[i]);
159 template<
class BAYESNET,
class GRAPH>
166 This temp(factorGraph, variableIndex, order);
171 template<
class BAYESNET,
class GRAPH>
180 remainingFactors_ = other.remainingFactors_;
186 template<
class BAYESNET,
class GRAPH>
187 std::pair<boost::shared_ptr<BAYESNET>, boost::shared_ptr<GRAPH> >
190 gttic(EliminationTree_eliminate);
192 auto result = boost::make_shared<BayesNetType>();
195 FastVector<sharedFactor>
remainingFactors = inference::EliminateTree(result, *
this,
function);
198 auto allRemainingFactors = boost::make_shared<FactorGraphType>();
199 allRemainingFactors->push_back(remainingFactors_.begin(), remainingFactors_.end());
203 return std::make_pair(result, allRemainingFactors);
207 template<
class BAYESNET,
class GRAPH>
214 template<
class BAYESNET,
class GRAPH>
218 std::stack<sharedNode, FastVector<sharedNode> > stack1, stack2;
223 for(
const sharedNode& root: this->roots_) { keys.insert(std::make_pair(root->key, root)); }
225 for(
const Key_Node& key_node: keys) { stack1.push(key_node.second); }
229 for(
const sharedNode& root: expected.roots_) { keys.insert(std::make_pair(root->key, root)); }
231 for(
const Key_Node& key_node: keys) { stack2.push(key_node.second); }
235 while(!stack1.empty() && !stack2.empty()) {
243 if(node1->key != node2->key)
245 if(node1->factors.size() != node2->factors.size()) {
248 for(
typename Node::Factors::const_iterator it1 = node1->factors.begin(), it2 = node2->factors.begin();
249 it1 != node1->factors.end(); ++it1, ++it2)
252 if(!(*it1)->equals(**it2, tol))
254 }
else if((*it1 && !*it2) || (*it2 && !*it1)) {
263 for(
const sharedNode& node: node1->children) { keys.insert(std::make_pair(node->key, node)); }
265 for(
const Key_Node& key_node: keys) { stack1.push(key_node.second); }
269 for(
const sharedNode& node: node2->children) { keys.insert(std::make_pair(node->key, node)); }
271 for(
const Key_Node& key_node: keys) { stack2.push(key_node.second); }
276 if(!stack1.empty() || !stack2.empty())
283 template<
class BAYESNET,
class GRAPH>
285 roots_.swap(other.roots_);
286 remainingFactors_.swap(other.remainingFactors_);
bool equals(const This &other, double tol=1e-9) const
Test whether the tree is equal to another.
Definition: EliminationTree-inst.h:215
Factors factors
factors associated with root
Definition: EliminationTree.h:71
boost::shared_ptr< Node > sharedNode
Shared pointer to Node.
Definition: EliminationTree.h:80
The VariableIndex class computes and stores the block column structure of a factor graph.
Definition: VariableIndex.h:43
Variable ordering for the elimination algorithm.
A Linear Factor Graph is a factor graph where all factors are Gaussian, i.e.
Definition: GaussianFactorGraph.h:65
boost::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:33
FastVector< Key > KeyVector
Define collection type once and for all - also used in wrappers.
Definition: Key.h:56
EliminationTree()
Protected default constructor.
Definition: EliminationTree.h:161
void swap(This &other)
Swap the data of this tree with another one, this operation is very fast.
Definition: EliminationTree-inst.h:284
void PrintForest(const FOREST &forest, std::string str, const KeyFormatter &keyFormatter)
Print a tree, prefixing each line with str, and formatting keys using keyFormatter.
Definition: treeTraversal-inst.h:220
void print(const std::string &name="EliminationTree: ", const KeyFormatter &formatter=DefaultKeyFormatter) const
Print the tree to cout.
Definition: EliminationTree-inst.h:208
boost::shared_ptr< FactorType > sharedFactor
Shared pointer to a factor.
Definition: EliminationTree.h:60
Global functions in a separate testing namespace.
Definition: chartTesting.h:28
Contains generic inference algorithms that convert between templated graphical models,...
std::pair< boost::shared_ptr< BayesNetType >, boost::shared_ptr< FactorGraphType > > eliminate(Eliminate function) const
Eliminate the factors to a Bayes net and remaining factor graph.
Definition: EliminationTree-inst.h:188
const FastVector< sharedFactor > & remainingFactors() const
Return the remaining factors that are not pulled into elimination.
Definition: EliminationTree.h:154
GRAPH FactorGraphType
The factor graph type.
Definition: EliminationTree.h:58
Key key
key associated with root
Definition: EliminationTree.h:70
This & operator=(const This &other)
Assignment operator - makes a deep copy of the tree structure, but only pointers to factors are copie...
Definition: EliminationTree-inst.h:173
Definition: Ordering.h:34
FastVector< boost::shared_ptr< typename FOREST::Node > > CloneForest(const FOREST &forest)
Clone a tree, copy-constructing new nodes (calling boost::make_shared) and setting up child pointers ...
Definition: treeTraversal-inst.h:190
Children children
sub-trees
Definition: EliminationTree.h:72