STK++ 0.9.13
STK_GramSchmidt.h
Go to the documentation of this file.
1/*--------------------------------------------------------------------*/
2/* Copyright (C) 2004-2016 Serge Iovleff, Université Lille 1, Inria
3
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU Lesser General Public License as
6 published by the Free Software Foundation; either version 2 of the
7 License, or (at your option) any later version.
8
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU Lesser General Public License for more details.
13
14 You should have received a copy of the GNU Lesser General Public
15 License along with this program; if not, write to the
16 Free Software Foundation, Inc.,
17 59 Temple Place,
18 Suite 330,
19 Boston, MA 02111-1307
20 USA
21
22 Contact : S..._Dot_I..._At_stkpp_Dot_org (see copyright for ...)
23*/
24
25/*
26 * Project: Algebra
27 * Purpose: Define the GramSchmidt method.
28 * Author: Serge Iovleff, S..._Dot_I..._At_stkpp_Dot_org (see copyright for ...)
29 *
30 **/
31
37#ifndef STK_GRAMSCHMIDT_H
38#define STK_GRAMSCHMIDT_H
39
40// Container classes
42
43namespace STK
44{
45
51template < class TContainer2D>
53{
54 // orthonormalize
55 for (int j= A.beginCols(); j< A.endCols(); j++)
56 {
57 for( int i= A.beginCols(); i < j; i++)
58 {
59 const Real dotij = dot(A.asDerived().col(i), A.asDerived().col(j));
60 A.asDerived().col(j) -= A.asDerived().col(i) * dotij;
61 }
62 // normalize
63 const Real norm = A.asDerived().col(j).norm();
64 if (norm)
65 {
66 A.asDerived().col(j)/=norm;
67 }
68 }
69}
70
71} // namespace STK
72
73#endif // STK_GRAMSCHMIDT_H
74
In this file we define the base class for Arrays.
The MultidimRegression class allows to regress a multidimensional output variable among a multivariat...
void gramSchmidt(ArrayBase< TContainer2D > &A)
The gramSchmidt method perform the Gram Schmidt orthonormalization of an Array of Real.
Real dot(ExprBase< Container1D1 > const &x, ExprBase< Container1D2 > const &y)
Compute the dot product.
Real norm(Real const &x, Real const &y)
Computation of sqrt(x^2 + y^2) without underflow or overflow.
Definition STK_Misc.h:93
double Real
STK fundamental type of Real values.
The namespace STK is the main domain space of the Statistical ToolKit project.