STK++ 1.0
STK_ILinearReduct.h
Go to the documentation of this file.
00001 /*--------------------------------------------------------------------*/
00002 /*     Copyright (C) 2004-2007  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::AAModels
00027  * created on: 17 avr. 2010
00028  * Purpose:  Abstract class for the computation of the Index in the SLAAM.
00029  * Author:   iovleff, serge.iovleff@stkpp.org
00030  *
00031  **/
00032 
00037 #ifndef STK_ILINEAREDUCT_H
00038 #define STK_ILINEAREDUCT_H
00039 
00040 #include "../../Arrays/include/STK_Vector.h"
00041 #include "../../Arrays/include/STK_Matrix.h"
00042 
00043 #include "STK_IReduct.h"
00044 
00045 namespace STK
00046 {
00068 class ILinearReduct : public IReduct
00069 {
00070   protected:
00074     ILinearReduct( Matrix const& data);
00075 
00076   public:
00078     virtual ~ILinearReduct();
00079 
00082     bool run();
00087     bool run(Vector const& weights);
00088 
00092     inline Integer const& nbAxis() const { return dim_;}
00096     inline Vector const& indexValues() const { return index_values_; }
00100     inline Matrix const& axis() const { return axis_; }
00101 
00102   protected:
00104     Vector index_values_;
00106     Matrix axis_;
00108     virtual void maximizeIndex() =0;
00112     virtual void maximizeIndex( const Vector& weights) =0;
00114     void projection();
00115 };
00116 
00117 } // namespace STK
00118 
00119 #endif /* STK_ILINEARREDUCT_H */