31struct ConstructorTraversalData {
32 typedef typename JunctionTree<BAYESTREE, GRAPH>::Node Node;
33 typedef typename JunctionTree<BAYESTREE, GRAPH>::sharedNode sharedNode;
35 ConstructorTraversalData*
const parentData;
36 sharedNode junctionTreeNode;
44 ConstructorTraversalData(ConstructorTraversalData* _parentData) :
45 parentData(_parentData) {
50 const boost::shared_ptr<ETREE_NODE>& node,
56 myData.junctionTreeNode =
57 boost::make_shared<Node>(node->key, node->factors);
58 parentData.junctionTreeNode->addChild(myData.junctionTreeNode);
63 static void ConstructorTraversalVisitorPostAlg2(
64 const boost::shared_ptr<ETREE_NODE>& ETreeNode,
65 const ConstructorTraversalData& myData) {
76 SymbolicFactors symbolicFactors;
77 symbolicFactors.reserve(
78 ETreeNode->factors.size() + myData.childSymbolicFactors.size());
80 symbolicFactors += ETreeNode->factors;
82 symbolicFactors += myData.childSymbolicFactors;
84 Ordering keyAsOrdering;
85 keyAsOrdering.push_back(ETreeNode->key);
88 boost::tie(myConditional, mySeparatorFactor) = internal::EliminateSymbolic(
89 symbolicFactors, keyAsOrdering);
92 myData.parentData->childSymbolicConditionals.push_back(myConditional);
93 myData.parentData->childSymbolicFactors.push_back(mySeparatorFactor);
95 sharedNode node = myData.junctionTreeNode;
96 const FastVector<SymbolicConditional::shared_ptr>& childConditionals =
97 myData.childSymbolicConditionals;
98 node->problemSize_ = (int) (myConditional->size() * symbolicFactors.size());
102 const size_t myNrParents = myConditional->nrParents();
103 const size_t nrChildren = node->nrChildren();
104 assert(childConditionals.size() == nrChildren);
107 std::vector<size_t> nrFrontals = node->nrFrontalsOfChildren();
108 std::vector<bool> merge(nrChildren,
false);
109 size_t myNrFrontals = 1;
110 for (
size_t i = 0;i<nrChildren;i++){
112 if (myNrParents + myNrFrontals == childConditionals[i]->nrParents()) {
114 myNrFrontals += nrFrontals[i];
120 node->mergeChildren(merge);
129 gttic(JunctionTree_FromEliminationTree);
143 rootData.junctionTreeNode = boost::make_shared<typename Base::Node>();
145 Data::ConstructorTraversalVisitorPre,
146 Data::ConstructorTraversalVisitorPostAlg2);
149 this->addChildrenAsRoots(rootData.junctionTreeNode);
std::vector< T, typename internal::FastDefaultVectorAllocator< T >::type > FastVector
FastVector is a type alias to a std::vector with a custom memory allocator.
Definition FastVector.h:33
void DepthFirstForest(FOREST &forest, DATA &rootData, VISITOR_PRE &visitorPre, VISITOR_POST &visitorPost)
Traverse a forest depth-first with pre-order and post-order visits.
Definition treeTraversal-inst.h:77
const FastVector< sharedFactor > & remainingFactors() const
Return the remaining factors that are not pulled into elimination.
Definition EliminationTree.h:154
JunctionTree(const EliminationTree< ETREE_BAYESNET, ETREE_GRAPH > &eliminationTree)
Build the junction tree from an elimination tree.
Definition JunctionTree-inst.h:127