113 assert(source.
get_etat() != ETATNONDEF) ;
114 assert(&source.
get_mp() ==
this) ;
119 assert(&uu.
get_mp() ==
this) ;
139 for (
int l=0; l<nz; l++) {
143 apre1 = apre1 *
dxdr *
dxdr * unjj ;
153 for (
int l=0; l<nz; l++) {
154 *(amax1.
t[l]) = amax0(l) ;
168 double unmlambda = 1. - lambda ;
192 cout <<
"Map_et::poisson : relat. diff. u^J <-> u^{J-1} : " << endl ;
229 sxlapang = sxlapang.
lapang() ;
231 sxlapang = sxlapang.
sx() ;
255 vuu = 2. *
dxdr * (
rsxdxdr * unjj - 1.) * varduudx
269 sauve_base = vuu.
base ;
300 ssj = lambda * ssjm1 + unmlambda * ssjm2 ;
302 ssj = ( source + uu + (amax - apre) * ssj ) / amax ;
320 mpaff.
poisson(ssj, par_nul, uu) ;
327 cout <<
" step " << niter <<
" : " ;
328 for (
int l=0; l<nz; l++) {
329 cout << tdiff(l) <<
" " ;
344 while ( (diff > precis) && (niter < nitermax) ) ;
362 assert(source.
get_etat() != ETATNONDEF) ;
363 assert(&source.
get_mp() ==
this) ;
368 assert(&uu.
get_mp() ==
this) ;
388 for (
int l=0; l<nz; l++) {
392 apre1 = apre1 *
dxdr *
dxdr * unjj ;
402 for (
int l=0; l<nz; l++) {
403 *(amax1.
t[l]) = amax0(l) ;
417 double unmlambda = 1. - lambda ;
441 cout <<
"Map_et::poisson_tau : relat. diff. u^J <-> u^{J-1} : " << endl ;
478 sxlapang = sxlapang.
lapang() ;
480 sxlapang = sxlapang.
sx() ;
504 vuu = 2. *
dxdr * (
rsxdxdr * unjj - 1.) * varduudx
518 sauve_base = vuu.
base ;
549 ssj = lambda * ssjm1 + unmlambda * ssjm2 ;
551 ssj = ( source + uu + (amax - apre) * ssj ) / amax ;
576 cout <<
" step " << niter <<
" : " ;
577 for (
int l=0; l<nz; l++) {
578 cout << tdiff(l) <<
" " ;
593 while ( (diff > precis) && (niter < nitermax) ) ;
612 assert(source.
get_etat() != ETATNONDEF) ;
613 assert(source.
get_mp() ==
this) ;
618 assert(uu.
get_mp() ==
this) ;
638 for (
int l=0; l<nz; l++) {
642 apre1 = apre1 *
dxdr *
dxdr * unjj ;
652 for (
int l=0; l<nz; l++) {
653 *(amax1.
t[l]) = amax0(l) ;
667 double unmlambda = 1. - lambda ;
691 cout <<
"Map_et::poisson : relat. diff. u^J <-> u^{J-1} : " << endl ;
728 sxlapang = sxlapang.
lapang() ;
730 sxlapang = sxlapang.
sx() ;
754 vuu = 2. *
dxdr * (
rsxdxdr * unjj - 1.) * varduudx
768 sauve_base = vuu.
base ;
799 ssj = lambda * ssjm1 + unmlambda * ssjm2 ;
801 ssj = ( source + uu + (amax - apre) * ssj ) / amax ;
803 (ssj.
va).set_base((source.
va).base) ;
819 mpaff.
poisson(ssj, par_nul, uu) ;
826 cout <<
" step " << niter <<
" : " ;
827 for (
int l=0; l<nz; l++) {
828 cout << tdiff(l) <<
" " ;
843 while ( (diff > precis) && (niter < nitermax) ) ;
861 assert(source.
get_etat() != ETATNONDEF) ;
862 assert(source.
get_mp() ==
this) ;
867 assert(uu.
get_mp() ==
this) ;
887 for (
int l=0; l<nz; l++) {
891 apre1 = apre1 *
dxdr *
dxdr * unjj ;
901 for (
int l=0; l<nz; l++) {
902 *(amax1.
t[l]) = amax0(l) ;
916 double unmlambda = 1. - lambda ;
940 cout <<
"Map_et::poisson_tau : relat. diff. u^J <-> u^{J-1} : " << endl ;
977 sxlapang = sxlapang.
lapang() ;
979 sxlapang = sxlapang.
sx() ;
1003 vuu = 2. *
dxdr * (
rsxdxdr * unjj - 1.) * varduudx
1017 sauve_base = vuu.
base ;
1048 ssj = lambda * ssjm1 + unmlambda * ssjm2 ;
1050 ssj = ( source + uu + (amax - apre) * ssj ) / amax ;
1052 (ssj.
va).set_base((source.
va).base) ;
1070 tdiff =
diffrel(vuu, vuujm1) ;
1075 cout <<
" step " << niter <<
" : " ;
1076 for (
int l=0; l<nz; l++) {
1077 cout << tdiff(l) <<
" " ;
1092 while ( (diff > precis) && (niter < nitermax) ) ;
1102 double lambda)
const {
1104 if (lambda !=
double(0)) {
1106 "Map_et::poisson_angu : the case lambda != 0 is not treated yet !" 1111 assert(source.
get_mp() == *
this) ;
1112 assert(uu.
get_mp() == *
this) ;
1117 int* nrm6 =
new int[nz];
1118 for (
int l=0; l<=nzm1; l++)
1131 int nitermax = par.
get_int() ;
1162 cout <<
"Map_et::poisson angu : relat. diff. u^J <-> u^{J-1} : " << endl ;
1204 vuu = - d2uudxdx *
dxdr *
dxdr * unjj
1231 ssj = (1-relax) * ssj + relax * ssjm1 ;
1242 tdiff =
diffrel(vuu, vuujm1) ;
1247 cout <<
" step " << niter <<
" : " ;
1248 for (
int l=0; l<nz; l++) {
1249 cout << tdiff(l) <<
" " ;
1263 while ( (diff > precis) && (niter < nitermax) ) ;
1276 cout <<
"Map_et::poisson_angu(const Cmp&, Param&, Cmp&, double) pas fait" << endl; abort() ;
const Map * get_mp() const
Returns the mapping.
const Base_val & get_spectral_base() const
Returns the spectral bases of the Valeur va.
Coord d2rdx2
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
const Valeur & dsdt() const
Returns of *this.
Coord sr2stdrdp
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
const Valeur & dsdx() const
Returns of *this.
Component of a tensorial field *** DEPRECATED : use class Scalar instead ***.
void filtre_r(int *nn)
Sets the n lasts coefficients in r to 0 in all domains.
void mult_r()
Multiplication by r everywhere; dzpuis is not changed.
const Valeur & lapang() const
Returns the angular Laplacian of *this.
void dec_dzpuis()
Decreases by 1 the value of dzpuis and changes accordingly the values of the Cmp in the external comp...
double * alpha
Array (size: mg->nzone ) of the values of in each domain.
void ylm()
Computes the coefficients of *this.
int get_etat() const
Returns the logical state.
Coord sr2drdt
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
Tensor field of valence 0 (or component of a tensorial field).
const Valeur & sx() const
Returns (r -sampling = RARE ) \ Id (r sampling = FIN ) \ (r -sampling = UNSURR ) ...
Values and coefficients of a (real-value) function.
int get_etat() const
Returns the logical state ETATNONDEF (undefined), ETATZERO (null) or ETATQCQ (ordinary).
void annule(int l)
Sets the Valeur to zero in a given domain.
virtual void set_etat_qcq()
Sets the logical state to ETATQCQ (ordinary state).
void set_base(const Base_val &)
Sets the bases for spectral expansions (member base )
Tbl diffrel(const Cmp &a, const Cmp &b)
Relative difference between two Cmp (norme version).
Coord srstdrdp
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
void set_dzpuis(int)
Modifies the dzpuis flag.
Cmp & get_cmp_mod(int position=0) const
Returns the reference of a modifiable Cmp stored in the list.
virtual void poisson(const Cmp &source, Param &par, Cmp &uu) const
Computes the solution of a scalar Poisson equation (Cmp version).
const int & get_int(int position=0) const
Returns the reference of a int stored in the list.
virtual void poisson(const Cmp &source, Param &par, Cmp &uu) const
Computes the solution of a scalar Poisson equation (Cmp version).
Coord dxdr
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
Base_val base
Bases on which the spectral expansion is performed.
int get_dzpuis() const
Returns dzpuis.
const Valeur & stdsdp() const
Returns of *this.
int get_nzone() const
Returns the number of domains.
int & get_int_mod(int position=0) const
Returns the reference of a modifiable int stored in the list.
Tbl max(const Cmp &)
Maximum values of a Cmp in each domain.
Coord sstd2rdpdx
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
void dec2_dzpuis()
Decreases by 2 the value of dzpuis and changes accordingly the values of the Cmp in the external comp...
Coord xsr
in the nucleus; \ 1/R in the non-compactified shells; \ in the compactified outer domain...
void set_etat_qcq()
Sets the logical state to ETATQCQ (ordinary state).
void set_etat_qcq()
Sets the logical state to ETATQCQ (ordinary state).
Coord rsxdxdr
in the nucleus; \ in the shells; \ in the outermost compactified domain.
void set_spectral_base(const Base_val &)
Sets the spectral bases of the Valeur va
virtual void poisson_tau(const Cmp &source, Param &par, Cmp &uu) const
Computes the solution of a scalar Poisson equation using a Tau method (Cmp version).
int get_nr(int l) const
Returns the number of points in the radial direction ( ) in domain no. l.
virtual void poisson_angu(const Scalar &source, Param &par, Scalar &uu, double lambda=0) const
Computes the solution of the generalized angular Poisson equation.
const Mg3d * mg
Pointer on the multi-grid Mgd3 on which this is defined.
Bases of the spectral expansions.
virtual void poisson_angu(const Scalar &source, Param &par, Scalar &uu, double lambda=0) const
Computes the solution of the generalized angular Poisson equation.
int get_dzpuis() const
Returns dzpuis.
Coord lapr_tp
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
Scalar & get_scalar_mod(int position=0) const
Returns the reference of a modifiable Scalar stored in the list.
bool check_dzpuis(int dzi) const
Returns false if the last domain is compactified and *this is not zero in this domain and dzpuis is n...
void set_dzpuis(int)
Set a value to dzpuis.
const double & get_double(int position=0) const
Returns the reference of a double stored in the list.
Valeur & set_spectral_va()
Returns va (read/write version)
int get_type_r(int l) const
Returns the type of sampling in the radial direction in domain no.
bool check_dzpuis(int dzi) const
Returns false if the last domain is compactified and *this is not zero in this domain and dzpuis is n...
Tbl ** t
Array (size nzone ) of pointers on the Tbl 's.
Coord srdrdt
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
const Map & get_mp() const
Returns the mapping.
virtual void dec_dzpuis(int dec=1)
Decreases by dec units the value of dzpuis and changes accordingly the values of the Scalar in the co...
Valeur va
The numerical value of the Cmp.
const Valeur & get_spectral_va() const
Returns va (read only version)
Coord d2rdtdx
in the nucleus and in the non-compactified shells; \ in the compactified outer domain.
virtual void poisson_tau(const Cmp &source, Param &par, Cmp &uu) const
Computes the solution of a scalar Poisson equation with a Tau method (Cmp version).