Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
|
Gram Schmidt Orthogonalisation Process More...
#include <array>
#include <cassert>
#include <cmath>
#include <iostream>
#include "math.h"
Namespaces | |
namespace | numerical_methods |
for assert | |
namespace | gram_schmidt |
Functions for Gram Schmidt Orthogonalisation Process | |
Functions | |
double | numerical_methods::gram_schmidt::dot_product (const std::array< double, 10 > &x, const std::array< double, 10 > &y, const int &c) |
double | numerical_methods::gram_schmidt::projection (const std::array< double, 10 > &x, const std::array< double, 10 > &y, const int &c) |
void | numerical_methods::gram_schmidt::display (const int &r, const int &c, const std::array< std::array< double, 10 >, 20 > &B) |
void | numerical_methods::gram_schmidt::gram_schmidt (int r, const int &c, const std::array< std::array< double, 10 >, 20 > &A, std::array< std::array< double, 10 >, 20 > B) |
static void | test () |
int | main () |
Main Function. | |
Gram Schmidt Orthogonalisation Process
Takes the input of Linearly Independent Vectors, returns vectors orthogonal to each other.
Take the first vector of given LI vectors as first vector of Orthogonal vectors. Take projection of second input vector on the first vector of Orthogonal vector and subtract it from the 2nd LI vector. Take projection of third vector on the second vector of Othogonal vectors and subtract it from the 3rd LI vector. Keep repeating the above process until all the vectors in the given input array are exhausted.
For Example: In R2, Input LI Vectors={(3,1),(2,2)} then Orthogonal Vectors= {(3, 1),(-0.4, 1.2)}
Have defined maximum dimension of vectors to be 10 and number of vectors taken is 20. Please do not give linearly dependent vectors
void numerical_methods::gram_schmidt::display | ( | const int & | r, |
const int & | c, | ||
const std::array< std::array< double, 10 >, 20 > & | B ) |
Function to print the orthogonalised vector
r | number of vectors |
c | dimenaion of vectors |
B | stores orthogonalised vectors |
double numerical_methods::gram_schmidt::dot_product | ( | const std::array< double, 10 > & | x, |
const std::array< double, 10 > & | y, | ||
const int & | c ) |
Dot product function. Takes 2 vectors along with their dimension as input and returns the dot product.
x | vector 1 |
y | vector 2 |
c | dimension of the vectors |
void numerical_methods::gram_schmidt::gram_schmidt | ( | int | r, |
const int & | c, | ||
const std::array< std::array< double, 10 >, 20 > & | A, | ||
std::array< std::array< double, 10 >, 20 > | B ) |
Function for the process of Gram Schimdt Process
r | number of vectors |
c | dimension of vectors |
A | stores input of given LI vectors |
B | stores orthogonalised vectors |
we check whether appropriate dimensions are given or not.
First vector is copied as it is.
array to store projections
First initialised to zero
to store previous projected array
to store the factor by which the previous array will change
projected array created
we take the projection with all the previous vector and add them.
subtract total projection vector from the input vector
int main | ( | void | ) |
Main Function.
a 2-D array for storing all vectors
a 2-D array for storing orthogonalised vectors
storing vectors in array A
Input of vectors is taken
To check whether vectors are orthogonal or not
take make the process numerically stable, upper bound for the dot product take 0.1
double numerical_methods::gram_schmidt::projection | ( | const std::array< double, 10 > & | x, |
const std::array< double, 10 > & | y, | ||
const int & | c ) |
Projection Function Takes input of 2 vectors along with their dimension and evaluates their projection in temp
x | Vector 1 |
y | Vector 2 |
c | dimension of each vector |
The dot product of two vectors is taken
The norm of the second vector is taken.
multiply that factor with every element in a 3rd vector, whose initial values are same as the 2nd vector.
|
static |
Test Function. Process has been tested for 3 Sample Inputs