Array.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 ARRAY_H
00061 #define ARRAY_H
00062 
00063 #include "./cimpl.h"
00064 
00065 
00066 #include <cstdarg>
00067 
00068 #include <iostream>
00069 
00070 using std::cout;
00071 using std::cerr;
00072 using std::endl;
00073 
00074 
00075 
00076 namespace CIMPL
00077 {
00078 
00079 // forward declaration
00080 template< class T > class Array;
00081 template< class T > class Matrix;
00082 template< class T > class Vector;
00083 
00085 template< class T >
00086 class Array
00087 {
00088 
00089         friend class Matrix<T>;
00090         friend class Vector<T>;
00091 
00092 
00093 protected:
00094         T *data;
00095         int ndims;
00096         int length;
00097         int *dims;
00098         Cleaner<T> *clean;   // Reference counting Garbage collector.
00099 
00100 
00101 public:
00102         Array();
00103         explicit Array(const int);
00104         Array(const int, const int);
00105         Array(const int, const int, const int);
00106         Array(const int, const int, const int, const int, ...);
00107         Array(const int _ndims, const int* _dims);
00108         Array(Array<T> &m);
00109 
00110 
00111         ~Array();
00112 
00113         // Useful for passing data to third party libraries.
00114         const T* DataPtr();
00115         T* Data();
00116 
00117         Array<T> Clone() const;
00118 
00119 
00120 
00121         const int XDim() const;
00122         const int YDim() const;
00123         const int ZDim() const;
00124         const int* Dims() const;
00125         const int* Size() const;
00126         int Length() const;
00127         int NDims() const;
00128         void Init(const T init);
00129 
00130 
00131 
00132         static bool IsCompatible(Array<T>& m1, Array<T>& m2);
00133 
00134         // Boolean Operations...
00135         static Array<int> And(Array<T>& m1, Array<T>& m2);
00136         static Array<int> Or(Array<T>& m1, Array<T>& m2);
00137         static Array<int> Lt(Array<T>& m1, Array<T>& m2);
00138         static Array<int> Gt(Array<T>& m1, Array<T>& m2);
00139         static Array<int> Le(Array<T>& m1, Array<T>& m2);
00140         static Array<int> Ge(Array<T>& m1, Array<T>& m2);
00141         static Array<int> Eq(Array<T>& m1, Array<T>& m2);
00142         static Array<int> Ne(Array<T>& m1, Array<T>& m2);
00143 
00144         // Boolean Operations with value type...
00145         static Array<int> And(Array<T>& m, T v);
00146         static Array<int> Or(Array<T>& m, T v);
00147         static Array<int> Lt(Array<T>& m, T v);
00148         static Array<int> Gt(Array<T>& m, T v);
00149         static Array<int> Le(Array<T>& m, T v);
00150         static Array<int> Ge(Array<T>& m, T v);
00151         static Array<int> Eq(Array<T>& m, T v);
00152         static Array<int> Ne(Array<T>& m, T v);
00153 
00154 
00155         // Add matrix to another matrix
00156         static Array<T> Add(Array<T>& m1, Array<T>& m2);
00157         static Array<T> Subtract(Array<T>& m1, Array<T>& m2);
00158         static Array<T> Multiply(Array<T>& m1, Array<T>& m2);
00159         static Array<T> Divide(Array<T>& m1, Array<T>& m2);
00160 
00161         // Add value to another matrix
00162         static Array<T> Add(Array<T>& m1, T v2);
00163         static Array<T> Subtract(Array<T>& m1, T v2);
00164         static Array<T> Subtract(T v2, Array<T>& m1);
00165         static Array<T> Multiply(Array<T>& m1, T v2);
00166         static Array<T> Divide(Array<T>& m1, T v2);
00167         static Array<T> Divide(T v2, Array<T>& m1);
00168 
00169 
00170 
00171         // Add matrix to "this" matrix
00172         Array<T>& Add(Array<T>& m);
00173         Array<T>& Subtract(Array<T>& m);
00174         Array<T>& Multiply(Array<T>& m);
00175         Array<T>& Divide(Array<T>& m);
00176 
00177         // Add value to "this" matrix
00178         Array<T>& Add(T v);
00179         Array<T>& Subtract(T v);
00180         Array<T>& Multiply(T v);
00181         Array<T>& Divide(T v);
00182 
00183 
00184 
00185 
00186 
00187 // OPERATORS
00188 
00189         // Assignment
00190         Array<T>& operator= (Array<T>& m);
00191         Array<T>& operator= (Matrix<T>& m);
00192         //***
00193         Array<T>& operator= (Vector<T>& m);
00194 
00195 
00196         // Unary +-!
00197         Array<T> operator+ ();
00198         Array<T> operator- ();
00199         Array<int> operator! ();
00200 
00201 
00202         // Access to the elements
00203         T& operator() (const int i);
00204         
00205                 // no bounds cheking...
00206         T& operator[] (const int i);
00207         
00208         
00209         T& operator() (const int i, const int j, ...);
00210 
00211 
00212         T& Elem(const int i, const int j, ...);
00213         T& ElemNC(const int i, const int j, ...); // No bounds check
00214         T& Elem(const int i);
00215         T& ElemNC(const int i); // No bounds check
00216 
00217 
00218 
00219         // Boolean operations
00220         friend Array<int> operator&& (Array<T>& m1, Array<T>& m2)
00221         {
00222                 return Array<T>::And(m1, m2);
00223         }
00224 
00225         friend Array<int> operator|| (Array<T>& m1, Array<T>& m2)
00226         {
00227                 return Array<T>::Or(m1, m2);
00228         }
00229 
00230         friend Array<int> operator< (Array<T>& m1, Array<T>& m2)
00231         {
00232                 return Array<T>::Lt(m1, m2);
00233         }
00234 
00235         friend Array<int> operator> (Array<T>& m1, Array<T>& m2)
00236         {
00237                 return Array<T>::Gt(m1, m2);
00238         }
00239 
00240         friend Array<int> operator<= (Array<T>& m1, Array<T>& m2)
00241         {
00242                 return Array<T>::Le(m1, m2);
00243         }
00244 
00245         friend Array<int> operator>= (Array<T>& m1, Array<T>& m2)
00246         {
00247                 return Array<T>::Ge(m1, m2);
00248         }
00249 
00250         friend Array<int> operator== (Array<T>& m1, Array<T>& m2)
00251         {
00252                 return Array<T>::Eq(m1, m2);
00253         }
00254 
00255         friend Array<int> operator!= (Array<T>& m1, Array<T>& m2)
00256         {
00257                 return Array<T>::Ne(m1, m2);
00258         }
00259 
00260 
00261 
00262         // Boolean operations with value type
00263         friend Array<int> operator&& (Array<T>& m, T v)
00264         {
00265                 return Array<T>::And(m, v);
00266         }
00267         friend Array<int> operator&& (T v, Array<T>& m)
00268         {
00269                 return Array<T>::And(m, v);
00270         }
00271 
00272         friend Array<int> operator|| (Array<T>& m, T v)
00273         {
00274                 return Array<T>::Or(m, v);
00275         }
00276         friend Array<int> operator|| (T v, Array<T>& m)
00277         {
00278                 return Array<T>::Or(m, v);
00279         }
00280 
00281         friend Array<int> operator< (Array<T>& m, T v)
00282         {
00283                 return Array<T>::Lt(m, v);
00284         }
00285         friend Array<int> operator< (T v, Array<T>& m)
00286         {
00287                 return Array<T>::Gt(m, v);
00288         }
00289 
00290         friend Array<int> operator> (Array<T>& m, T v)
00291         {
00292                 return Array<T>::Gt(m, v);
00293         }
00294         friend Array<int> operator> (T v, Array<T>& m)
00295         {
00296                 return Array<T>::Lt(m, v);
00297         }
00298 
00299         friend Array<int> operator<= (Array<T>& m, T v)
00300         {
00301                 return Array<T>::Le(m, v);
00302         }
00303         friend Array<int> operator<= (T v, Array<T>& m)
00304         {
00305                 return Array<T>::Ge(m, v);
00306         }
00307 
00308         friend Array<int> operator>= (Array<T>& m, T v)
00309         {
00310                 return Array<T>::Ge(m, v);
00311         }
00312         friend Array<int> operator>= (T v, Array<T>& m)
00313         {
00314                 return Array<T>::Le(m, v);
00315         }
00316 
00317         friend Array<int> operator== (Array<T>& m, T v)
00318         {
00319                 return Array<T>::Eq(m, v);
00320         }
00321         friend Array<int> operator== (T v, Array<T>& m)
00322         {
00323                 return Array<T>::Eq(m, v);
00324         }
00325 
00326         friend Array<int> operator!= (Array<T>& m, T v)
00327         {
00328                 return Array<T>::Ne(m, v);
00329         }
00330         friend Array<int> operator!= (T v, Array<T>& m)
00331         {
00332                 return Array<T>::Ne(m, v);
00333         }
00334 
00335 
00336 
00337 
00338 
00339         // Matrix to Matrix elementwise math operations.
00340         friend Array<T> operator+ (Array<T>& m1, Array<T>& m2)
00341         {
00342                 return Array<T>::Add(m1, m2);
00343         }
00344 
00345         friend Array<T> operator- (Array<T>& m1, Array<T>& m2)
00346         {
00347                 return Array<T>::Subtract(m1, m2);
00348         }
00349 
00350         friend Array<T> operator* (Array<T>& m1, Array<T>& m2)
00351         {
00352                 return Array<T>::Multiply(m1, m2);
00353         }
00354 
00355         friend Array<T> operator/ (Array<T>& m1, Array<T>& m2)
00356         {
00357                 return Array<T>::Divide(m1, m2);
00358         }
00359 
00360 
00361 
00362         // Matrix - value math operations.
00363         friend Array<T> operator+ (Array<T>& m, T v)
00364         {
00365                 return Array<T>::Add(m, v);
00366         }
00367 
00368         friend Array<T> operator+ (T v, Array<T>& m)
00369         {
00370                 return Array<T>::Add(m, v);
00371         }
00372 
00373         friend Array<T> operator- (Array<T>& m, T v)
00374         {
00375                 return Array<T>::Subtract(m, v);
00376         }
00377 
00378         friend Array<T> operator- (T v, Array<T>& m)
00379         {
00380                 return Array<T>::Subtract(v, m);
00381         }
00382 
00383         friend Array<T> operator* (Array<T>& m, T v)
00384         {
00385                 return Array<T>::Multiply(m, v);
00386         }
00387 
00388         friend Array<T> operator* (T v, Array<T>& m)
00389         {
00390                 return Array<T>::Multiply(m, v);
00391         }
00392 
00393         friend Array<T> operator/ (Array<T>& m, T v)
00394         {
00395                 return Array<T>::Divide(m, v);
00396         }
00397 
00398         friend Array<T> operator/ (T v, Array<T>& m)
00399         {
00400                 return Array<T>::Divide(v, m);
00401         }
00402 
00403 
00404 
00405 
00406         // Inline math operations
00407         Array<T>& operator+= (Array<T>& m);
00408         Array<T>& operator-= (Array<T>& m);
00409         Array<T>& operator*= (Array<T>& m);
00410         Array<T>& operator/= (Array<T>& m);
00411 
00412         Array<T>& operator+= (T v);
00413         Array<T>& operator-= (T v);
00414         Array<T>& operator*= (T v);
00415         Array<T>& operator/= (T v);
00416 
00417 
00418 // TYPE CONVERSIONS
00419         Array(Matrix<T> &m);
00420         Array(Vector<T> &m);
00421 
00422 
00423 };
00424 
00425 
00426 }; //namespace
00427 
00428 
00429 
00430 #include "./Array.inl"
00431 
00432 
00433 
00434 
00435 
00436 #endif
00437 
00438 
00439 
00440 
00441 
00442 
00443 
00444 
00445 
00446 

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