| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  | #ifndef HORUS_LIFTEDUTILS_H
 | 
					
						
							|  |  |  | #define HORUS_LIFTEDUTILS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2012-12-27 12:54:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  | #include <vector>
 | 
					
						
							|  |  |  | #include <unordered_map>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "TinySet.h"
 | 
					
						
							|  |  |  | #include "Util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace std; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Symbol | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     Symbol (void) : id_(Util::maxUnsigned()) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Symbol (unsigned id) : id_(id) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     operator unsigned (void) const { return id_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool valid (void) const { return id_ != Util::maxUnsigned(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static Symbol invalid (void) { return Symbol(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     friend ostream& operator<< (ostream &os, const Symbol& s); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     unsigned id_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LogVar | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     LogVar (void) : id_(Util::maxUnsigned()) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LogVar (unsigned id) : id_(id) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     operator unsigned (void) const  { return id_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LogVar& operator++ (void) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       assert (valid()); | 
					
						
							|  |  |  |       id_ ++; | 
					
						
							|  |  |  |       return *this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool valid (void) const | 
					
						
							| 
									
										
										
										
											2012-12-20 23:19:10 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  |       return id_ != Util::maxUnsigned(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     friend ostream& operator<< (ostream &os, const LogVar& X); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     unsigned id_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace std { | 
					
						
							|  |  |  | template <> struct hash<Symbol> { | 
					
						
							|  |  |  |   size_t operator() (const Symbol& s) const { | 
					
						
							|  |  |  |     return std::hash<unsigned>() (s); | 
					
						
							|  |  |  |   }}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | template <> struct hash<LogVar> { | 
					
						
							|  |  |  |   size_t operator() (const LogVar& X) const { | 
					
						
							|  |  |  |     return std::hash<unsigned>() (X); | 
					
						
							|  |  |  |   }}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef vector<Symbol>   Symbols; | 
					
						
							|  |  |  | typedef vector<Symbol>   Tuple; | 
					
						
							|  |  |  | typedef vector<Tuple>    Tuples; | 
					
						
							|  |  |  | typedef vector<LogVar>   LogVars; | 
					
						
							|  |  |  | typedef TinySet<Symbol>  SymbolSet; | 
					
						
							|  |  |  | typedef TinySet<LogVar>  LogVarSet; | 
					
						
							|  |  |  | typedef TinySet<Tuple>   TupleSet; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ostream& operator<< (ostream &os, const Tuple& t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace LiftedUtils { | 
					
						
							|  |  |  | Symbol getSymbol (const string&); | 
					
						
							|  |  |  | void  printSymbolDictionary (void); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Ground | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     Ground (Symbol f) : functor_(f) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Ground (Symbol f, const Symbols& args) : functor_(f), args_(args) { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Symbol functor (void) const { return functor_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Symbols args (void) const { return args_; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-24 22:55:20 +01:00
										 |  |  |     size_t arity (void) const { return args_.size(); } | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-27 12:54:58 +00:00
										 |  |  |     bool isAtom (void) const { return args_.empty(); } | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     friend ostream& operator<< (ostream &os, const Ground& gr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     Symbol   functor_; | 
					
						
							|  |  |  |     Symbols  args_; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef vector<Ground> Grounds; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Substitution | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     void add (LogVar X_old, LogVar X_new) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       assert (Util::contains (subs_, X_old) == false); | 
					
						
							|  |  |  |       subs_.insert (make_pair (X_old, X_new)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void rename (LogVar X_old, LogVar X_new) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       assert (Util::contains (subs_, X_old)); | 
					
						
							|  |  |  |       subs_.find (X_old)->second = X_new; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LogVar newNameFor (LogVar X) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       unordered_map<LogVar, LogVar>::const_iterator it; | 
					
						
							|  |  |  |       it = subs_.find (X); | 
					
						
							|  |  |  |       if (it != subs_.end()) { | 
					
						
							|  |  |  |         return subs_.find (X)->second; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return X; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-20 23:19:10 +00:00
										 |  |  |     bool containsReplacementFor (LogVar X) const | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |       return Util::contains (subs_, X); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-12-17 18:39:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-24 22:55:20 +01:00
										 |  |  |     size_t nrReplacements (void) const { return subs_.size(); } | 
					
						
							| 
									
										
										
										
											2012-05-23 14:56:01 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     LogVars getDiscardedLogVars (void) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     friend ostream& operator<< (ostream &os, const Substitution& theta); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     unordered_map<LogVar, LogVar> subs_; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // HORUS_LIFTEDUTILS_H
 | 
					
						
							|  |  |  | 
 |