File: README

package info (click to toggle)
itsol 1.0.0-1
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 2,096 kB
  • ctags: 551
  • sloc: ansic: 6,795; sh: 686; fortran: 349; makefile: 76
file content (181 lines) | stat: -rw-r--r-- 8,589 bytes parent folder | download | duplicates (3)
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
=======================================================================
 --> Version 1.0  Latest changes made on: Tue Sep 16 18:32:57 CDT 2008
+======================================================================+
|------------------- Iterative Solvers Package ------------------------|
+======================================================================+

NOTE*** iluc has been temporily removed for a fix 

This is  part of  the ITSOL extention  to the SPARSKIT  package.  This
particular  sub-package provides  preconditioners for  solving general
sparse * real-valued * linear systems of equations.

Main Contributors: Brian Suchomel, Na Li, Zhongze Li, Daniel Osei-Kuffuor, 
     and Yousef Saad.

Current contacts: Daniel Osei Kuffuor (dosei@cs.umn.edu)
                  Yousef Saad         (saad@cs.umn.edu) 

Apr. 2008 

=======================================================================

This  library contains a  number of  classic and  new preconditioners.
There are several ways in  which you can use these preconditioners for
solving  a linear  system.  The  easiest way  is probably  to  use the
sample drivers  provided in the directories TESTS_COO  and TESTS_HB as
templates. TESTS_COO contains test codes for matrices in coordinate or
matrix-market  format  while  TESTS_HB  is  for matrices  in  the  old
Harwell- Boeing format.  Each if these  drivers has a name of the form
mainPRECONhb.c or mainPRECONcoo where PRECON is one of

 ILUK     standard ILU preconditioner with level of fill 
 ILUT     standard ILU preconditioner with threshold 
 ILUC     standard ILU preconditioner with threshold - Crout version
 ARMS     Algebraic Multilevel Solvers == This includes both the 
          standard ARMS and a version with nonsymmetric permutations
          which reorders the matrix by diagonal dominance
 VBILUT   Variable Block ILUT preconditioner
 VBILUK   Variable Block ILUK preconditioner

For  example, mainILUThb.c  is  a driver  which  reads a  matrix in  a
Harwell-Boeing format (or a  sequence of such matrices for consecutive
tests  --  see below),  then  constructs  an  ILUT preconditioner  and
proceeds to  solve the system  with the accelerator fgmres.   There is
only  one accelerator  used  for the  iteration  phase, namely  FGMRES
(fgmr.c).  This uses two wrapper structs

 MAT for the matrix [for matvecs] 
 PRE for the preconditoner (preconditioning operation). 

These  structs  include substructs  for  each  of the  data-structures
required by the above  preconditioners and pointers to functions. Only
one of these, along with  one matvec function needs to be instantiated
(set) for  the MAT  struct. Similarly one  member and  a corresponding
function  pointer of  PRE needs  to  be instantiated.  Thus, a  driver
mainPREC (resp mainPRECcoo) does the following steps

 1/ read the matrix in Harwell-Boeing (resp. coo) format
 2/ convert it to any required format 
 3/ construct the preconditioner -- get its struct -- say LU
 4/ set MAT, PRE [by filling the appropriate members] 
 5/ call fgmr(MAT, PRE, + other parameters).
 6/ output various results in OUT/PRECON.out 

Once you  are familiar with  the preconditioners and  various structs,
you should  be able to  bypass the wrapper  structs MAT and  PREC.  In
fact a second way of using  the preconditioner is to build it directly
by  a  call  to  the  appropriate  function and  then  call  your  own
accelerator. For example, fgmr can be easily modified to pass directly
the structs needed for the iteration.  Thus, if your preconditioner is
ILUK and  you have the 'iluptr' struct LU and the 'csptr' struct CSMAT
for the  preconditioner and matrix respectively, you  can simply issue
the call

    call fgmr(CSmat, LU, + other parameters).

and  replace  the matvec  routines  and  preconditioner  calls by  the
appropriate ones == These are available in LIB/MatOps.c

-------------------------------------------------------------------------
---------------- DETAILS ON THE PRECONDITIONERS -------------------------
-------------------------------------------------------------------------

 ILU*      These are the standard ILU(k), ILUT, preconditioners and the
           new, Crout-based ILU preconditoner. ILUT and ILUK are simple
           translations of the corresonding version in the old sparskit.
           ILUC is new and it is written in an "experimental" version
           which allows various dropping strategies [5 different ones] 

	   drivers: mainILUThb,  mainILUKhb,  mainILUChb, and
                    mainILUTcoo, mainILUKcoo, mainILUCcoo, 
           these produce the executables
                    ilut.ex     iluk.ex     iluc.ex 

 ARMS      Algebraic Multilevel Solvers.  This includes both the 
           standard ARMS and a version with nonsymmetric permutations
           which reorders the matrix by diagonal dominance. 
                      
           drivers mainARMShb and mainARMScoo
           which produce the executable   arms.ex

 VB        block variants of ILUT and ILUK preconditioners with variable
	   blocks. 

           drivers mainVBILUThb, mainVBILUKhb, mainVBILUTcoo and VBILUKcoo
           which produce the executables   vbilut.ex and vbiluk.ex

-------------------------------------------------------------------------
---------------- DETAILS ON THE DRIVERS ---------------------------------
-------------------------------------------------------------------------

Each main driver reads input parameters from the file 
	
 inputs

This is done with the  function "read_inputs". The parameters that are
read are the same for all drivers  - though some of these are not used
by the drivers.  For example  droptol is not used by the level-of-fill
techniques  [iluk].  Note  that   the  arms  drivers  set  some  other
parameters to a default via the `set_arms_params' function -- which is
in the 'auxill.c' file.

The execution  of the driver consists  of looping through  a number of
matrices  in harwell-boeing  format and  for  each of  them, a  preset
number of tests is done. The list  of matrices used for the test is in
the file:
 
matfile_coo (coordinate format) and matfile_hb (harwell-Boeing format)

These files begin with a number "nmat" of matrices to be read followed
by  nmat lines  each  consisting of  a  pathname for  the matrix  file
followed by a short name that will be used for creating out filenames.
The other major  loop in the driver will  loop through parameters. The
parameters for  dropping are tightened  at each loop as  instructed by
the choice of lfilInc (how  to increase the lfil parameter) and tolMul
(scalar by which to multiply the drop tolerance at each new loop). 

SAMPLE_MATRICES: two 

-------------------------------------------------------------------------
-------------- porting itsol solvers into packages----------------------- 
-------------------------------------------------------------------------

It is recommended  to test the various solvers  with different options
to see what  works best. For this it is useful  to imitate the general
framework of the  drivers provided.  You can for  example generate the
matrix in  coordinate format and then  convert it to  the internal csr
format  (called SparMat)  by the  function COOcs.   Then you  can call
whatever  preconditioner set-up  function (e.g.   ilut) to  obtain the
desired preconditioner- The pointers in MAT and PRE can then be set --
for example when using ILUT:

      MAT->n = n;                         matrix size
      MAT->CSR = csmat;                   matrix A itself [for matvecs]
      MAT->matvec = matvecCSR;            ptr to matvec routine 
      PRE->ILU = lu;                      preconditioner struct
      PRE->precon = preconILU;            ptr to corresponding precon oper.

You are now ready to call the accelerator:

      fgmr(MAT, PRE, rhs, sol, tol, krydim, itmax, outputs);

-------------------------------------------------- updated Apr. 7th, 2008

A few of the changes in the April 2008 version 
 
** quite a few small fixes.

** added test codes for the COO format -- this is the same essentially as
   the matrix-market format. 

** chaged a few names -- SparRow became SparMat -- VBsparRow became 
   VBSparMat. nnzrow became nzcount. These changes were made to avoid
   confusions [in fact confusion lead to some small errors in earlier
   versions].. Specifically nnzrow used to count number of nonzeros in
   rows or in columns.. 

** ILUC [or possibly just the main routine calling it] seems to have a
   problem -- it will put back after this is fixed.