Mercurial > hg > octave-nkf
view liboctave/MArrayN.h @ 5915:b2e1be30c8e9 ss-2-9-7
[project @ 2006-07-28 18:08:56 by jwe]
author | jwe |
---|---|
date | Fri, 28 Jul 2006 18:08:56 +0000 |
parents | dfa2da0563e5 |
children | 0ce71beb1cf3 |
line wrap: on
line source
// Template array classes with like-type math ops /* Copyright (C) 1996, 1997 John W. Eaton This file is part of Octave. Octave is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. Octave is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Octave; see the file COPYING. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #if !defined (octave_MArrayN_h) #define octave_MArrayN_h 1 #include "ArrayN.h" #include "MArray2.h" #include "dim-vector.h" // N-dimensional array with math ops. // But first, some preprocessor abuse... #include "MArray-defs.h" MARRAY_OPS_FORWARD_DECLS (MArrayN) template <class T> class MArrayN : public ArrayN<T> { protected: MArrayN (T *d, const dim_vector& dv) : ArrayN<T> (d, dv) { } public: MArrayN (void) : ArrayN<T> () {} MArrayN (const dim_vector& dv) : ArrayN<T> (dv) { } MArrayN (const dim_vector& dv, const T& val) : ArrayN<T> (dv, val) { } template <class U> explicit MArrayN (const Array2<U>& a) : ArrayN<T> (a) { } template <class U> MArrayN (const ArrayN<U>& a) : ArrayN<T> (a) { } template <class U> MArrayN (const MArrayN<U>& a) : ArrayN<T> (a) { } ~MArrayN (void) { } MArrayN<T>& operator = (const MArrayN<T>& a) { ArrayN<T>::operator = (a); return *this; } octave_idx_type nnz (void) const { octave_idx_type retval = 0; const T *d = this->data (); octave_idx_type nel = this->numel (); for (octave_idx_type i = 0; i < nel; i++) { if (d[i] != T ()) retval++; } return retval; } MArrayN<T> reshape (const dim_vector& new_dims) const { return ArrayN<T>::reshape (new_dims); } MArrayN<T> permute (const Array<int>& vec, bool inv = false) const { return ArrayN<T>::permute (vec, inv); } MArrayN<T> ipermute (const Array<int>& vec) const { return ArrayN<T>::ipermute (vec); } MArrayN squeeze (void) const { return ArrayN<T>::squeeze (); } }; #endif /* ;;; Local Variables: *** ;;; mode: C++ *** ;;; End: *** */