00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #ifndef C_PRIORITZEDSWEEPING__H
00033 #define C_PRIORITZEDSWEEPING__H
00034
00035 #include "cdynamicprogramming.h"
00036 #include "cbaseobjects.h"
00037 #include "cagentlistener.h"
00038
00039 class CFeatureQFunction;
00040 class CStateModifier;
00041 class CAbstractFeatureStochasticModel;
00042 class CFeatureRewardFunction;
00043 class CFeatureVFunction;
00044 class CFeatureCalculator;
00045
00046
00047 #include <map>
00049
00059 class CPrioritizedSweeping : public CSemiMDPListener, public CValueIteration, public CStateObject
00060 {
00061 protected:
00063 int kSteps;
00064
00065 public:
00066
00071 CPrioritizedSweeping(CFeatureQFunction *qFunction, CStateModifier *discretizer, CAbstractFeatureStochasticModel *model, CFeatureRewardFunction *rewardFunction, int kSteps);
00072
00073 CPrioritizedSweeping(CFeatureVFunction *vFunction, CStateModifier *discretizer, CAbstractFeatureStochasticModel *model, CFeatureRewardFunction *rewardFunction, int kSteps);
00074
00075 virtual ~CPrioritizedSweeping();
00076
00078
00080 virtual void nextStep(CStateCollection *oldState, CAction *action, CStateCollection *newState);
00081
00082 CFeatureCalculator *getFeatureCalculator();
00083 };
00084
00085 #endif
00086