Menu

[r54]: / trunk / test / zhematrix / zhecomplex / main.cpp  Maximize  Restore  History

Download this file

58 lines (47 with data), 1.6 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <iostream>
#include "cpplapack.h"
int main(int argc, char *argv[])
{
CPPL::zhematrix Z(4), W(4);
// Assign values to lower triangle only.
for( int i = 0; i < Z.n; i++ ) {
for( int j = 0; j <=i; j++ ) {
std::complex<double> x = std::complex<double>(i,j);
if( i == j ) {
Z(i,j) = std::complex<double>(i,0);
} else {
Z(i,j) = x;
}
std::cout << "(" << i << "," << j << "):Z(i,j)=" << Z(i,j) << std::endl;
}
}
std::cout << "Z = " << Z << std::endl;
// Assing values to upper triangle only.
for( int i = 0; i < W.n; i++ ) {
for( int j = i; j < W.n; j++ ) {
std::complex<double> x = std::complex<double>(j,i);
if( i == j ) {
W(i,j) = std::complex<double>(j,0);
} else {
W(i,j) = x;
}
std::cout << "(" << i << "," << j << "):W(i,j)=" << W(i,j) << std::endl;
}
}
std::cout << "W = " << W << std::endl;
std::cout << "Z+W = " << Z+W << "<-Should have all imaginary parts zero." << std::endl;
std::cout << "Z-W = " << Z-W << "<-Should have all real parts zero." << std::endl;
CPPL::zgematrix G(Z.n, Z.n);
for( int i = 0; i < Z.n; i++ ) {
for( int j = 0; j < Z.n; j++ ) {
std::cout << "sqrt( " << Z(i,j) << " ) = " << std::sqrt( Z(i,j) ) << std::endl;
G(i,j) = std::sqrt( Z(i,j) ) * std::sqrt( Z(i,j) );
}
}
std::cout << "G-Z = " << G-Z << "<-Should be zero." << std::endl;
W.write( "zhe.txt" );
CPPL::zhematrix WW;
WW.read( "zhe.txt" );
std::cout << "W-WW = " << W-WW << "<-Should be zero." << std::endl;
return 0;
}
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.