| 
									
										
										
										
											2010-10-14 12:54:38 +08:00
										 |  |  | /* ----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * GTSAM Copyright 2010, Georgia Tech Research Corporation,  | 
					
						
							|  |  |  |  * Atlanta, Georgia 30332-0415 | 
					
						
							|  |  |  |  * All Rights Reserved | 
					
						
							|  |  |  |  * Authors: Frank Dellaert, et al. (see THANKS for the full author list) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * See LICENSE for the license information | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * -------------------------------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  |  * @file   BayesNet-inl.h | 
					
						
							| 
									
										
										
										
											2009-11-12 12:56:30 +08:00
										 |  |  |  * @brief  Bayes net template definitions | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  |  * @author Frank Dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-08 07:00:03 +08:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | #include <gtsam/inference/BayesNet.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | #include <iostream>
 | 
					
						
							| 
									
										
										
										
											2010-02-10 06:59:18 +08:00
										 |  |  | #include <fstream>
 | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | #include <boost/foreach.hpp>
 | 
					
						
							|  |  |  | #include <boost/tuple/tuple.hpp>
 | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | #include <boost/format.hpp>
 | 
					
						
							|  |  |  | #include <boost/lambda/bind.hpp>
 | 
					
						
							|  |  |  | #include <boost/lambda/lambda.hpp>
 | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | #include <boost/assign/std/vector.hpp> // for +=
 | 
					
						
							|  |  |  | using namespace boost::assign; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | using namespace std; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	void BayesNet<CONDITIONAL>::print(const string& s) const { | 
					
						
							| 
									
										
										
										
											2009-10-30 11:48:32 +08:00
										 |  |  | 		cout << s << ":\n"; | 
					
						
							| 
									
										
										
										
											2009-12-20 19:56:33 +08:00
										 |  |  | 		BOOST_REVERSE_FOREACH(sharedConditional conditional,conditionals_) | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 			conditional->print((boost::format("Node[%1%]") % conditional->key()).str()); | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	bool BayesNet<CONDITIONAL>::equals(const BayesNet& cbn, double tol) const { | 
					
						
							| 
									
										
										
										
											2009-10-31 23:24:22 +08:00
										 |  |  | 		if(size() != cbn.size()) return false; | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 		return equal(conditionals_.begin(),conditionals_.end(),cbn.conditionals_.begin(),equals_star<CONDITIONAL>(tol)); | 
					
						
							| 
									
										
										
										
											2009-10-30 12:54:11 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  |   /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  |   template<class CONDITIONAL> | 
					
						
							|  |  |  | 	void BayesNet<CONDITIONAL>::permuteWithInverse(const Permutation& inversePermutation) { | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  |     BOOST_FOREACH(sharedConditional conditional, conditionals_) { | 
					
						
							|  |  |  |       conditional->permuteWithInverse(inversePermutation); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  |   template<class CONDITIONAL> | 
					
						
							|  |  |  |   bool BayesNet<CONDITIONAL>::permuteSeparatorWithInverse(const Permutation& inversePermutation) { | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  |     bool separatorChanged = false; | 
					
						
							|  |  |  |     BOOST_FOREACH(sharedConditional conditional, conditionals_) { | 
					
						
							|  |  |  |       if(conditional->permuteSeparatorWithInverse(inversePermutation)) | 
					
						
							|  |  |  |         separatorChanged = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return separatorChanged; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-09 06:50:26 +08:00
										 |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	void BayesNet<CONDITIONAL>::push_back(const BayesNet<CONDITIONAL> bn) { | 
					
						
							| 
									
										
										
										
											2009-11-09 06:50:26 +08:00
										 |  |  | 		BOOST_FOREACH(sharedConditional conditional,bn.conditionals_) | 
					
						
							|  |  |  | 			push_back(conditional); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	void BayesNet<CONDITIONAL>::push_front(const BayesNet<CONDITIONAL> bn) { | 
					
						
							| 
									
										
										
										
											2009-11-09 06:50:26 +08:00
										 |  |  | 		BOOST_FOREACH(sharedConditional conditional,bn.conditionals_) | 
					
						
							|  |  |  | 			push_front(conditional); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	list<Index> BayesNet<CONDITIONAL>::ordering() const { | 
					
						
							| 
									
										
										
										
											2010-10-12 05:14:35 +08:00
										 |  |  | 		list<Index> ord; | 
					
						
							| 
									
										
										
										
											2009-11-08 03:31:39 +08:00
										 |  |  | 		BOOST_FOREACH(sharedConditional conditional,conditionals_) | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 		   ord.push_back(conditional->key()); | 
					
						
							|  |  |  | 		return ord; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 06:59:18 +08:00
										 |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	void BayesNet<CONDITIONAL>::saveGraph(const std::string &s) const { | 
					
						
							| 
									
										
										
										
											2010-02-10 06:59:18 +08:00
										 |  |  | 		ofstream of(s.c_str()); | 
					
						
							|  |  |  | 		of<< "digraph G{\n"; | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 		BOOST_FOREACH(const_sharedConditional conditional,conditionals_) { | 
					
						
							| 
									
										
										
										
											2010-10-12 05:14:35 +08:00
										 |  |  | 			Index child = conditional->key(); | 
					
						
							|  |  |  | 			BOOST_FOREACH(Index parent, conditional->parents()) { | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 				of << parent << "->" << child << endl; | 
					
						
							| 
									
										
										
										
											2010-02-10 06:59:18 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		of<<"}"; | 
					
						
							|  |  |  | 		of.close(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-11-03 14:29:56 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-18 01:47:16 +08:00
										 |  |  | 	template<class CONDITIONAL> | 
					
						
							|  |  |  | 	typename BayesNet<CONDITIONAL>::sharedConditional | 
					
						
							|  |  |  | 	BayesNet<CONDITIONAL>::operator[](Index key) const { | 
					
						
							|  |  |  | 		const_iterator it = find_if(conditionals_.begin(), conditionals_.end(), boost::lambda::bind(&CONDITIONAL::key, *boost::lambda::_1) == key); | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 		if (it == conditionals_.end()) throw(invalid_argument((boost::format( | 
					
						
							|  |  |  | 						"BayesNet::operator['%1%']: not found") % key).str())); | 
					
						
							| 
									
										
										
										
											2009-11-03 14:29:56 +08:00
										 |  |  | 		return *it; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-09 06:50:26 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-10-28 10:57:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | } // namespace gtsam
 |