-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrunHHSimetrica3.c
70 lines (49 loc) · 1.33 KB
/
runHHSimetrica3.c
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#include "matrix.h"
#include <sys/time.h>
#include <time.h>
#define VERBOSE
int main(int argc, char *argv[]) {
if(argc <= 1){
printf("usage: %s inputFile\n", argv[0]);
exit(1);
}
struct timeval start, stop;
double duration;
gettimeofday(&start, NULL);
matrix *A, *HH;
loadMatrix(&A, argv[1]);
#ifdef VERBOSE
printMatrix2(A, "A");
#endif
isSymmetric(A) ? printf("\nMatrix A is symmetric\n") : printf("\nMatrix A is Asymmetric\n");
printf("\nHouseholder transformation: (results in a tridiagonal matrix)\n");
HH = householder2(A);
deleteMatrix(A);
#ifdef VERBOSE
printMatrix2(HH, "householder(A)");
#endif
printf("\nQR decomposition of HH matrix...\n");
double epsilon = 0.001;
matrix *D = qr2(HH, epsilon);
#ifdef VERBOSE
printMatrix2(HH, "HH");
printf("\nEigenvalues of matrix A:\n");
printMatrix2(D, "D");
#endif
gettimeofday(&stop, NULL);
duration = (double)(stop.tv_usec - start.tv_usec) / 1000000 + (double)(stop.tv_sec - start.tv_sec);
long int hour, min, vt;
long int sec;
hour = duration / 3600;
vt = (int)duration % 3600;
min = vt / 60;
sec = vt % 60;
int intpart = (int)duration;
double decpart = duration - intpart;
double secd = sec + decpart;
if(hour > 0)
printf("\nElapsed time: %ldh%ldm%1.3fs\n", hour, min, secd);
else
printf("\nElapsed time: %ldm%1.3fs\n", min, secd);
memoryUsage();
}