STK++ 1.0
STK_Law_ITMultivariate.h
Go to the documentation of this file.
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 */