/* 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, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #if defined (__GNUG__) #pragma implementation #endif #ifdef HAVE_CONFIG_H #include #endif #include "MDiagArray2.h" #include "lo-error.h" #include "MArray-defs.h" // Two dimensional diagonal array with math ops. // Element by element MDiagArray2 by MDiagArray2 ops. template MDiagArray2& operator += (MDiagArray2& a, const MDiagArray2& b) { int r = a.rows (); int c = a.cols (); int b_nr = b.rows (); int b_nc = b.cols (); if (r != b_nr || c != b_nc) { gripe_nonconformant ("operator +=", r, c, b_nr, b_nc); static MDiagArray2 foo; return foo; } else { int l = a.length (); DO_VV_OP2 (+=); } return a; } template MDiagArray2& operator -= (MDiagArray2& a, const MDiagArray2& b) { int r = a.rows (); int c = a.cols (); int b_nr = b.rows (); int b_nc = b.cols (); if (r != b_nr || c != b_nc) { gripe_nonconformant ("operator -=", r, c, b_nr, b_nc); static MDiagArray2 foo; return foo; } else { int l = a.length (); DO_VV_OP2 (-=); } return a; } // Element by element MDiagArray2 by scalar ops. #define MARRAY_DAS_OP(OP) \ template \ MDiagArray2 \ operator OP (const MDiagArray2& a, const T& s) \ { \ DO_VS_OP (OP); \ return MDiagArray2 (result, a.rows (), a.cols ()); \ } MARRAY_DAS_OP (*) MARRAY_DAS_OP (/) // Element by element scalar by MDiagArray2 ops. template MDiagArray2 operator * (const T& s, const MDiagArray2& a) { DO_SV_OP (*); return MDiagArray2 (result, a.rows (), a.cols ()); } // Element by element MDiagArray2 by MDiagArray2 ops. #define MARRAY_DADA_OP(FCN, OP) \ template \ MDiagArray2 \ FCN (const MDiagArray2& a, const MDiagArray2& b) \ { \ int r = a.rows (); \ int c = a.cols (); \ int b_nr = b.rows (); \ int b_nc = b.cols (); \ if (r != b_nr || c != b_nc) \ { \ gripe_nonconformant (#FCN, r, c, b_nr, b_nc); \ return MDiagArray2 (); \ } \ if (c == 0 || r == 0) \ return MDiagArray2 (); \ int l = a.length (); \ DO_VV_OP (OP); \ return MDiagArray2 (result, r, c); \ } MARRAY_DADA_OP (operator +, +) MARRAY_DADA_OP (operator -, -) MARRAY_DADA_OP (product, *) // Unary MDiagArray2 ops. template MDiagArray2 operator - (const MDiagArray2& a) { NEG_V; return MDiagArray2 (result, a.rows (), a.cols ()); } /* ;;; Local Variables: *** ;;; mode: C++ *** ;;; End: *** */