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 SUBMATRIX_H 00061 #define SUBMATRIX_H 00062 00063 #include <iostream> 00064 00065 using std::cout; 00066 using std::cerr; 00067 using std::endl; 00068 00069 00070 #include "./Cleaner.h" 00071 #include "./Utility.h" 00072 #include "./Matrix.h" 00073 #include "./Vector.h" 00074 00075 00076 00077 // forward declaration 00078 template< class T > class Matrix; 00079 template< class T > class Vector; 00080 template< class T, int l > class List; 00081 template< class T > class VarList; 00082 00084 template< class T > 00085 class SubMatrix 00086 { 00087 friend class Matrix<T>; 00088 friend class Vector<T>; 00089 00090 protected: 00091 Vector<T> *columns; 00092 Cleaner<T> *clean; 00093 int xDim; 00094 int yDim; 00095 00096 public: 00097 SubMatrix(void); 00098 SubMatrix(SubMatrix<T>& sm); 00099 ~SubMatrix(void); 00100 00101 const int Columns() const; 00102 const int Rows() const; 00103 const int XDim() const; 00104 const int YDim() const; 00105 const List<int,2> Size() const; 00106 00107 SubMatrix<T>& operator= (SubMatrix<T>& sm); 00108 T& operator() (const int i, const int j); 00109 Vector<T>& operator[] (const int i); 00110 00111 }; 00112 00113 00114 00115 00116 #include "./Submatrix.inl" 00117 00118 #endif 00119