00001 // Copyright (C) 200300002 // Gerhard Neumann (gneumann@gmx.net)00003 // Stephan Neumann (sneumann@gmx.net)00004 // 00005 // This file is part of RL Toolbox.00006 // http://www.igi.tugraz.at/ril_toolbox00007 //00008 // All rights reserved.00009 //00010 // Redistribution and use in source and binary forms, with or without00011 // modification, are permitted provided that the following conditions00012 // are met:00013 // 1. Redistributions of source code must retain the above copyright00014 // notice, this list of conditions and the following disclaimer.00015 // 2. Redistributions in binary form must reproduce the above copyright00016 // notice, this list of conditions and the following disclaimer in the00017 // documentation and/or other materials provided with the distribution.00018 // 3. The name of the author may not be used to endorse or promote products00019 // derived from this software without specific prior written permission.00020 //00021 // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR00022 // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES00023 // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.00024 // IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,00025 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT00026 // NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,00027 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY00028 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT00029 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF00030 // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.00031
00032 #ifndef C_FUNCTIONFROMQFUNCTION__H00033 #define C_FUNCTIONFROMQFUNCTION__H00034
00035 #include "cvfunction.h"00036
00037 classCAbstractQFunction;
00038 classCActionSet;
00039 classCStateProperties;
00040 classCStateCollection;
00041 classCState;
00042 classCAbstractVETraces;
00043
00044classCOptimalVFunctionFromQFunction : publicCAbstractVFunction00045 {
00046 protected:
00047CAbstractQFunction *qFunction;
00048CActionSet *availableActions;
00049 public:
00050 COptimalVFunctionFromQFunction(CAbstractQFunction *qfunction, CStateProperties *properties);
00051 virtual~COptimalVFunctionFromQFunction();
00052
00053 virtualdoublegetValue(CStateCollection *state);
00054 virtualdoublegetValue(CState *state);
00055
00056 virtualCAbstractVETraces *getStandardETraces();
00057 };
00058
00059classCVFunctionFromQFunction : publicCOptimalVFunctionFromQFunction00060 {
00061 protected:
00062
00063double *actionValues;
00064CStochasticPolicy *stochPolicy;
00065
00066 public:
00067 CVFunctionFromQFunction(CAbstractQFunction *qfunction, CStochasticPolicy *stochPolicy, CStateProperties *properties);
00068 virtual~CVFunctionFromQFunction();
00069
00070 virtualdoublegetValue(CStateCollection *state);
00071 virtualdoublegetValue(CState *state);
00072
00073 virtualCStochasticPolicy *getPolicy();
00074 virtualvoidsetPolicy( CStochasticPolicy *policy);
00075 };
00076
00077 #endif00078