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_ADAPTIVESOFTMAX__H
00033 #define C_ADAPTIVESOFTMAX__H
00034
00035 #include <stdio.h>
00036 #include <vector>
00037 #include <list>
00038 #include <map>
00039
00040 #include "clearndataobject.h"
00041 #include "cstatemodifier.h"
00042
00043 class CRBFBasisFunction;
00044
00045 class DataSubset;
00046 class CDataSet;
00047
00048 class CKDTree;
00049 class CKNearestNeighbors;
00050
00051 class CStateCollection;
00052 class CState;
00053 class CStateProperties;
00054
00055 class CRBFCenterNetwork : public CLearnDataObject
00056 {
00057 protected:
00058 int numDim;
00059
00060 std::vector<CRBFBasisFunction*> *centers;
00061
00062 virtual void initNetwork() {};
00063
00064 CRBFCenterNetwork(std::vector<CRBFBasisFunction *> *centers, int numDim);
00065 public:
00066
00067 CRBFCenterNetwork(int numDim);
00068
00069 virtual ~CRBFCenterNetwork();
00070
00071 virtual void getNearestNeigbors(ColumnVector *state, unsigned int K, DataSubset *subset) = 0;
00072
00073 virtual void saveData(FILE *stream);
00074 virtual void loadData(FILE *stream);
00075
00076 virtual void resetData() {};
00077
00078 CRBFBasisFunction *getCenter(int index);
00079 int getNumCenters();
00080
00081 virtual void deleteCenters();
00082
00083 int getNumDimensions();
00084 };
00085
00086 class CRBFCenterNetworkSimpleSearch : public CRBFCenterNetwork
00087 {
00088 protected:
00089 virtual void initNetwork() {};
00090
00091
00092 public:
00093 CRBFCenterNetworkSimpleSearch(int numDim);
00094
00095 virtual ~CRBFCenterNetworkSimpleSearch();
00096
00097
00098 virtual void getNearestNeigbors(ColumnVector *state, unsigned int K, DataSubset *subset);
00099 };
00100
00101 class CRBFCenterNetworkKDTree : public CRBFCenterNetwork
00102 {
00103 protected:
00104 CDataSet *dataset;
00105
00106 virtual void initNetwork();
00107
00108 unsigned int K;
00109
00110 CKDTree *tree;
00111 CKNearestNeighbors *nearestNeighbors;
00112 public:
00113 CRBFCenterNetworkKDTree(int numDim, unsigned int K);
00114
00115 virtual ~CRBFCenterNetworkKDTree();
00116
00117 virtual void getNearestNeigbors(ColumnVector *state, unsigned int K, DataSubset *subset);
00118 };
00119
00120 class CRBFCenterFeatureCalculator : public CFeatureCalculator
00121 {
00122 protected:
00123 CRBFCenterNetwork *network;
00124
00125 public:
00126 bool useBias;
00127 bool normalizeFeat;
00128
00129 CRBFCenterFeatureCalculator(CStateProperties *stateProperties, CRBFCenterNetwork *network, unsigned int K);
00130 virtual ~CRBFCenterFeatureCalculator();
00131
00132 virtual void getModifiedState(CStateCollection *state, CState *targetState);
00133 };
00134
00135
00136 #endif
00137