00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #if !defined (octave_charNDArray_h)
00024 #define octave_charNDArray_h 1
00025
00026 #include "MArrayN.h"
00027 #include "chMatrix.h"
00028
00029 #include "mx-defs.h"
00030 #include "mx-op-decl.h"
00031
00032 class
00033 OCTAVE_API
00034 charNDArray : public MArrayN<char>
00035 {
00036 public:
00037
00038 typedef charMatrix matrix_type;
00039
00040 charNDArray (void) : MArrayN<char> () { }
00041
00042 charNDArray (const dim_vector& dv) : MArrayN<char> (dv) { }
00043
00044 charNDArray (const dim_vector& dv, char val) : MArrayN<char> (dv, val) { }
00045
00046 charNDArray (const charNDArray& a) : MArrayN<char> (a) { }
00047
00048 charNDArray (const charMatrix& a) : MArrayN<char> (a) { }
00049
00050 charNDArray (char c) : MArrayN<char> (charMatrix (c)) { }
00051
00052 charNDArray (const char *s) : MArrayN<char> (charMatrix (s)) { }
00053
00054 charNDArray (const std::string& s) : MArrayN<char> (charMatrix (s)) { }
00055
00056 charNDArray (const string_vector& s) : MArrayN<char> (charMatrix (s)) { }
00057
00058 charNDArray (const Array<char>& a) : MArrayN<char> (a) { }
00059
00060 charNDArray& operator = (const charNDArray& a)
00061 {
00062 MArrayN<char>::operator = (a);
00063 return *this;
00064 }
00065
00066 bool any_element_is_nan (void) const { return false; }
00067
00068
00069
00070 boolNDArray all (int dim = -1) const;
00071 boolNDArray any (int dim = -1) const;
00072 charNDArray concat (const charNDArray& rb, const Array<octave_idx_type>& ra_idx);
00073 charNDArray concat (const NDArray& rb, const Array<octave_idx_type>& ra_idx);
00074
00075 charNDArray& insert (const charNDArray& a, octave_idx_type r, octave_idx_type c);
00076 charNDArray& insert (const charNDArray& a, const Array<octave_idx_type>& ra_idx);
00077
00078 charMatrix matrix_value (void) const;
00079
00080 charNDArray squeeze (void) const { return Array<char>::squeeze (); }
00081
00082 static void increment_index (Array<octave_idx_type>& ra_idx,
00083 const dim_vector& dimensions,
00084 int start_dimension = 0);
00085
00086 static octave_idx_type compute_index (Array<octave_idx_type>& ra_idx,
00087 const dim_vector& dimensions);
00088
00089
00090
00091
00092
00093
00094 static char resize_fill_value (void) { return '\0'; }
00095
00096 charNDArray diag (octave_idx_type k = 0) const;
00097
00098 typedef int (*mapper) (int);
00099 boolNDArray bmap (mapper fcn) const;
00100 NDArray dmap (mapper fcn) const;
00101 charNDArray smap (mapper fcn) const;
00102
00103 private:
00104
00105 charNDArray (char *d, dim_vector& dv) : MArrayN<char> (d, dv) { }
00106 };
00107
00108 NDS_CMP_OP_DECLS (charNDArray, char, OCTAVE_API)
00109 NDS_BOOL_OP_DECLS (charNDArray, char, OCTAVE_API)
00110
00111 SND_CMP_OP_DECLS (char, charNDArray, OCTAVE_API)
00112 SND_BOOL_OP_DECLS (char, charNDArray, OCTAVE_API)
00113
00114 NDND_CMP_OP_DECLS (charNDArray, charNDArray, OCTAVE_API)
00115 NDND_BOOL_OP_DECLS (charNDArray, charNDArray, OCTAVE_API)
00116
00117 MARRAY_FORWARD_DEFS (MArrayN, charNDArray, char)
00118
00119 #endif
00120
00121
00122
00123
00124
00125