00001
00002
00003
00004
00005
00006
00007
00008
00009
00010 #ifndef PATHFIND_SEARCH_H
00011 #define PATHFIND_SEARCH_H
00012
00013 #include <list>
00014 #include <queue>
00015 #include "environment.h"
00016 #include "statistics.h"
00017
00018
00019
00020 namespace PathFind
00021 {
00022 using namespace std;
00023
00024 static const int NO_NODE = -1;
00025
00026
00027 class Search
00028 {
00029 public:
00030 Search();
00031
00032 virtual ~Search();
00033
00034
00035
00036
00037
00038
00039
00040 virtual StatisticsCollection createStatistics() = 0;
00041
00042
00043
00044
00045 virtual bool findPath(const Environment& env, int start,
00046 int target) = 0;
00047
00048 long long int getNodesLimit() const
00049 {
00050 return m_nodesLimit;
00051 }
00052
00053 virtual const vector<int>& getPath() const = 0;
00054
00055
00056
00057
00058
00059
00060 virtual const vector<char>& getVisitedNodes() const = 0;
00061
00062
00063 virtual const StatisticsCollection& getStatistics() const = 0;
00064
00065
00066
00067
00068
00069
00070
00071 void setNodesLimit(long long int nodesLimit)
00072 {
00073 m_nodesLimit = nodesLimit;
00074 }
00075
00076
00077 public:
00078 long long int m_nodesLimit;
00079 };
00080 }
00081
00082
00083
00084 #endif