STK++ 1.0

STK_GaussianStatModel.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::StatModel
00027  * created on: 13 août 2011
00028  * Purpose:  Create a gaussian statistical model.
00029  * Author:   iovleff, serge.iovleff@stkpp.org
00030  *
00031  **/
00032 
00037 #ifndef STK_GAUSSIANSTATMODEL_H
00038 #define STK_GAUSSIANSTATMODEL_H
00039 
00040 #include "STK_ITStatModel.h"
00041 #include "../../Algebra/include/STK_MatrixSquare.h"
00042 
00043 namespace STK
00044 {
00045 
00103 class GaussianStatModel : public ITStatModel<Real, Point, Vector, Matrix>
00104 {
00105   typedef ITStatModel<Real, Point, Vector, Matrix> RealStatModel;
00106 
00107   public:
00111     GaussianStatModel( Matrix const* p_data);
00112 
00114     virtual ~GaussianStatModel();
00115 
00119     virtual bool run();
00120 
00125     virtual bool run(Vector const& weights);
00126 
00130     inline Point const& mean() const { return mean_;}
00134     inline MatrixSquare const& covariance() const { return cov_;}
00135 
00136   protected:
00138     virtual void compMean();
00140     virtual void compCovariance();
00144     virtual void compWeightedMean(Vector const& weights);
00148     virtual void compWeightedCovariance(Vector const& weights);
00150     Point mean_;
00152     MatrixSquare cov_;
00153 };
00154 
00155 } // namespace STK
00156 
00157 #endif /* STK_GAUSSIANSTATMODEL_H */