| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  | #ifndef HORUS_WEIGHTEDBP_H
 | 
					
						
							|  |  |  | #define HORUS_WEIGHTEDBP_H
 | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  | #include "BeliefProp.h"
 | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | class WeightedLink : public BpLink | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     WeightedLink (FacNode* fn, VarNode* vn, size_t idx, unsigned weight)  | 
					
						
							|  |  |  |         : BpLink (fn, vn), index_(idx), weight_(weight), | 
					
						
							|  |  |  |           pwdMsg_(vn->range(), LogAware::one()) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     size_t index (void) const { return index_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     unsigned weight (void) const { return weight_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const Params& powMessage (void) const { return pwdMsg_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void updateMessage (void)  | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       pwdMsg_ = *nextMsg_; | 
					
						
							|  |  |  |       swap (currMsg_, nextMsg_); | 
					
						
							|  |  |  |       LogAware::pow (pwdMsg_, weight_); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     size_t    index_; | 
					
						
							|  |  |  |     unsigned  weight_; | 
					
						
							|  |  |  |     Params    pwdMsg_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  | class WeightedBp : public BeliefProp | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  | { | 
					
						
							|  |  |  |   public:    | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  |     WeightedBp (const FactorGraph& fg, | 
					
						
							| 
									
										
										
										
											2012-05-31 23:06:53 +01:00
										 |  |  |         const vector<vector<unsigned>>& weights) | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  |       : BeliefProp (fg), weights_(weights) { } | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  |    ~WeightedBp (void); | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  |    | 
					
						
							|  |  |  |     Params getPosterioriOf (VarId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      void createLinks (void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      void maxResidualSchedule (void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      void calcFactorToVarMsg (BpLink*); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      Params getVarToFactorMsg (const BpLink*) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      void printLinkInformation (void) const; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |      vector<vector<unsigned>> weights_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 16:29:57 +01:00
										 |  |  | #endif // HORUS_WEIGHTEDBP_H
 | 
					
						
							| 
									
										
										
										
											2012-05-31 21:24:15 +01:00
										 |  |  | 
 |