|
|
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
|
|
|
|
|
|
|
|
<!--Converted with LaTeX2HTML 2008 (1.71)
|
|
|
|
original version by: Nikos Drakos, CBLU, University of Leeds
|
|
|
|
* revised and updated by: Marcus Hennecke, Ross Moore, Herb Swan
|
|
|
|
* with significant contributions from:
|
|
|
|
Jens Lippmann, Marek Rouchal, Martin Wilck and others -->
|
|
|
|
<HTML>
|
|
|
|
<HEAD>
|
|
|
|
<TITLE>Sparse Matrix data structure</TITLE>
|
|
|
|
<META NAME="description" CONTENT="Sparse Matrix data structure">
|
|
|
|
<META NAME="keywords" CONTENT="userhtml">
|
|
|
|
<META NAME="resource-type" CONTENT="document">
|
|
|
|
<META NAME="distribution" CONTENT="global">
|
|
|
|
|
|
|
|
<META NAME="Generator" CONTENT="LaTeX2HTML v2008">
|
|
|
|
<META HTTP-EQUIV="Content-Style-Type" CONTENT="text/css">
|
|
|
|
|
|
|
|
<LINK REL="STYLESHEET" HREF="userhtml.css">
|
|
|
|
|
|
|
|
<LINK REL="next" HREF="node13.html">
|
|
|
|
<LINK REL="previous" HREF="node9.html">
|
|
|
|
<LINK REL="up" HREF="node8.html">
|
|
|
|
<LINK REL="next" HREF="node12.html">
|
|
|
|
</HEAD>
|
|
|
|
|
|
|
|
<BODY >
|
|
|
|
<!--Navigation Panel-->
|
|
|
|
<A NAME="tex2html308"
|
|
|
|
HREF="node12.html">
|
|
|
|
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next" SRC="next.png"></A>
|
|
|
|
<A NAME="tex2html304"
|
|
|
|
HREF="node8.html">
|
|
|
|
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up" SRC="up.png"></A>
|
|
|
|
<A NAME="tex2html298"
|
|
|
|
HREF="node10.html">
|
|
|
|
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous" SRC="prev.png"></A>
|
|
|
|
<A NAME="tex2html306"
|
|
|
|
HREF="node1.html">
|
|
|
|
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents" SRC="contents.png"></A>
|
|
|
|
<BR>
|
|
|
|
<B> Next:</B> <A NAME="tex2html309"
|
|
|
|
HREF="node12.html">Named Constants</A>
|
|
|
|
<B> Up:</B> <A NAME="tex2html305"
|
|
|
|
HREF="node8.html">Data Structures</A>
|
|
|
|
<B> Previous:</B> <A NAME="tex2html299"
|
|
|
|
HREF="node10.html">Named Constants</A>
|
|
|
|
<B> <A NAME="tex2html307"
|
|
|
|
HREF="node1.html">Contents</A></B>
|
|
|
|
<BR>
|
|
|
|
<BR>
|
|
|
|
<!--End of Navigation Panel-->
|
|
|
|
|
|
|
|
<H2><A NAME="SECTION00042000000000000000"></A>
|
|
|
|
<A NAME="sec:spmat"></A>
|
|
|
|
<BR>
|
|
|
|
Sparse Matrix data structure
|
|
|
|
</H2>
|
|
|
|
The spdata<TT>psb_spmat_type</TT> data structure
|
|
|
|
contains all information about the local portion of the sparse matrix and
|
|
|
|
its storage mode. Most of these fields are set by the tools
|
|
|
|
routines when inserting a new sparse matrix; the user needs only
|
|
|
|
choose, if he/she so whishes, a specific matrix storage mode.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
The
|
|
|
|
<DL>
|
|
|
|
<DT><STRONG><B>aspk</B></STRONG></DT>
|
|
|
|
<DD>Contains values of the local distributed sparse
|
|
|
|
matrix.
|
|
|
|
<BR>
|
|
|
|
Specified as: an allocatable array of rank one of type corresponding
|
|
|
|
to matrix entries type.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>ia1</B></STRONG></DT>
|
|
|
|
<DD>Holds integer information on distributed sparse
|
|
|
|
matrix. Actual information will depend on data format used.
|
|
|
|
<BR>
|
|
|
|
Specified as: an allocatable integer array of rank one.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>ia2</B></STRONG></DT>
|
|
|
|
<DD>Holds integer information on distributed sparse
|
|
|
|
matrix. Actual information will depend on data format used.
|
|
|
|
<BR>
|
|
|
|
Specified as: an allocatable integer array of rank one.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>infoa</B></STRONG></DT>
|
|
|
|
<DD>On entry can hold auxiliary information on distributed sparse
|
|
|
|
matrix. Actual information will depend on data format used.
|
|
|
|
<BR>
|
|
|
|
Specified as: an integer array of length <code>psb_ifasize_</code>.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>fida</B></STRONG></DT>
|
|
|
|
<DD>Defines the format of the distributed sparse matrix.
|
|
|
|
<BR>
|
|
|
|
Specified as: a string of length 5
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>descra</B></STRONG></DT>
|
|
|
|
<DD>Describe the characteristic of the distributed sparse matrix.
|
|
|
|
<BR>
|
|
|
|
Specified as: array of character of length 9.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>pl</B></STRONG></DT>
|
|
|
|
<DD>Specifies the local row permutation of distributed sparse
|
|
|
|
matrix. If pl(1) is equal to 0, then there isn't row permutation.
|
|
|
|
<BR>
|
|
|
|
Specified as: an allocatable integer array of dimension equal to number of local row (matrix_data[psb_n_row_])
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>pr</B></STRONG></DT>
|
|
|
|
<DD>Specifies the local column permutation of distributed sparse
|
|
|
|
matrix. If PR(1) is equal to 0, then there isn't columnm permutation.
|
|
|
|
<BR>
|
|
|
|
Specified as: an allocatable integer array of dimension equal to number of
|
|
|
|
local row (matrix_data[psb_n_col_])
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>m</B></STRONG></DT>
|
|
|
|
<DD>Number of rows; if row indices are stored explicitly,
|
|
|
|
as in Coordinate Storage, should be greater than or equal to the
|
|
|
|
maximum row index actually present in the sparse matrix.
|
|
|
|
Specified as: integer variable.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG><B>k</B></STRONG></DT>
|
|
|
|
<DD>Number of columns; if column indices are stored explicitly,
|
|
|
|
as in Coordinate Storage or Compressed Sparse Rows, should be greater
|
|
|
|
than or equal to the maximum column index actually present in the sparse matrix.
|
|
|
|
Specified as: integer variable.
|
|
|
|
</DD>
|
|
|
|
</DL>
|
|
|
|
The Fortran 95 interface for distributed sparse matrices containing
|
|
|
|
double precision real entries is defined as shown in
|
|
|
|
figure <A HREF="#fig:spmattype">4</A>. The definitions for single precision and
|
|
|
|
complex data are identical except for the <code>real</code> declaration and
|
|
|
|
for the kind type parameter.
|
|
|
|
|
|
|
|
<DIV ALIGN="CENTER"><A NAME="fig:spmattype"></A><A NAME="639"></A>
|
|
|
|
<TABLE>
|
|
|
|
<CAPTION ALIGN="BOTTOM"><STRONG>Figure 4:</STRONG>
|
|
|
|
The PSBLAS defined data type that
|
|
|
|
contains a sparse matrix.</CAPTION>
|
|
|
|
<TR><TD>
|
|
|
|
<BR>
|
|
|
|
|
|
|
|
<DIV ALIGN="CENTER">
|
|
|
|
<!-- MATH
|
|
|
|
$\fbox{\TheSbox}$
|
|
|
|
-->
|
|
|
|
<IMG
|
|
|
|
WIDTH="535" HEIGHT="218" ALIGN="MIDDLE" BORDER="0"
|
|
|
|
SRC="img20.png"
|
|
|
|
ALT="\fbox{\TheSbox}">
|
|
|
|
</DIV></TD></TR>
|
|
|
|
</TABLE>
|
|
|
|
</DIV>
|
|
|
|
|
|
|
|
<P>
|
|
|
|
The following two cases are among the most commonly used:
|
|
|
|
<DL>
|
|
|
|
<DT><STRONG>fida=``CSR''</STRONG></DT>
|
|
|
|
<DD>Compressed storage by rows. In this case the
|
|
|
|
following should hold:
|
|
|
|
|
|
|
|
<OL>
|
|
|
|
<LI><code>ia2(i)</code> contains the index of the first element of row
|
|
|
|
<code>i</code>; the last element of the sparse matrix is thus stored at
|
|
|
|
index <IMG
|
|
|
|
WIDTH="107" HEIGHT="32" ALIGN="MIDDLE" BORDER="0"
|
|
|
|
SRC="img22.png"
|
|
|
|
ALT="$ia2(m+1)-1$">. It should contain <code>m+1</code> entries in
|
|
|
|
nondecreasing order (strictly increasing, if there are no empty rows).
|
|
|
|
</LI>
|
|
|
|
<LI><code>ia1(j)</code> contains the column index and <code>aspk(j)</code>
|
|
|
|
contains the corresponding coefficient value, for all <!-- MATH
|
|
|
|
$ia2(1) \le j
|
|
|
|
\le ia2(m+1)-1$
|
|
|
|
-->
|
|
|
|
<IMG
|
|
|
|
WIDTH="200" HEIGHT="32" ALIGN="MIDDLE" BORDER="0"
|
|
|
|
SRC="img23.png"
|
|
|
|
ALT="$ia2(1) \le j
|
|
|
|
\le ia2(m+1)-1$">.
|
|
|
|
</LI>
|
|
|
|
</OL>
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG>fida=``COO''</STRONG></DT>
|
|
|
|
<DD>Coordinate storage. In this case the following
|
|
|
|
should hold:
|
|
|
|
|
|
|
|
<OL>
|
|
|
|
<LI><code>infoa(1)</code> contains the number of nonzero elements in the
|
|
|
|
matrix;
|
|
|
|
</LI>
|
|
|
|
<LI>For all <!-- MATH
|
|
|
|
$1 \le j \le infoa(1)$
|
|
|
|
-->
|
|
|
|
<IMG
|
|
|
|
WIDTH="122" HEIGHT="32" ALIGN="MIDDLE" BORDER="0"
|
|
|
|
SRC="img24.png"
|
|
|
|
ALT="$1 \le j \le infoa(1)$">, the coefficient, row index and
|
|
|
|
column index are stored into <code>apsk(j)</code>, <code>ia1(j)</code> and
|
|
|
|
<code>ia2(j)</code> respectively.
|
|
|
|
</LI>
|
|
|
|
</OL>
|
|
|
|
</DD>
|
|
|
|
</DL>
|
|
|
|
A sparse matrix has an associated state, which can take the following
|
|
|
|
values:
|
|
|
|
<DL>
|
|
|
|
<DT><STRONG>Build:</STRONG></DT>
|
|
|
|
<DD>State entered after the first allocation, and before the
|
|
|
|
first assembly; in this state it is possible to add nonzero entries.
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG>Assembled:</STRONG></DT>
|
|
|
|
<DD>State entered after the assembly; computations using
|
|
|
|
the sparse matrix, such as matrix-vector products, are only possible
|
|
|
|
in this state;
|
|
|
|
</DD>
|
|
|
|
<DT><STRONG>Update:</STRONG></DT>
|
|
|
|
<DD>State entered after a reinitalization; this is used to
|
|
|
|
handle applications in which the same sparsity pattern is used
|
|
|
|
multiple times with different coefficients. In this state it is only
|
|
|
|
possible to enter coefficients for already existing nonzero entries.
|
|
|
|
</DD>
|
|
|
|
</DL>
|
|
|
|
<BR><HR>
|
|
|
|
<!--Table of Child-Links-->
|
|
|
|
<A NAME="CHILD_LINKS"><STRONG>Subsections</STRONG></A>
|
|
|
|
|
|
|
|
<UL>
|
|
|
|
<LI><A NAME="tex2html310"
|
|
|
|
HREF="node12.html">Named Constants</A>
|
|
|
|
</UL>
|
|
|
|
<!--End of Table of Child-Links-->
|
|
|
|
<HR>
|
|
|
|
<!--Navigation Panel-->
|
|
|
|
<A NAME="tex2html308"
|
|
|
|
HREF="node12.html">
|
|
|
|
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next" SRC="next.png"></A>
|
|
|
|
<A NAME="tex2html304"
|
|
|
|
HREF="node8.html">
|
|
|
|
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up" SRC="up.png"></A>
|
|
|
|
<A NAME="tex2html298"
|
|
|
|
HREF="node10.html">
|
|
|
|
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous" SRC="prev.png"></A>
|
|
|
|
<A NAME="tex2html306"
|
|
|
|
HREF="node1.html">
|
|
|
|
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents" SRC="contents.png"></A>
|
|
|
|
<BR>
|
|
|
|
<B> Next:</B> <A NAME="tex2html309"
|
|
|
|
HREF="node12.html">Named Constants</A>
|
|
|
|
<B> Up:</B> <A NAME="tex2html305"
|
|
|
|
HREF="node8.html">Data Structures</A>
|
|
|
|
<B> Previous:</B> <A NAME="tex2html299"
|
|
|
|
HREF="node10.html">Named Constants</A>
|
|
|
|
<B> <A NAME="tex2html307"
|
|
|
|
HREF="node1.html">Contents</A></B>
|
|
|
|
<!--End of Navigation Panel-->
|
|
|
|
|
|
|
|
</BODY>
|
|
|
|
</HTML>
|