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 char mtbl_C[] = "$Header: /cvsroot/Lorene/C++/Source/Mtbl/mtbl.C,v 1.7 2008/08/19 06:42:00 j_novak Exp $" ;
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107 #include <assert.h>
00108
00109
00110 #include "mtbl.h"
00111 #include "coord.h"
00112 #include "type_parite.h"
00113 #include "utilitaires.h"
00114
00115
00116
00117 Mtbl::Mtbl(const Mg3d& g) : mg(&g), etat(ETATNONDEF), t(0x0) {
00118
00119 nzone = g.get_nzone() ;
00120
00121 }
00122
00123 Mtbl::Mtbl(const Mg3d* g) : mg(g), etat(ETATNONDEF), t(0x0) {
00124
00125 nzone = g->get_nzone() ;
00126
00127 }
00128
00129 Mtbl::Mtbl(const Coord& c1) {
00130
00131
00132 if (c1.c == 0x0) c1.fait() ;
00133
00134
00135 mg = c1.c->get_mg() ;
00136 nzone = mg->get_nzone() ;
00137
00138
00139 t = 0x0 ;
00140 etat = ETATNONDEF ;
00141
00142
00143 *this = *(c1.c) ;
00144 }
00145
00146
00147
00148
00149 Mtbl::~Mtbl() {
00150 del_t() ;
00151 }
00152
00153
00154
00155 Mtbl::Mtbl(const Mtbl& mtc) : mg(mtc.mg), nzone(mtc.nzone) {
00156
00157
00158 assert(mtc.get_etat() != ETATNONDEF) ;
00159
00160 t = 0x0 ;
00161 etat = ETATNONDEF ;
00162 if (mtc.etat == ETATQCQ) {
00163 set_etat_qcq() ;
00164 for (int i=0 ; i<nzone ; i++) {
00165 *t[i] = *mtc.t[i] ;
00166 }
00167 }
00168 else {
00169 assert(mtc.etat == ETATZERO) ;
00170 }
00171 etat = mtc.etat ;
00172 }
00173
00174
00175 Mtbl::Mtbl(const Mg3d & g, FILE* fd) : mg(&g) {
00176
00177
00178 Mg3d* mg_tmp = new Mg3d(fd) ;
00179 if (*mg != *mg_tmp) {
00180 cout << "Mtbl::Mtbl(Mg3d & , FILE*): grid not consistent !" << endl ;
00181 abort() ;
00182 }
00183 delete mg_tmp ;
00184
00185
00186 nzone = mg->get_nzone() ;
00187 fread_be(&etat, sizeof(int), 1, fd) ;
00188
00189
00190 t = 0x0 ;
00191 if (etat == ETATQCQ) {
00192 t = new Tbl*[nzone] ;
00193 for (int i=0 ; i<nzone ; i++) {
00194 t[i] = new Tbl(fd) ;
00195 }
00196 }
00197 int dzpuis_vieux ;
00198 fread_be(&dzpuis_vieux, sizeof(int), 1, fd) ;
00199 }
00200
00201
00202 void Mtbl::sauve(FILE* fd) const {
00203
00204 mg->sauve(fd) ;
00205 fwrite_be(&etat, sizeof(int), 1, fd) ;
00206 if (etat == ETATQCQ) {
00207 for (int i=0 ; i<nzone ; i++) {
00208 t[i]->sauve(fd) ;
00209 }
00210 }
00211 int dzpuis_vieux = 0 ;
00212 fwrite_be(&dzpuis_vieux, sizeof(int), 1, fd) ;
00213 }
00214
00215
00216
00217 void Mtbl::operator=(const Mtbl& mtc)
00218 {
00219
00220 assert (mg == mtc.mg) ;
00221 assert(mtc.get_etat() != ETATNONDEF) ;
00222
00223
00224 if (mtc.get_etat() == ETATZERO) {
00225 set_etat_zero() ;
00226 }
00227 else {
00228 assert(mtc.get_etat() == ETATQCQ) ;
00229 set_etat_qcq() ;
00230 for (int i=0 ; i<nzone ; i++) {
00231 *t[i] = *mtc.t[i] ;
00232 }
00233 }
00234 }
00235
00236 void Mtbl::operator=(double x)
00237 {
00238 if (x == double(0)) {
00239 set_etat_zero() ;
00240 }
00241 else {
00242 set_etat_qcq() ;
00243 for (int i=0 ; i<nzone ; i++) {
00244 *t[i] = x ;
00245 }
00246 }
00247
00248 }
00249
00250 void Mtbl::operator=(int m)
00251 {
00252 if (m == 0) {
00253 set_etat_zero() ;
00254 }
00255 else {
00256 set_etat_qcq() ;
00257 for (int i=0 ; i<nzone ; i++) {
00258 *t[i] = m ;
00259 }
00260 }
00261
00262 }
00263
00264
00265
00266
00267
00268
00269
00270 void Mtbl::del_t() {
00271 if (t != 0x0) {
00272 for (int l=0 ; l<nzone ; l++) {
00273 delete t[l] ;
00274 }
00275 delete [] t ;
00276 t = 0x0 ;
00277 }
00278 }
00279
00280 void Mtbl::set_etat_zero() {
00281 if (etat == ETATZERO) return ;
00282 del_t() ;
00283 etat = ETATZERO ;
00284 }
00285
00286 void Mtbl::set_etat_nondef() {
00287 if (etat == ETATNONDEF) return ;
00288 del_t() ;
00289 etat = ETATNONDEF ;
00290 }
00291
00292 void Mtbl::set_etat_qcq() {
00293 if (etat == ETATQCQ) return ;
00294
00295
00296 assert( (etat == ETATZERO) || (etat == ETATNONDEF) ) ;
00297
00298 t = new Tbl*[nzone] ;
00299 for (int i=0 ; i<nzone ; i++) {
00300 t[i] = new Tbl( *(mg->get_grille3d(i)) ) ;
00301 }
00302 etat = ETATQCQ ;
00303 }
00304
00305 void Mtbl::annule_hard() {
00306 if (t == 0x0) {
00307 t = new Tbl*[nzone] ;
00308 for (int i=0 ; i<nzone ; i++) {
00309 t[i] = new Tbl( *(mg->get_grille3d(i)) ) ;
00310 }
00311 }
00312
00313 for (int i=0 ; i<nzone ; i++) {
00314 t[i]->annule_hard() ;
00315 }
00316 etat = ETATQCQ ;
00317 }
00318
00319
00320
00321
00322 void Mtbl::annule(int l_min, int l_max) {
00323
00324 assert( (l_min >= 0) && (l_min < nzone) ) ;
00325 assert( (l_max >= 0) && (l_max < nzone) ) ;
00326
00327
00328 if ( (l_min == 0) && (l_max == nzone-1) ) {
00329 set_etat_zero() ;
00330 return ;
00331 }
00332
00333 assert( etat != ETATNONDEF ) ;
00334
00335 if ( etat == ETATZERO ) {
00336 return ;
00337 }
00338 else {
00339 assert( etat == ETATQCQ ) ;
00340 for (int l=l_min; l<=l_max; l++) {
00341 t[l]->set_etat_zero() ;
00342 }
00343
00344 }
00345
00346 }
00347
00348
00349
00350
00351
00352
00353
00354
00355
00356
00357
00358 ostream& operator<<(ostream& o, const Mtbl& mt) {
00359
00360 assert(mt.get_etat() != ETATNONDEF) ;
00361
00362 int nzone = mt.get_nzone() ;
00363 o.precision(4);
00364 o.setf(ios::showpoint);
00365 o << "*** Mtbl " << nzone << " domains" << endl ;
00366
00367 if (mt.get_etat() == ETATZERO) {
00368 o << "Logically NULL" << endl ;
00369 }
00370 else {
00371 for (int l=0 ; l<nzone ; l++) {
00372 o << " Domain #" << l << endl ;
00373 o << *(mt.t[l]) ;
00374 o << endl ;
00375 }
00376 }
00377
00378 o << endl ;
00379 return o ;
00380 }
00381
00382
00383
00384
00385
00386 void Mtbl::affiche_seuil(ostream& ost, int precis, double seuil) const {
00387 ost << "*** Mtbl " << nzone << " domains" << endl ;
00388
00389
00390
00391
00392 if (etat == ETATNONDEF) {
00393 ost << " state: UNDEFINED" << endl ;
00394 return ;
00395 }
00396
00397 if (etat == ETATZERO) {
00398 ost << " state: ZERO" << endl ;
00399 return ;
00400 }
00401
00402
00403
00404
00405 for (int l=0; l < nzone; l++) {
00406 t[l]->affiche_seuil( ost , precis, seuil ) ;
00407 }
00408
00409
00410 }
00411
00412
00413
00414
00415
00416 void Mtbl::operator+=(double ) {
00417 const char* f = __FILE__ ;
00418 c_est_pas_fait(f) ;
00419 }
00420
00421 void Mtbl::operator-=(double ) {
00422 const char* f = __FILE__ ;
00423 c_est_pas_fait(f) ;
00424 }
00425
00426 void Mtbl::operator*=(double ) {
00427 const char* f = __FILE__ ;
00428 c_est_pas_fait(f) ;
00429 }
00430
00431 void Mtbl::operator/=(double ) {
00432 const char* f = __FILE__ ;
00433 c_est_pas_fait(f) ;
00434 }
00435
00436