| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    Conditional.h | 
					
						
							|  |  |  |  * @brief   Base class for conditional densities | 
					
						
							|  |  |  |  * @author  Frank Dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/utility.hpp> // for noncopyable
 | 
					
						
							| 
									
										
										
										
											2010-08-27 23:31:20 +08:00
										 |  |  | //#include <boost/serialization/string.hpp>
 | 
					
						
							|  |  |  | //#include <boost/serialization/access.hpp>
 | 
					
						
							|  |  |  | //#include <boost/serialization/nvp.hpp>
 | 
					
						
							| 
									
										
										
										
											2010-08-20 01:23:19 +08:00
										 |  |  | #include <gtsam/base/Testable.h>
 | 
					
						
							|  |  |  | #include <gtsam/inference/Key.h>
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Base class for conditional densities | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * We make it noncopyable so we enforce the fact that factors are | 
					
						
							|  |  |  |  * kept in pointer containers. To be safe, you should make them | 
					
						
							|  |  |  |  * immutable, i.e., practicing functional programming. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class Conditional: boost::noncopyable, public Testable<Conditional> { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** key of random variable */ | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  |   Symbol key_; | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:55:07 +08:00
										 |  |  | 	/** empty constructor for serialization */ | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	Conditional() {} | 
					
						
							| 
									
										
										
										
											2009-11-10 22:55:07 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/** constructor */ | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	Conditional(const Symbol& key) : key_(key) {} | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/* destructor */ | 
					
						
							|  |  |  | 	virtual ~Conditional() { | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/** check equality */ | 
					
						
							|  |  |  | 	bool equals(const Conditional& c, double tol = 1e-9) const { | 
					
						
							|  |  |  | 		return key_ == c.key_; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/** return key */ | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	inline const Symbol& key() const { | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 		return key_; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/** return parent keys */ | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	virtual std::list<Symbol> parents() const = 0; | 
					
						
							| 
									
										
										
										
											2009-11-08 03:31:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 	/** return the number of parents */ | 
					
						
							|  |  |  | 	virtual std::size_t nrParents() const = 0; | 
					
						
							| 
									
										
										
										
											2009-11-08 03:31:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | private: | 
					
						
							|  |  |  | 	/** Serialization function */ | 
					
						
							|  |  |  | 	friend class boost::serialization::access; | 
					
						
							|  |  |  | 	template<class Archive> | 
					
						
							|  |  |  | 	void serialize(Archive & ar, const unsigned int version) { | 
					
						
							|  |  |  | 		ar & BOOST_SERIALIZATION_NVP(key_); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2009-11-08 03:31:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | // predicate to check whether a conditional has the sought key
 | 
					
						
							|  |  |  | template<class Conditional> | 
					
						
							|  |  |  | class onKey { | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	const Symbol& key_; | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	onKey(const Symbol& key) : | 
					
						
							| 
									
										
										
										
											2009-11-10 22:44:53 +08:00
										 |  |  | 		key_(key) { | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	bool operator()(const typename Conditional::shared_ptr& conditional) { | 
					
						
							|  |  |  | 		return (conditional->key() == key_); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | } |