| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ClusterTree.h | 
					
						
							|  |  |  |  * Created on: July 13, 2010 | 
					
						
							|  |  |  |  * @author Kai Ni | 
					
						
							|  |  |  |  * @author Frank Dellaert | 
					
						
							|  |  |  |  * @brief: Collects factorgraph fragments defined on variable clusters, arranged in a tree | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/shared_ptr.hpp>
 | 
					
						
							| 
									
										
										
										
											2010-07-14 20:41:22 +08:00
										 |  |  | #include "Ordering.h"
 | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * A cluster-tree is associated with a factor graph and is defined as in Koller-Friedman: | 
					
						
							|  |  |  | 	 * each node k represents a subset C_k \sub X, and the tree is family preserving, in that | 
					
						
							|  |  |  | 	 * each factor f_i is associated with a single cluster and scope(f_i) \sub C_k. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 	template <class FG> | 
					
						
							|  |  |  | 	class ClusterTree : public Testable<ClusterTree<FG> > { | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-15 07:48:51 +08:00
										 |  |  | 	protected: | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 		// the class for subgraphs that also include the pointers to the parents and two children
 | 
					
						
							| 
									
										
										
										
											2010-07-14 20:41:22 +08:00
										 |  |  | 		struct Cluster : public FG { | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			typedef typename boost::shared_ptr<Cluster> shared_ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			Ordering frontal_;                   // the frontal variables
 | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 			Unordered separator_;                // the separator variables
 | 
					
						
							| 
									
										
										
										
											2010-07-15 07:48:51 +08:00
										 |  |  | 			shared_ptr parent_;                  // the parent cluster
 | 
					
						
							|  |  |  | 			std::vector<shared_ptr> children_;   // the child clusters
 | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-15 07:48:51 +08:00
										 |  |  | 			// Construct empty clique
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 			Cluster() {} | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-15 07:48:51 +08:00
										 |  |  | 			/* Create a node with a single frontal variable */ | 
					
						
							|  |  |  | 			Cluster(const FG& fg, const Symbol& key); | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			// print the object
 | 
					
						
							|  |  |  | 			void print(const std::string& indent) const; | 
					
						
							|  |  |  | 			void printTree(const std::string& indent) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// check equality
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 			bool equals(const Cluster& other) const; | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 		}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 		// typedef for shared pointers to clusters
 | 
					
						
							|  |  |  | 		typedef typename Cluster::shared_ptr sharedCluster; | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 		// Root cluster
 | 
					
						
							|  |  |  | 		sharedCluster root_; | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							| 
									
										
										
										
											2010-07-15 07:48:51 +08:00
										 |  |  | 		// constructor of empty tree
 | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 		ClusterTree() {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 		// return the root cluster
 | 
					
						
							|  |  |  | 		sharedCluster root() const { return root_; } | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		// print the object
 | 
					
						
							|  |  |  | 		void print(const std::string& str) const { | 
					
						
							| 
									
										
										
										
											2010-07-14 12:32:58 +08:00
										 |  |  | 			std::cout << str << std::endl; | 
					
						
							| 
									
										
										
										
											2010-07-14 06:03:18 +08:00
										 |  |  | 			if (root_.get()) root_->printTree(""); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** check equality */ | 
					
						
							|  |  |  | 		bool equals(const ClusterTree<FG>& other, double tol = 1e-9) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	}; // ClusterTree
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace gtsam
 |