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