| 
									
										
										
										
											2012-04-16 06:35:28 +08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * CSP.h | 
					
						
							|  |  |  |  * @brief Constraint Satisfaction Problem class | 
					
						
							|  |  |  |  * @date Feb 6, 2012 | 
					
						
							|  |  |  |  * @author Frank Dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | #include <gtsam/discrete/DiscreteFactorGraph.h>
 | 
					
						
							| 
									
										
										
										
											2012-05-15 08:47:19 +08:00
										 |  |  | #include <gtsam_unstable/discrete/AllDiff.h>
 | 
					
						
							|  |  |  | #include <gtsam_unstable/discrete/SingleValue.h>
 | 
					
						
							| 
									
										
										
										
											2012-04-16 06:35:28 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Constraint Satisfaction Problem class | 
					
						
							|  |  |  |  * A specialization of a DiscreteFactorGraph. | 
					
						
							|  |  |  |  * It knows about CSP-specific constraints and algorithms | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class GTSAM_UNSTABLE_EXPORT CSP : public DiscreteFactorGraph { | 
					
						
							|  |  |  |  public: | 
					
						
							|  |  |  |   /** A map from keys to values */ | 
					
						
							|  |  |  |   typedef Assignment<Key> Values; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  public: | 
					
						
							|  |  |  |   /// Add a unary constraint, allowing only a single value
 | 
					
						
							|  |  |  |   void addSingleValue(const DiscreteKey& dkey, size_t value) { | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |     emplace_shared<SingleValue>(dkey, value); | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /// Add a binary AllDiff constraint
 | 
					
						
							|  |  |  |   void addAllDiff(const DiscreteKey& key1, const DiscreteKey& key2) { | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |     emplace_shared<BinaryAllDiff>(key1, key2); | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /// Add a general AllDiff constraint
 | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |   void addAllDiff(const DiscreteKeys& dkeys) { emplace_shared<AllDiff>(dkeys); } | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   //    /** return product of all factors as a single factor */
 | 
					
						
							|  |  |  |   //    DecisionTreeFactor product() const {
 | 
					
						
							|  |  |  |   //      DecisionTreeFactor result;
 | 
					
						
							|  |  |  |   //      for(const sharedFactor& factor: *this)
 | 
					
						
							|  |  |  |   //        if (factor) result = (*factor) * result;
 | 
					
						
							|  |  |  |   //      return result;
 | 
					
						
							|  |  |  |   //    }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |   /// Find the best total assignment - can be expensive.
 | 
					
						
							| 
									
										
										
										
											2021-11-21 05:15:05 +08:00
										 |  |  |   Values optimalAssignment() const; | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |   /// Find the best total assignment, with given ordering - can be expensive.
 | 
					
						
							| 
									
										
										
										
											2021-11-21 05:15:05 +08:00
										 |  |  |   Values optimalAssignment(const Ordering& ordering) const; | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   //    /*
 | 
					
						
							|  |  |  |   //     * Perform loopy belief propagation
 | 
					
						
							|  |  |  |   //     * True belief propagation would check for each value in domain
 | 
					
						
							|  |  |  |   //     * whether any satisfying separator assignment can be found.
 | 
					
						
							|  |  |  |   //     * This corresponds to hyper-arc consistency in CSP speak.
 | 
					
						
							|  |  |  |   //     * This can be done by creating a mini-factor graph and search.
 | 
					
						
							|  |  |  |   //     * For a nine-by-nine Sudoku, the search tree will be 8+6+6=20 levels
 | 
					
						
							|  |  |  |   //     deep.
 | 
					
						
							|  |  |  |   //     * It will be very expensive to exclude values that way.
 | 
					
						
							|  |  |  |   //     */
 | 
					
						
							|  |  |  |   //     void applyBeliefPropagation(size_t nrIterations = 10) const;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*
 | 
					
						
							|  |  |  |    * Apply arc-consistency ~ Approximate loopy belief propagation | 
					
						
							|  |  |  |    * We need to give the domains to a constraint, and it returns | 
					
						
							|  |  |  |    * a domain whose values don't conflict in the arc-consistency way. | 
					
						
							| 
									
										
										
										
											2021-11-21 00:46:32 +08:00
										 |  |  |    * TODO: should get cardinality from DiscreteKeys | 
					
						
							| 
									
										
										
										
											2012-10-02 22:40:07 +08:00
										 |  |  |    */ | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  |   void runArcConsistency(size_t cardinality, size_t nrIterations = 10, | 
					
						
							|  |  |  |                          bool print = false) const; | 
					
						
							|  |  |  | };  // CSP
 | 
					
						
							| 
									
										
										
										
											2012-04-16 06:35:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-18 23:54:00 +08:00
										 |  |  | }  // namespace gtsam
 |