Neural Networks 0.2
A framework for Lukas Zdechovan's Neural Networks C++ projects.
|
00001 /* 00002 <one line to give the program's name and a brief idea of what it does.> 00003 Copyright (C) <year> <name of author> 00004 00005 This program is free software: you can redistribute it and/or modify 00006 it under the terms of the GNU General Public License as published by 00007 the Free Software Foundation, either version 3 of the License, or 00008 (at your option) any later version. 00009 00010 This program is distributed in the hope that it will be useful, 00011 but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 GNU General Public License for more details. 00014 00015 You should have received a copy of the GNU General Public License 00016 along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 00018 */ 00019 00020 #ifndef CACLA_H 00021 #define CACLA_H 00022 00023 #include "ContEnvironment.h" 00024 #include "Actor.h" 00025 #include "Critic.h" 00026 00027 namespace RL{ 00028 00032 namespace CACLA{ 00033 00034 class CACLA 00035 { 00036 protected: 00037 Environment *environment; 00038 Actor *actor; 00039 Critic *critic; 00040 double discount; 00041 double tdError(double reward, State oldState, State newState); 00042 public: 00043 void train(); 00044 }; 00045 00046 } 00047 } 00048 00049 #endif // CACLA_H