<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">

<!--Converted with LaTeX2HTML 2002-2-1 (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 v2002-2-1">
<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="tex2html304"
  HREF="node12.html">
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next"
 SRC="file:/usr/share/latex2html/icons/next.png"></A> 
<A NAME="tex2html300"
  HREF="node8.html">
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up"
 SRC="file:/usr/share/latex2html/icons/up.png"></A> 
<A NAME="tex2html294"
  HREF="node10.html">
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous"
 SRC="file:/usr/share/latex2html/icons/prev.png"></A> 
<A NAME="tex2html302"
  HREF="node1.html">
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents"
 SRC="file:/usr/share/latex2html/icons/contents.png"></A>  
<BR>
<B> Next:</B> <A NAME="tex2html305"
  HREF="node12.html">Named Constants</A>
<B> Up:</B> <A NAME="tex2html301"
  HREF="node8.html">Data Structures</A>
<B> Previous:</B> <A NAME="tex2html295"
  HREF="node10.html">Named Constants</A>
 &nbsp; <B>  <A NAME="tex2html303"
  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 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. 
<BR><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&nbsp;95 interface for distributed sparse matrices containing
double precision real entries is defined as shown in
figure&nbsp;<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="622"></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="536" HEIGHT="218" ALIGN="MIDDLE" BORDER="0"
 SRC="img19.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="img21.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="199" HEIGHT="32" ALIGN="MIDDLE" BORDER="0"
 SRC="img22.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="123" HEIGHT="32" ALIGN="MIDDLE" BORDER="0"
 SRC="img23.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="tex2html306"
  HREF="node12.html">Named Constants</A>
</UL>
<!--End of Table of Child-Links-->
<HR>
<!--Navigation Panel-->
<A NAME="tex2html304"
  HREF="node12.html">
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next"
 SRC="file:/usr/share/latex2html/icons/next.png"></A> 
<A NAME="tex2html300"
  HREF="node8.html">
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up"
 SRC="file:/usr/share/latex2html/icons/up.png"></A> 
<A NAME="tex2html294"
  HREF="node10.html">
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous"
 SRC="file:/usr/share/latex2html/icons/prev.png"></A> 
<A NAME="tex2html302"
  HREF="node1.html">
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents"
 SRC="file:/usr/share/latex2html/icons/contents.png"></A>  
<BR>
<B> Next:</B> <A NAME="tex2html305"
  HREF="node12.html">Named Constants</A>
<B> Up:</B> <A NAME="tex2html301"
  HREF="node8.html">Data Structures</A>
<B> Previous:</B> <A NAME="tex2html295"
  HREF="node10.html">Named Constants</A>
 &nbsp; <B>  <A NAME="tex2html303"
  HREF="node1.html">Contents</A></B> 
<!--End of Navigation Panel-->

</BODY>
</HTML>