00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef TNT_ARRAY1D_H
00023 #define TNT_ARRAY1D_H
00024
00025
00026 #include <iostream>
00027
00028 #ifdef TNT_BOUNDS_CHECK
00029 #include <assert.h>
00030 #endif
00031
00032
00033 #include "tnt_i_refvec.h"
00034
00035 namespace TNT
00036 {
00037
00038 template <class T>
00039 class Array1D
00040 {
00041
00042 private:
00043
00044
00045 i_refvec<T> v_;
00046 int n_;
00047 T* data_;
00048
00049
00050
00051
00052 void copy_(T* p, const T* q, int len) const;
00053 void set_(T* begin, T* end, const T& val);
00054
00055
00056 public:
00057
00058 typedef T value_type;
00059
00060
00061 Array1D();
00062 explicit Array1D(int n);
00063 Array1D(int n, const T &a);
00064 Array1D(int n, T *a);
00065 inline Array1D(const Array1D &A);
00066 inline operator T*();
00067 inline operator const T*();
00068 inline Array1D & operator=(const T &a);
00069 inline Array1D & operator=(const Array1D &A);
00070 inline Array1D & ref(const Array1D &A);
00071 Array1D copy() const;
00072 Array1D & inject(const Array1D & A);
00073 inline T& operator[](int i);
00074 inline T& operator()(int i);
00075 inline const T& operator[](int i) const;
00076 inline const T& operator()(int i) const;
00077 inline int dim1() const;
00078 inline int dim() const;
00079 ~Array1D();
00080
00081
00082
00083
00084 inline int ref_count() const;
00085 inline Array1D<T> subarray(int i0, int i1);
00086
00087 };
00088
00089
00090
00091
00092 template <class T>
00093 Array1D<T>::Array1D() : v_(), n_(0), data_(0) {}
00094
00095 template <class T>
00096 Array1D<T>::Array1D(const Array1D<T> &A) : v_(A.v_), n_(A.n_),
00097 data_(A.data_)
00098 {
00099 #ifdef TNT_DEBUG
00100 std::cout << "Created Array1D(const Array1D<T> &A) \n";
00101 #endif
00102
00103 }
00104
00105 template <class T>
00106 Array1D<T>::Array1D(int n) : v_(n), n_(n), data_(v_.begin())
00107 {
00108 #ifdef TNT_DEBUG
00109 std::cout << "Created Array1D(int n) \n";
00110 #endif
00111 }
00112
00113 template <class T>
00114 Array1D<T>::Array1D(int n, const T &val) : v_(n), n_(n), data_(v_.begin())
00115 {
00116 #ifdef TNT_DEBUG
00117 std::cout << "Created Array1D(int n, const T& val) \n";
00118 #endif
00119 set_(data_, data_+ n, val);
00120
00121 }
00122
00123 template <class T>
00124 Array1D<T>::Array1D(int n, T *a) : v_(a), n_(n) , data_(v_.begin())
00125 {
00126 #ifdef TNT_DEBUG
00127 std::cout << "Created Array1D(int n, T* a) \n";
00128 #endif
00129 }
00130
00131 template <class T>
00132 inline Array1D<T>::operator T*()
00133 {
00134 return &(v_[0]);
00135 }
00136
00137
00138 template <class T>
00139 inline Array1D<T>::operator const T*()
00140 {
00141 return &(v_[0]);
00142 }
00143
00144
00145
00146 template <class T>
00147 inline T& Array1D<T>::operator[](int i)
00148 {
00149 #ifdef TNT_BOUNDS_CHECK
00150 assert(i>= 0);
00151 assert(i < n_);
00152 #endif
00153 return data_[i];
00154 }
00155
00156 template <class T>
00157 inline const T& Array1D<T>::operator[](int i) const
00158 {
00159 #ifdef TNT_BOUNDS_CHECK
00160 assert(i>= 0);
00161 assert(i < n_);
00162 #endif
00163 return data_[i];
00164 }
00165
00166
00167
00168 template <class T>
00169 inline T& Array1D<T>::operator()(int i)
00170 {
00171 #ifdef TNT_BOUNDS_CHECK
00172 assert(i>= 0);
00173 assert(i < n_);
00174 #endif
00175 return data_[i-1];
00176 }
00177
00178 template <class T>
00179 inline const T& Array1D<T>::operator()(int i) const
00180 {
00181 #ifdef TNT_BOUNDS_CHECK
00182 assert(i>= 0);
00183 assert(i < n_);
00184 #endif
00185 return data_[i-1];
00186 }
00187
00188
00189
00190
00191 template <class T>
00192 Array1D<T> & Array1D<T>::operator=(const T &a)
00193 {
00194 set_(data_, data_+n_, a);
00195 return *this;
00196 }
00197
00198 template <class T>
00199 Array1D<T> Array1D<T>::copy() const
00200 {
00201 Array1D A( n_);
00202 copy_(A.data_, data_, n_);
00203
00204 return A;
00205 }
00206
00207
00208 template <class T>
00209 Array1D<T> & Array1D<T>::inject(const Array1D &A)
00210 {
00211 if (A.n_ == n_)
00212 copy_(data_, A.data_, n_);
00213
00214 return *this;
00215 }
00216
00217
00218
00219
00220
00221 template <class T>
00222 Array1D<T> & Array1D<T>::ref(const Array1D<T> &A)
00223 {
00224 if (this != &A)
00225 {
00226 v_ = A.v_;
00227 n_ = A.n_;
00228 data_ = A.data_;
00229
00230 }
00231 return *this;
00232 }
00233
00234 template <class T>
00235 Array1D<T> & Array1D<T>::operator=(const Array1D<T> &A)
00236 {
00237 return ref(A);
00238 }
00239
00240 template <class T>
00241 inline int Array1D<T>::dim1() const { return n_; }
00242
00243 template <class T>
00244 inline int Array1D<T>::dim() const { return n_; }
00245
00246 template <class T>
00247 Array1D<T>::~Array1D() {}
00248
00249
00250
00251
00252 template <class T>
00253 inline int Array1D<T>::ref_count() const
00254 {
00255 return v_.ref_count();
00256 }
00257
00258 template <class T>
00259 inline Array1D<T> Array1D<T>::subarray(int i0, int i1)
00260 {
00261 if ((i0 >= 0) && (i1 < n_) || (i0 <= i1))
00262 {
00263 Array1D<T> X(*this);
00264 X.n_ = i1-i0+1;
00265 X.data_ += i0;
00266
00267 return X;
00268 }
00269 else
00270 {
00271 return Array1D<T>();
00272 }
00273 }
00274
00275
00276
00277
00278
00279 template <class T>
00280 void Array1D<T>::set_(T* begin, T* end, const T& a)
00281 {
00282 for (T* p=begin; p<end; p++)
00283 *p = a;
00284
00285 }
00286
00287 template <class T>
00288 void Array1D<T>::copy_(T* p, const T* q, int len) const
00289 {
00290 T *end = p + len;
00291 while (p<end )
00292 *p++ = *q++;
00293
00294 }
00295
00296
00297 }
00298
00299 #endif
00300
00301