00001 /***************************************************************************** 00002 * Copyright (C) 2011 by Benjamin Hadorn (b_hadorn@bluewin.ch) 00003 ***************************************************************************** 00004 * Project : Zeus Math Library 00005 * Module : IDistribution 00006 * Package : Zeus.ZeusMath.Stochastic.Interfaces 00007 * Author : Benjamin Hadorn 00008 * Date : 27.12.2011 00009 * System : Zeus-Framework 00010 ***************************************************************************** 00011 * Licence: * 00012 * This library is free software; you can redistribute it and/or modify * 00013 * it under the terms of the GNU Lesser General Public License as * 00014 * published by the Free Software Foundation; either version * 00015 * 2.1 of the License, or (at your option) any later version. * 00016 * * 00017 * This library is distributed in the hope that it will be useful, * 00018 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00019 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00020 * GNU Lesser General Public License for more details. * 00021 * * 00022 * You should have received a copy of the GNU Lesser General Public * 00023 * License along with this library; if not, write to the Free Software * 00024 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA * 00025 *****************************************************************************/ 00026 00027 /***************************************************************************** 00028 * Changes: 00029 * 27.12.2011 bha: created zeus 2.0 00030 *****************************************************************************/ 00031 00032 #ifndef IDistributionHPP 00033 #define IDistributionHPP 00034 00035 00036 #include <zeusmath/Config/PlatformDefines.hpp> 00037 #include <zeusbase/System/Interfaces/IValueType.hpp> 00038 00039 BEGIN_NAMESPACE_Zeus 00040 00041 /**************************************************************************/ 00044 /**************************************************************************/ 00045 class IDistribution : public IValueType 00046 { 00047 /**************************************************************************/ 00050 /**************************************************************************/ 00051 HIDE_ASSIGNMENT_OPERATOR(IDistribution) 00052 00053 public: 00054 00055 /************************************************************************/ 00058 /************************************************************************/ 00059 virtual Float MQUALIFIER getEntropy() const = 0; 00060 00061 /************************************************************************/ 00064 /************************************************************************/ 00065 virtual Float MQUALIFIER getExpectedValue() const = 0; 00066 00067 /************************************************************************/ 00072 /************************************************************************/ 00073 virtual Float MQUALIFIER getMean() const = 0; 00074 00075 /************************************************************************/ 00083 /************************************************************************/ 00084 virtual Float MQUALIFIER getMedian() const = 0; 00085 00086 /************************************************************************/ 00089 /************************************************************************/ 00090 virtual Float MQUALIFIER getVariance() const = 0; 00091 00092 /************************************************************************/ 00095 /************************************************************************/ 00096 virtual Float MQUALIFIER getStdDeviation() const = 0; 00097 00098 /************************************************************************/ 00101 /************************************************************************/ 00102 virtual Float MQUALIFIER getMode() const = 0; 00103 00104 /************************************************************************/ 00107 /************************************************************************/ 00108 virtual Float MQUALIFIER getSkewness() const = 0; 00109 00110 /************************************************************************/ 00117 /************************************************************************/ 00118 virtual Float MQUALIFIER getCumulativeProb(const Float& rfStart, const Float& rfEnd) const = 0; 00119 00120 /************************************************************************/ 00126 /************************************************************************/ 00127 virtual Float MQUALIFIER getProb(const Float& rfX) const = 0; 00128 00129 /************************************************************************/ 00134 /************************************************************************/ 00135 virtual Float MQUALIFIER getSampleProb(Int iSample) const = 0; 00136 00137 }; 00138 00139 00140 END_NAMESPACE_Zeus 00141 00142 #endif