00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054 #include "Sacado_ConfigDefs.h"
00055 #include "Sacado_mpl_range_c.hpp"
00056 #include "Sacado_mpl_for_each.hpp"
00057
00058 template <typename T, int Num>
00059 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00060 Expr(const int sz, const T & x) : val_(x)
00061 {
00062 #ifdef SACADO_DEBUG
00063 if (sz != Num)
00064 throw "SELRFad::SFad() Error: Supplied derivative dimension does not match compile time length.";
00065 #endif
00066
00067 ss_array<T>::zero(dx_, Num);
00068 }
00069
00070 template <typename T, int Num>
00071 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00072 Expr(const int sz, const int i, const T & x) : val_(x)
00073 {
00074 #ifdef SACADO_DEBUG
00075 if (sz != Num)
00076 throw "SELRFad::SFad() Error: Supplied derivative dimension does not match compile time length.";
00077 if (i >= Num)
00078 throw "SELRFad::SFad() Error: Invalid derivative index.";
00079 #endif
00080
00081 ss_array<T>::zero(dx_, Num);
00082 dx_[i]=1.;
00083 }
00084
00085 template <typename T, int Num>
00086 template <typename S>
00087 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00088 Expr(const Expr<S>& x) : val_(x.val())
00089 {
00090 #ifdef SACADO_DEBUG
00091 if (x.size() != Num)
00092 throw "SELRFad::SFad() Error: Attempt to assign with incompatible sizes";
00093 #endif
00094
00095
00096 const int N = Expr<S>::num_args;
00097
00098
00099 LocalAccumOp< Expr<S> > op(x);
00100
00101
00102 for(int i=0; i<Num; ++i) {
00103 op.t = T(0.);
00104 op.i = i;
00105
00106
00107
00108
00109 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00110
00111 dx_[i] = op.t;
00112
00113 }
00114 }
00115
00116
00117 template <typename T, int Num>
00118 inline void
00119 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00120 diff(const int ith, const int n)
00121 {
00122 #ifdef SACADO_DEBUG
00123 if (n != Num)
00124 throw "SELRFad::diff() Error: Supplied derivative dimension does not match compile time length.";
00125 #endif
00126
00127 ss_array<T>::zero(dx_, Num);
00128 dx_[ith] = T(1.);
00129 }
00130
00131 template <typename T, int Num>
00132 inline void
00133 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00134 resize(int sz)
00135 {
00136 #ifdef SACADO_DEBUG
00137 if (sz != Num)
00138 throw "SELRFad::resize() Error: Cannot resize fixed derivative array dimension";
00139 #endif
00140 }
00141
00142 template <typename T, int Num>
00143 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00144 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00145 operator=(const T& val)
00146 {
00147 val_ = val;
00148 ss_array<T>::zero(dx_, Num);
00149
00150 return *this;
00151 }
00152
00153 template <typename T, int Num>
00154 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00155 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00156 operator=(const Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >& x)
00157 {
00158
00159 val_ = x.val_;
00160
00161
00162
00163 for (int i=0; i<Num; i++)
00164 dx_[i] = x.dx_[i];
00165
00166 return *this;
00167 }
00168
00169 template <typename T, int Num>
00170 template <typename S>
00171 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00172 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00173 operator=(const Expr<S>& x)
00174 {
00175 #ifdef SACADO_DEBUG
00176 if (x.size() != Num)
00177 throw "SELRFad::operator=() Error: Attempt to assign with incompatible sizes";
00178 #endif
00179
00180
00181 const int N = Expr<S>::num_args;
00182
00183
00184 LocalAccumOp< Expr<S> > op(x);
00185
00186
00187 for(int i=0; i<Num; ++i) {
00188 op.t = T(0.);
00189 op.i = i;
00190
00191
00192
00193
00194 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00195
00196 dx_[i] = op.t;
00197 }
00198
00199
00200 val_ = x.val();
00201
00202 return *this;
00203 }
00204
00205 template <typename T, int Num>
00206 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00207 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00208 operator += (const T& val)
00209 {
00210 val_ += val;
00211
00212 return *this;
00213 }
00214
00215 template <typename T, int Num>
00216 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00217 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00218 operator -= (const T& val)
00219 {
00220 val_ -= val;
00221
00222 return *this;
00223 }
00224
00225 template <typename T, int Num>
00226 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00227 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00228 operator *= (const T& val)
00229 {
00230 val_ *= val;
00231
00232 for (int i=0; i<Num; ++i)
00233 dx_[i] *= val;
00234
00235 return *this;
00236 }
00237
00238 template <typename T, int Num>
00239 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00240 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00241 operator /= (const T& val)
00242 {
00243 val_ /= val;
00244
00245 for (int i=0; i<Num; ++i)
00246 dx_[i] /= val;
00247
00248 return *this;
00249 }
00250
00251 template <typename T, int Num>
00252 template <typename S>
00253 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00254 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00255 operator += (const Sacado::ELRFad::Expr<S>& x)
00256 {
00257 #ifdef SACADO_DEBUG
00258 if (x.size() != Num)
00259 throw "SELRFad::operator+=() Error: Attempt to assign with incompatible sizes";
00260 #endif
00261
00262
00263 const int N = Expr<S>::num_args;
00264
00265
00266 LocalAccumOp< Expr<S> > op(x);
00267
00268
00269 for(int i=0; i<Num; ++i) {
00270 op.t = T(0.);
00271 op.i = i;
00272
00273
00274
00275
00276 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00277
00278 dx_[i] += op.t;
00279 }
00280
00281
00282 val_ += x.val();
00283
00284 return *this;
00285 }
00286
00287 template <typename T, int Num>
00288 template <typename S>
00289 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00290 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00291 operator -= (const Sacado::ELRFad::Expr<S>& x)
00292 {
00293 #ifdef SACADO_DEBUG
00294 if (x.size() != Num)
00295 throw "SELRFad::operator-=() Error: Attempt to assign with incompatible sizes";
00296 #endif
00297
00298
00299 const int N = Expr<S>::num_args;
00300
00301
00302 LocalAccumOp< Expr<S> > op(x);
00303
00304
00305 for(int i=0; i<Num; ++i) {
00306 op.t = T(0.);
00307 op.i = i;
00308
00309
00310
00311
00312 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00313
00314 dx_[i] -= op.t;
00315 }
00316
00317
00318 val_ -= x.val();
00319
00320 return *this;
00321 }
00322
00323 template <typename T, int Num>
00324 template <typename S>
00325 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00326 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00327 operator *= (const Sacado::ELRFad::Expr<S>& x)
00328 {
00329 T xval = x.val();
00330
00331 #ifdef SACADO_DEBUG
00332 if (x.size() != Num)
00333 throw "SELRFad::operator*=() Error: Attempt to assign with incompatible sizes";
00334 #endif
00335
00336
00337 const int N = Expr<S>::num_args;
00338
00339
00340 LocalAccumOp< Expr<S> > op(x);
00341
00342
00343 for(int i=0; i<Num; ++i) {
00344 op.t = T(0.);
00345 op.i = i;
00346
00347
00348
00349
00350 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00351
00352 dx_[i] = val_ * op.t + dx_[i] * xval;
00353 }
00354
00355
00356 val_ *= xval;
00357
00358 return *this;
00359 }
00360
00361 template <typename T, int Num>
00362 template <typename S>
00363 inline Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >&
00364 Sacado::ELRFad::Expr< Sacado::ELRFad::SFadExprTag<T,Num> >::
00365 operator /= (const Sacado::ELRFad::Expr<S>& x)
00366 {
00367 T xval = x.val();
00368
00369 #ifdef SACADO_DEBUG
00370 if (x.size() != Num)
00371 throw "SELRFad::operator/=() Error: Attempt to assign with incompatible sizes";
00372 #endif
00373
00374
00375 const int N = Expr<S>::num_args;
00376
00377
00378 LocalAccumOp< Expr<S> > op(x);
00379
00380 T xval2 = xval*xval;
00381
00382
00383 for(int i=0; i<Num; ++i) {
00384 op.t = T(0.);
00385 op.i = i;
00386
00387
00388
00389
00390 Sacado::mpl::for_each< mpl::range_c< int, 0, N > > f(op);
00391
00392 dx_[i] = (dx_[i] * xval - val_ * op.t) / xval2;
00393 }
00394
00395
00396 val_ /= xval;
00397
00398 return *this;
00399 }
00400