1 #ifndef MEDMEM_WRAPPER_FIELD_HXX
2 #define MEDMEM_WRAPPER_FIELD_HXX
4 #include "MEDMEM_Field.hxx"
8 //////////////////////////////////////////////////////////////////
10 /// DECLARATIONS ET CODE ///
12 //////////////////////////////////////////////////////////////////
14 /*********************************************************/
16 /* Template Arithmétiques de Valdhuizen */
18 /*********************************************************/
20 // permet de faire des opérations algébriques sur des Wrappers_MED_Field sans faire d'allocations inutiles
21 // voir les articles de Valdhuizen pour la compréhension du processus
23 template <class TYPE> class Valeur;
28 static double apply(double a,double b) {return a+b;}
34 static double apply(double a,double b) {return a*b;}
38 template <typename Left,typename Op, typename Right> struct X
42 X(Left l,Right r):left(l),right(r){}
43 double operator[](int i)
45 return Op::apply(left[i],right[i]);
49 template <typename Right> struct X<double,Multiply,Right>
53 X(double l,Right r):left(l),right(r){}
54 double operator[](int i)
56 return Multiply::apply(left,right[i]);
60 template <typename TYPE> X< Valeur<TYPE>,Plus,Valeur<TYPE> > operator+(Valeur<TYPE> v1,Valeur<TYPE> v2)
62 return X< Valeur<TYPE>,Plus,Valeur<TYPE> >(v1,v2);
65 template <typename TYPE> X< double,Multiply,Valeur<double> > operator*(TYPE sca,Valeur<TYPE> v)
67 return X< TYPE,Multiply,Valeur<TYPE> >(sca,v);
70 template <typename TYPE,typename L, typename O, typename R> X< Valeur<TYPE>,Plus,X<L,O,R> > operator+(Valeur<TYPE> v,X<L,O,R> expression)
72 return X< Valeur<TYPE>,Plus,X<L,O,R> >(v,expression);
75 template <typename TYPE,typename L, typename O, typename R> X< X<L,O,R>,Plus,Valeur<TYPE> > operator+(X<L,O,R> expression,Valeur<TYPE> v)
77 return X< X<L,O,R>,Plus,Valeur<TYPE> >(expression,v);
80 template <typename Ll, typename Ol, typename Rl,typename Lr, typename Or, typename Rr> X< X<Ll,Ol,Rl>,Plus, X<Lr,Or,Rr> > operator+(X<Ll,Ol,Rl> el, X<Lr,Or,Rr> er )
82 return X< X<Ll,Ol,Rl>,Plus,X<Lr,Or,Rr> >(el,er);
85 template <typename L, typename O, typename R> X< double,Multiply,X<L,O,R> > operator*(double sca,X<L,O,R> expression)
87 return X< double,Multiply,X<L,O,R> >(sca,expression);
90 template <typename Left,typename Op,typename Right> X< double,Multiply,X<Left,Op,Right> > operator/(X<Left,Op,Right> l,double x)
92 return X< double,Multiply,X<Left,Op,Right> >(((double) 1/x),l);
95 /*********************************************************/
99 /*********************************************************/
101 // Problèmes : les constructeurs par copie ne sont pas satisfaisants
102 // Valeur est symboliquement l'argument d'une classe formelle Vecteur<Valeur>
103 // elle peut etre un réel ou un pointeur sur réel, simulant un vecteur de vecteur
105 template <class TYPE> class Valeur
112 Valeur():valeurs(NULL),a_detruire(0){}
113 Valeur(TYPE * val,int nv):valeurs(val),nbr_valeurs(nv),a_detruire(0){} // A VERIFIER
114 Valeur(int n):nbr_valeurs(n),a_detruire(1)
116 valeurs=new TYPE[nbr_valeurs];
118 template <typename Left,typename Op,typename Right> Valeur(X<Left,Op,Right> expression)
120 for (int i=0;i<nbr_valeurs;i++) valeurs[i]=expression[i];
122 template <typename Left,typename Op,typename Right> void operator=(X<Left,Op,Right> expression)
124 for (int i=0;i<nbr_valeurs;i++) valeurs[i]=expression[i];
126 void operator=(Valeur v)
128 for (int i=0;i<nbr_valeurs;i++) valeurs[i]=v[i];
130 Valeur(const Valeur &v):nbr_valeurs(v.nbr_valeurs)
135 valeurs=new TYPE[nbr_valeurs];
136 for (int i=0;i<nbr_valeurs;i++) valeurs[i]=v.valeurs[i];
144 ~Valeur(){if (a_detruire) delete [] valeurs;}
145 TYPE operator[](int i){return valeurs[i];}
146 int SIZE() const {return nbr_valeurs;}
151 for (i=0;i<nbr_valeurs;i++) tmp+=fabs(valeurs[i]);
157 template <class TYPE> ostream &operator<<(ostream &os,Valeur<TYPE> v)
160 for (int i=0;i<v.SIZE();i++) os<<" "<<v[i]<<flush;
165 /*********************************************************/
167 /* Classe Wrapper_MED_Field */
169 /*********************************************************/
171 // c'est la classe de Wrapping sur un objet FIELD<double> MEDMEMOIRE
173 class Wrapper_MED_Field
180 Wrapper_MED_Field():valeurs(NULL){}
181 Wrapper_MED_Field(int nv, int nc, double * v):nbr_valeurs(nv),nbr_composantes(nc),valeurs(v)
184 Wrapper_MED_Field(const FIELD<double> * medfield)
186 nbr_valeurs=medfield->getNumberOfValues();
187 nbr_composantes=medfield->getNumberOfComponents();
188 valeurs=const_cast<double *>(medfield->getValue(MED_FULL_INTERLACE));
190 ~Wrapper_MED_Field(){}
191 inline Valeur<double> operator[](int i)
193 return Valeur<double>(&valeurs[nbr_composantes*i],nbr_composantes);
195 double * Get_Valeurs() {return valeurs;}
196 inline int Get_Nbr_Valeurs() const {return nbr_valeurs;}
197 inline int Get_Nbr_Composantes() const {return nbr_composantes;}
198 friend ostream & operator<<(ostream &os, Wrapper_MED_Field);
201 ostream & operator<<(ostream &os, Wrapper_MED_Field wmf)
203 for (int i=0;i<wmf.nbr_valeurs;i++) os<<"Wrapper_MED_Field["<<i<<"] = "<<wmf[i]<<endl;