SparseMatrix.h

Go to the documentation of this file.
00001 //Copyright (c) 2004-2005, Baris Sumengen
00002 //All rights reserved.
00003 //
00004 // CIMPL Matrix Performance Library
00005 //
00006 //Redistribution and use in source and binary
00007 //forms, with or without modification, are
00008 //permitted provided that the following
00009 //conditions are met:
00010 //
00011 //    * No commercial use is allowed. 
00012 //    This software can only be used
00013 //    for non-commercial purposes. This 
00014 //    distribution is mainly intended for
00015 //    academic research and teaching.
00016 //    * Redistributions of source code must
00017 //    retain the above copyright notice, this
00018 //    list of conditions and the following
00019 //    disclaimer.
00020 //    * Redistributions of binary form must
00021 //    mention the above copyright notice, this
00022 //    list of conditions and the following
00023 //    disclaimer in a clearly visible part 
00024 //    in associated product manual, 
00025 //    readme, and web site of the redistributed 
00026 //    software.
00027 //    * Redistributions in binary form must
00028 //    reproduce the above copyright notice,
00029 //    this list of conditions and the
00030 //    following disclaimer in the
00031 //    documentation and/or other materials
00032 //    provided with the distribution.
00033 //    * The name of Baris Sumengen may not be
00034 //    used to endorse or promote products
00035 //    derived from this software without
00036 //    specific prior written permission.
00037 //
00038 //THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT
00039 //HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
00040 //EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT
00041 //NOT LIMITED TO, THE IMPLIED WARRANTIES OF
00042 //MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00043 //PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00044 //CONTRIBUTORS BE LIABLE FOR ANY
00045 //DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00046 //EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00047 //(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
00048 //OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00049 //DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00050 //HOWEVER CAUSED AND ON ANY THEORY OF
00051 //LIABILITY, WHETHER IN CONTRACT, STRICT
00052 //LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
00053 //OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00054 //OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00055 //POSSIBILITY OF SUCH DAMAGE.
00056 
00057 
00058 
00059 #pragma once
00060 #ifndef SPARSEMATRIX_H
00061 #define SPARSEMATRIX_H
00062 
00063 
00064 namespace CIMPL
00065 {
00066 
00067 
00068 
00069 template< class T >
00070 struct matrixCell
00071 {
00072         int x, y;
00073         T value;
00074         matrixCell *xNext;
00075         matrixCell *yNext;
00076 };
00077 
00078 template< class T >
00079 struct matrixCellStart
00080 {
00081         matrixCell<T> *first;
00082         int listCount;
00083 };
00084 
00085 
00087 template< class T >
00088 class SparseMatrix
00089 {
00090 protected:
00091         matrixCellStart<T> *xDimStarts;         // List of column starting points
00092         matrixCellStart<T> *yDimStarts;         // List of row starting points
00093         int ndims;              // always 2
00094         int *dims;              // of length 2
00095         int count;              // count of nonzero elements
00096         
00097         
00098         bool AddCellXStart(matrixCell<T> *c);
00099         bool AddCellYStart(matrixCell<T> *c);
00100         T GetCellXStart(const int x, const int y);
00101         T GetCellYStart(const int x, const int y);
00102         bool DeleteCell(const int x, const int y);
00103 
00104 
00105 
00106 public:
00107         SparseMatrix(void);
00108         SparseMatrix(const int xdim, const int ydim);
00109         
00110         ~SparseMatrix(void);
00111 
00112         const int Columns() const;
00113         const int Rows() const;
00114         const int XDim() const;
00115         const int YDim() const;
00116         //const int* Dims() const;
00117         //const int* Size() const;
00118         //int const NDims() const;
00119         int const NNZ(void) const;
00120 
00121         void SetValue(const int x, const int y, const T value); 
00122         T GetValue(const int x, const int y);
00123         
00124 
00125 // OPERATORS
00126 
00127         T operator() (const int i, const int j);
00128 
00129 
00130 };
00131 
00132 }; //namespace
00133 
00134 
00135 #include "./SparseMatrix.inl"
00136 
00137 
00138 
00139 
00140 #endif
00141 

Generated on Thu Jan 20 08:43:45 2005 for CIMPL by  doxygen 1.3.9.1