|
STK++ 1.0
|
00001 /*--------------------------------------------------------------------*/ 00002 /* Copyright (C) 2004-2011 Serge Iovleff 00003 00004 This program is free software; you can redistribute it and/or modify 00005 it under the terms of the GNU Lesser General Public License as 00006 published by the Free Software Foundation; either version 2 of the 00007 License, or (at your option) any later version. 00008 00009 This program is distributed in the hope that it will be useful, 00010 but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 GNU Lesser General Public License for more details. 00013 00014 You should have received a copy of the GNU Lesser General Public 00015 License along with this program; if not, write to the 00016 Free Software Foundation, Inc., 00017 59 Temple Place, 00018 Suite 330, 00019 Boston, MA 02111-1307 00020 USA 00021 00022 Contact : Serge.Iovleff@stkpp.org 00023 */ 00024 00025 /* 00026 * Project: stkpp::STatistiK::Law 00027 * created on: 29 juil. 2011 00028 * Purpose: . 00029 * Author: iovleff, serge.iovleff@stkpp.org 00030 * 00031 **/ 00032 00037 #ifndef STK_ITMULTIVARIATE_H 00038 #define STK_ITMULTIVARIATE_H 00039 00040 #include "../../Sdk/include/STK_IRecursiveTemplate.h" 00041 #include "../../Sdk/include/STK_ITContainer1D.h" 00042 00043 #include "../../STKernel/include/STK_Real.h" 00044 00045 #include "STK_Law_ILawBase.h" 00046 00047 namespace STK 00048 { 00049 00050 namespace Law 00051 { 00052 00059 template<class TYPE, class Container1D> 00060 class ITMultivariate: public ILawBase 00061 { 00062 protected: 00064 ITMultivariate( String const& name) : ILawBase(name) {} 00065 00066 public: 00068 virtual ~ITMultivariate() {} 00069 00076 virtual Real pdf( ITContainer1D<TYPE, Container1D> const& x) const =0; 00077 00083 virtual Real lpdf( ITContainer1D<TYPE, Container1D> const& x) const =0; 00084 00089 virtual void rand( ITContainer1D<TYPE, Container1D>& x) const =0; 00090 00096 virtual void rand( ITContainer1D<TYPE, Container1D> const& x) const =0; 00097 }; 00098 00099 } // namespace Law 00100 00101 } // namespace STK 00102 00103 #endif /* STK_ITMULTIVARIATE_H */