diff main/fixed/src/fixedNDArray.h @ 2383:d1930f8af7ca octave-forge

Changed the directory structure of fixed to match the package system
author hauberg
date Sun, 20 Aug 2006 14:43:38 +0000
parents
children 1728eb2120ef
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/main/fixed/src/fixedNDArray.h	Sun Aug 20 14:43:38 2006 +0000
@@ -0,0 +1,272 @@
+/*
+
+Copyright (C) 2004 Motorola Inc
+Copyright (C) 2004 David Bateman
+
+This program 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.
+
+This program 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 this program; see the file COPYING.  If not, write to the Free
+Software Foundation, 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+
+In addition to the terms of the GPL, you are permitted to link
+this program with any Open Source program, as defined by the
+Open Source Initiative (www.opensource.org)
+
+*/
+
+#if !defined (octave_FixedNDArray_h) && defined (HAVE_ND_ARRAYS)
+#define octave_FixedNDArray_h 1
+
+#if defined (__GNUG__) && defined (USE_PRAGMA_INTERFACE_IMPLEMENTATION)
+#pragma interface
+#endif
+
+#include <octave/MArrayN.h>
+#include <octave/dMatrix.h>
+#include <octave/dNDArray.h>
+#include <octave/boolNDArray.h>
+
+#include <octave/mx-defs.h>
+#include <octave/mx-op-defs.h>
+
+#include <octave/data-conv.h>
+#include <octave/mach-info.h>
+
+#include "int/fixed.h"
+#include "fixedMatrix.h"
+
+class FixedComplexNDArray;
+
+class
+FixedNDArray : public MArrayN<FixedPoint>
+{
+public:
+  FixedNDArray (void) : MArrayN<FixedPoint> () { }
+
+  FixedNDArray (const dim_vector& dv) : MArrayN<FixedPoint> (dv) { }
+
+  FixedNDArray (const dim_vector& dv, const FixedPoint val) 
+    : MArrayN<FixedPoint> (dv, val) { }
+
+  FixedNDArray (const MArrayN<int> &is, const MArrayN<int> &ds);
+
+  FixedNDArray (const NDArray &is, const NDArray &ds);
+
+  FixedNDArray (unsigned int is, unsigned int ds, const FixedNDArray& a);
+
+  FixedNDArray (const MArrayN<int> &is, const MArrayN<int> &ds, 
+	       const FixedNDArray& a);
+
+  FixedNDArray (const NDArray &is, const NDArray &ds, const FixedNDArray& a);
+
+  FixedNDArray (unsigned int is, unsigned int ds, const NDArray& a);
+
+  FixedNDArray (const MArrayN<int> &is, const MArrayN<int> &ds, 
+	       const NDArray& a);
+
+  FixedNDArray (const NDArray &is, const NDArray &ds, const NDArray& a);
+
+  FixedNDArray (unsigned int is, unsigned int ds, const NDArray& a, 
+	       const NDArray& b);
+
+  FixedNDArray (const MArrayN<int> &is, const MArrayN<int> &ds, 
+	       const NDArray& a, const NDArray& b);
+
+  FixedNDArray (const NDArray &is, const NDArray &ds, const NDArray& a, 
+	       const NDArray& b);
+
+  FixedNDArray (const MArrayN<int> &a);
+
+  FixedNDArray (const NDArray &a);
+
+  FixedNDArray (const FixedNDArray& a) : MArrayN<FixedPoint> (a) { }
+  FixedNDArray (const MArrayN<FixedPoint>& a) : MArrayN<FixedPoint> (a) { }
+  FixedNDArray (const ArrayN<FixedPoint>& a) : MArrayN<FixedPoint> (a) { }
+
+  NDArray sign (void) const;
+  NDArray signbit (void) const;
+  NDArray getdecsize (void) const;
+  NDArray getintsize (void) const;
+  NDArray getnumber (void) const;
+  NDArray fixedpoint (void) const;
+  FixedNDArray chdecsize (const double n);
+  FixedNDArray chdecsize (const NDArray &n);
+  FixedNDArray chintsize (const double n);
+  FixedNDArray chintsize (const NDArray &n);
+  FixedNDArray incdecsize (const double n);
+  FixedNDArray incdecsize (const NDArray &n);
+  FixedNDArray incdecsize ();
+  FixedNDArray incintsize (const double n);
+  FixedNDArray incintsize (const NDArray &n);
+  FixedNDArray incintsize ();
+
+  FixedNDArray& operator = (const FixedNDArray& a)
+    {
+      MArrayN<FixedPoint>::operator = (a);
+      return *this;
+    }
+
+  bool operator == (const FixedNDArray& a) const;
+  bool operator != (const FixedNDArray& a) const;
+
+  FixedNDArray operator ! (void) const;
+
+  boolNDArray all (octave_idx_type dim = -1) const;
+  boolNDArray any (octave_idx_type dim = -1) const;
+
+#ifdef HAVE_OLD_OCTAVE_CONCAT
+  friend FixedNDArray concat (const FixedNDArray& ra, const FixedNDArray& rb, 
+			      const Array<octave_idx_type>& ra_idx);
+#endif
+
+#ifdef HAVE_OCTAVE_CONCAT
+  FixedNDArray concat (const FixedNDArray& rb, const Array<octave_idx_type>& ra_idx);
+  FixedComplexNDArray concat (const FixedComplexNDArray& rb, 
+			      const Array<octave_idx_type>& ra_idx);
+#endif
+
+#if defined (HAVE_OCTAVE_CONCAT) || (HAVE_OLD_OCTAVE_CONCAT)
+  FixedNDArray& insert (const FixedNDArray& a, const Array<octave_idx_type>& ra_idx);
+#endif
+
+  FixedNDArray cumprod (octave_idx_type dim = -1) const;
+  FixedNDArray cumsum (octave_idx_type dim = -1) const;
+  FixedNDArray prod (octave_idx_type dim = -1) const;
+  FixedNDArray sum (octave_idx_type dim = -1) const;  
+  FixedNDArray sumsq (octave_idx_type dim = -1) const;
+
+  FixedNDArray max (octave_idx_type dim = 0) const;
+  FixedNDArray max (ArrayN<octave_idx_type>& index, octave_idx_type dim = 0) const;
+  FixedNDArray min (octave_idx_type dim = 0) const;
+  FixedNDArray min (ArrayN<octave_idx_type>& index, octave_idx_type dim = 0) const;
+  
+  FixedNDArray abs (void) const;
+
+  FixedMatrix fixed_matrix_value (void) const;
+
+  FixedNDArray squeeze (void) const { return ArrayN<FixedPoint>::squeeze (); }
+
+  static void increment_index (Array<octave_idx_type>& ra_idx,
+			       const dim_vector& dimensions,
+			       octave_idx_type start_dimension = 0);
+
+  static octave_idx_type compute_index (Array<octave_idx_type>& ra_idx,
+			    const dim_vector& dimensions);
+
+  // friend FixedNDArray abs  (const FixedNDArray &x);
+  friend FixedNDArray cos  (const FixedNDArray &x);
+  friend FixedNDArray cosh  (const FixedNDArray &x);
+  friend FixedNDArray sin  (const FixedNDArray &x);
+  friend FixedNDArray sinh  (const FixedNDArray &x);
+  friend FixedNDArray tan  (const FixedNDArray &x);
+  friend FixedNDArray tanh  (const FixedNDArray &x);
+
+  friend FixedNDArray sqrt  (const FixedNDArray &x);
+  friend FixedNDArray exp  (const FixedNDArray &x);
+  friend FixedNDArray log  (const FixedNDArray &x);
+  friend FixedNDArray log10  (const FixedNDArray &x);
+
+  friend FixedNDArray atan2 (const FixedNDArray &x, const FixedNDArray &y);
+
+  friend FixedNDArray round (const FixedNDArray &x);
+  friend FixedNDArray rint (const FixedNDArray &x);
+  friend FixedNDArray floor (const FixedNDArray &x);
+  friend FixedNDArray ceil (const FixedNDArray &x);
+
+  friend FixedNDArray real (const FixedNDArray& a);
+  friend FixedNDArray imag (const FixedNDArray& a);
+  friend FixedNDArray conj (const FixedNDArray &x);
+
+  friend NDArray fixedpoint (const FixedNDArray& x);
+  friend NDArray sign (const FixedNDArray& x);
+  friend NDArray signbit (const FixedNDArray& x);
+  friend NDArray getdecsize (const FixedNDArray& x);
+  friend NDArray getintsize (const FixedNDArray& x);
+  friend NDArray getnumber (const FixedNDArray& x);
+
+  // i/o
+
+  friend std::ostream& operator << (std::ostream& os, const FixedNDArray& a);
+  friend std::istream& operator >> (std::istream& is, FixedNDArray& a);
+
+  static FixedPoint resize_fill_value (void) { return FixedPoint(); }
+
+private:
+
+  FixedNDArray (FixedPoint *d, const dim_vector& dv) : MArrayN<FixedPoint> (d, dv) { }
+  
+};
+
+// FixedNDArray abs  (const FixedNDArray &x);
+FixedNDArray cos  (const FixedNDArray &x);
+FixedNDArray cosh  (const FixedNDArray &x);
+FixedNDArray sin  (const FixedNDArray &x);
+FixedNDArray sinh  (const FixedNDArray &x);
+FixedNDArray tan  (const FixedNDArray &x);
+FixedNDArray tanh  (const FixedNDArray &x);
+
+FixedNDArray sqrt  (const FixedNDArray &x);
+FixedNDArray exp  (const FixedNDArray &x);
+FixedNDArray log  (const FixedNDArray &x);
+FixedNDArray log10  (const FixedNDArray &x);
+
+FixedNDArray atan2 (const FixedNDArray &x, const FixedNDArray &y);
+
+FixedNDArray round (const FixedNDArray &x);
+FixedNDArray rint (const FixedNDArray &x);
+FixedNDArray floor (const FixedNDArray &x);
+FixedNDArray ceil (const FixedNDArray &x);
+
+FixedNDArray real (const FixedNDArray& a);
+FixedNDArray imag (const FixedNDArray& a);
+FixedNDArray conj (const FixedNDArray &x);
+
+inline NDArray fixedpoint (const FixedNDArray& x) { return x.fixedpoint(); }
+inline NDArray sign (const FixedNDArray& x) { return x.sign(); }
+inline NDArray signbit (const FixedNDArray& x) { return x.signbit(); }
+inline NDArray getdecsize (const FixedNDArray& x) { return x.getdecsize(); }
+inline NDArray getintsize (const FixedNDArray& x) { return x.getintsize(); }
+inline NDArray getnumber (const FixedNDArray& x) { return x.getnumber(); }
+
+std::ostream& operator << (std::ostream& os, const FixedNDArray& a);
+std::istream& operator >> (std::istream& is, FixedNDArray& a);
+
+FixedNDArray min (double d, const FixedNDArray& m);
+FixedNDArray min (const FixedNDArray& m, double d);
+FixedNDArray min (const FixedNDArray& a, const FixedNDArray& b);
+
+FixedNDArray max (double d, const FixedNDArray& m);
+FixedNDArray max (const FixedNDArray& m, double d);
+FixedNDArray max (const FixedNDArray& a, const FixedNDArray& b);
+
+FixedNDArray elem_pow (const FixedNDArray &a, const FixedNDArray &b);
+FixedNDArray elem_pow (const FixedNDArray &a, const FixedPoint &b);
+FixedNDArray elem_pow (const FixedPoint &a, const FixedNDArray &b);
+
+NDS_CMP_OP_DECLS (FixedNDArray, FixedPoint)
+NDS_BOOL_OP_DECLS (FixedNDArray, FixedPoint)
+
+SND_CMP_OP_DECLS (FixedPoint, FixedNDArray)
+SND_BOOL_OP_DECLS (FixedPoint, FixedNDArray)
+
+NDND_CMP_OP_DECLS (FixedNDArray, FixedNDArray)
+NDND_BOOL_OP_DECLS (FixedNDArray, FixedNDArray)
+
+MARRAY_FORWARD_DEFS (MArrayN, FixedNDArray, FixedPoint)
+
+#endif
+
+/*
+;;; Local Variables: ***
+;;; mode: C++ ***
+;;; End: ***
+*/