STK++ 1.0
STK_GramSchmidt.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:  Algebra
00027  * Purpose:  Define the GramScmidt Class.
00028  * Author:   Serge Iovleff, serge.iovleff@stkpp.org
00029  *
00030  **/
00031 
00037 #ifndef STK_GRAMSCHMIDT_H
00038 #define STK_GRAMSCHMIDT_H
00039 
00040 // Container classes
00041 #include "../../Sdk/include/STK_ITContainer2D.h"
00042 #include "STK_LinAlgebra1D.h"
00043 
00044 namespace STK
00045 {
00046 
00052 template < class TContainer2D>
00053 void gramSchmidt( ITContainer2D< Real, TContainer2D>& A)
00054 {
00055   // get dimensions
00056   const Integer firstRow = A.firstRow(), lastRow = A.lastRow();
00057   const Integer firstCol = A.firstCol(), lastCol = A.lastCol();
00058   // orthonormalize
00059   for (Integer j= firstCol; j<= lastCol; j++)
00060   {
00061     for( Integer i= firstCol; i < j; i++)
00062     {
00063       const Real dotij = dot(A.col(i), A.col(j));
00064       for (Integer k= firstRow; k<= lastRow; k++)
00065       {
00066         A(k,j) -= A(k,i) * dotij;
00067       }
00068     }
00069     // normalize
00070     const Real norm = normTwo(A.col(j));
00071     if (norm)
00072     {
00073       for (Integer k= firstRow; k<= lastRow; k++)
00074       {
00075         A(k,j) /= norm;
00076       }
00077     }
00078   }
00079 }
00080 
00081 } // Namespace STK
00082 
00083 #endif // STK_GRAMSCHMIDT_H
00084