File: genmat_gen.m

package info (click to toggle)
rocsolver 6.4.3-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 17,876 kB
  • sloc: cpp: 151,850; python: 2,275; sh: 875; objc: 642; ansic: 402; makefile: 71; xml: 26
file content (103 lines) | stat: -rw-r--r-- 2,363 bytes parent folder | download
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
% ********************************************************************
% Copyright (C) 2023 Advanced Micro Devices, Inc. All rights reserved.
% ********************************************************************

function genmat_gen(n,nz)

%{
-----------------------------------------------------------
	This function generates all the files required for a
	test case of the LU re-factorization functionality in rocSOLVER.

	genmat_gen(n, nz)

	Inputs:
	n  			Size of the problem (number of row and columns
				of the sparse matrix A)
	nz  		Number of non-zero elements in A

	Outputs:
	isok		This will be -1 if any of the files could not
				be generated

	The resulting files are created in the working directory.
	See printall.m for more details.

	(This script is for internal use only. It is not part of
	rocSOLVER library interface and could change or be removed
	without any notice)
-----------------------------------------------------------
%}


%---------------------------
% generate random sparse matrix
% with nz non-zero elements
%---------------------------
per = nz / (n*n);
A = sprand(n, n, per);

%---------------------------
% Ensure matrix is diagonally dominant
%---------------------------
A = fixmat(A, n);

%---------------------------
% If necessary, remove extra non-zero elements
%---------------------------
dif = nnz(A) - nz;
if(dif > 0),
	A = cleanmat(A, dif);
end;

%---------------------------
% Compute LU factorization
%---------------------------
[L, U, P, Q] = lu(A, 'vector');
T = L - eye(n,n) + U;

%---------------------------
% Generate output files
%---------------------------
disp('')
disp('Generating files...')
isok = printall("lu", A, T, Q, L, U, P);
if (isok),
	disp('OK')
	disp('')
else
	disp('FAILURE!');
	disp('')
end;

%------------------------
% quick validation
%------------------------
ptr = dlmread('ptrT');
ind = dlmread('indT');
val = dlmread('valT');
t = csr2full(n, ptr, ind, val);
l = tril(t) - diag(diag(t)) + eye(n,n);
u = triu(t);

pp = dlmread('P') + 1;
p = eye(n,n);
p = p(pp,:);
qq = dlmread('Q') + 1;
q = eye(n,n);
q = q(:,qq);

disp('Quick checking:')
b = dlmread('B_1');
x = dlmread('X_1');
err1 = norm(p'*l*u*q'*x-b, "fro")
b = dlmread('B_10');
x = dlmread('X_10');
err2 = norm(p'*l*u*q'*x-b, "fro")
b = dlmread('B_30');
x = dlmread('X_30');
err3 = norm(p'*l*u*q'*x-b, "fro")
disp('')


end