91 static double* cx_tcp = 0 ;
92 static double* cx_rrp = 0 ;
93 static double* cx_rf_x2 = 0 ;
94 static double* cx_rf_x = 0 ;
95 static double* cx_rf = 0 ;
97 static int nt_cp_pre = 0 ;
98 static int nr_p_pre = 0 ;
99 static int nr_f_pre = 0 ;
101 assert(sci.
get_etat() != ETATNONDEF) ;
118 assert(p_mti->
get_etat() == ETATQCQ) ;
124 for (
int l=0 ; l<nz ; l++) {
126 const Tbl* p_tbi = p_mti->
t[l] ;
128 if ( p_tbi->
get_etat() == ETATZERO ) {
133 assert( p_tbi->
get_etat() == ETATQCQ ) ;
138 int base = (p_mti->
base).get_b(l) ;
139 int base_r = base &
MSQ_R ;
140 int base_t = base &
MSQ_T ;
141 int base_p = base &
MSQ_P ;
147 double* s_tr =
new double[nr] ;
148 double* x_spec = p_tbi->
t ;
162 if (nt > nt_cp_pre) {
165 =
static_cast<double*
>(realloc(cx_tcp, nt*
sizeof(
double))) ;
166 for (
int j=0 ; j<nt ; j++) {
167 cx_tcp[j] = 2./(1. - 4.*j*j) ;
172 for (
int i=0 ; i<nr ; i++) s_tr[i] = 0 ;
173 for (
int j=0 ; j<nt ; j++) {
174 for (
int i=0 ; i<nr ; i++) {
175 s_tr[i] += cx_tcp[j] * x_spec[i] ;
184 for (
int i=0 ; i<nr ; i++) s_tr[i] = 0 ;
185 for (
int j=0 ; j<nt ; j++) {
187 for (
int i=0 ; i<nr ; i++) {
188 s_tr[i] += (2. / (1.-j*j)) * x_spec[i] ;
195 cout <<
"Map_af::integrale: unknown theta basis ! " << endl ;
213 assert(
beta[l] == 0) ;
216 cx_rrp =
static_cast<double*
>(realloc(cx_rrp, nr*
sizeof(
double))) ;
217 for (
int i=0 ; i<nr ; i++) {
218 cx_rrp[i] = (3. - 4.*i*i) /
219 (9. - 40. * i*i + 16. * i*i*i*i) ;
223 for (
int i=0 ; i<nr ; i++) {
224 som += cx_rrp[i] * s_tr[i] ;
226 double rmax =
alpha[l] ;
227 som *= rmax*rmax*rmax ;
234 cx_rf_x2 =
static_cast<double*
>(realloc(cx_rf_x2, nr*
sizeof(
double))) ;
235 cx_rf_x =
static_cast<double*
>(realloc(cx_rf_x, nr*
sizeof(
double))) ;
236 cx_rf =
static_cast<double*
>(realloc(cx_rf, nr*
sizeof(
double))) ;
237 for (
int i=0 ; i<nr ; i +=2 ) {
238 cx_rf_x2[i] = 2.*(3. - i*i)/(9. - 10. * i*i + i*i*i*i) ;
240 cx_rf[i] = 2./(1. - i*i) ;
242 for (
int i=1 ; i<nr ; i +=2 ) {
244 cx_rf_x[i] = 2./(4. - i*i) ;
249 for (
int i=0 ; i<nr ; i +=2 ) {
250 som_x2 += cx_rf_x2[i] * s_tr[i] ;
252 for (
int i=1 ; i<nr ; i +=2 ) {
253 som_x += cx_rf_x[i] * s_tr[i] ;
255 for (
int i=0 ; i<nr ; i +=2 ) {
256 som_c += cx_rf[i] * s_tr[i] ;
258 double a =
alpha[l] ;
260 som = a*a*a * som_x2 + 2.*a*a*b * som_x + a*b*b * som_c ;
267 cx_rf_x2 =
static_cast<double*
>(realloc(cx_rf_x2, nr*
sizeof(
double))) ;
268 cx_rf_x =
static_cast<double*
>(realloc(cx_rf_x, nr*
sizeof(
double))) ;
269 cx_rf =
static_cast<double*
>(realloc(cx_rf, nr*
sizeof(
double))) ;
271 for (
int i=0 ; i<nr ; i +=1 ) {
273 cx_rf_x[i] = 2*signe/double(i+1)/double(i+2);
277 cx_rf_x2[0] = double(8)/double(3) ;
280 for (
int i=0 ; i<nr ; i +=1 ) {
281 som_x2 += cx_rf_x2[i] * s_tr[i] ;
283 for (
int i=1 ; i<nr ; i +=1 ) {
284 som_x += cx_rf_x[i] * s_tr[i] ;
286 for (
int i=0 ; i<nr ; i +=1 ) {
287 som_c += cx_rf[i] * s_tr[i] ;
289 double a =
alpha[l] ;
292 som = a*a*a * som_x2 + 2.*a*a*(b-a) * som_x + a*(b-a)*(b-a) * som_c ;
300 cx_rf =
static_cast<double*
>(realloc(cx_rf, nr*
sizeof(
double))) ;
301 for (
int i=0 ; i<nr ; i +=2 ) {
302 cx_rf[i] = 2./(1. - i*i) ;
304 for (
int i=1 ; i<nr ; i +=2 ) {
309 for (
int i=0 ; i<nr ; i +=2 ) {
310 som_c += cx_rf[i] * s_tr[i] ;
312 som = -
alpha[l] * som_c ;
318 cout <<
"Map_af::integrale: unknown r basis ! " << endl ;
342 cout <<
"Map_af::integrale: unknown phi basis ! " << endl ;
Mtbl_cf * c_cf
Coefficients of the spectral expansion of the function.
Component of a tensorial field *** DEPRECATED : use class Scalar instead ***.
#define P_COSSIN
dev. standart
void coef() const
Computes the coeffcients of *this.
double * alpha
Array (size: mg->nzone ) of the values of in each domain.
Tensor field of valence 0 (or component of a tensorial field).
#define MSQ_P
Extraction de l'info sur Phi.
#define T_COS
dev. cos seulement
#define T_COSSIN_SP
sin pair-cos impair alternes, sin pour m=0
int get_etat() const
Gives the logical state.
int get_etat() const
Returns the logical state ETATNONDEF (undefined), ETATZERO (null) or ETATQCQ (ordinary).
int get_etat() const
Returns the logical state.
#define R_JACO02
base de Jacobi(0,2) ordinaire (finjac)
virtual Tbl * integrale(const Scalar &) const
Computes the integral over all space of a Scalar.
#define T_SIN
dev. sin seulement
void set_etat_qcq()
Sets the logical state to ETATQCQ (ordinary state).
#define R_CHEBP
base de Cheb. paire (rare) seulement
#define T_COS_P
dev. cos seulement, harmoniques paires
#define MSQ_T
Extraction de l'info sur Theta.
#define T_COSSIN_C
dev. cos-sin alternes, cos pour m=0
double * t
The array of double.
#define MSQ_R
Extraction de l'info sur R.
#define T_SIN_P
dev. sin seulement, harmoniques paires
double * beta
Array (size: mg->nzone ) of the values of in each domain.
int get_nzone() const
Returns the number of domains.
#define R_CHEBPIM_P
Cheb. pair-impair suivant m, pair pour m=0.
int get_nr(int l) const
Returns the number of points in the radial direction ( ) in domain no. l.
const Mg3d * mg
Pointer on the multi-grid Mgd3 on which this is defined.
#define R_CHEBPI_P
Cheb. pair-impair suivant l pair pour l=0.
#define T_COSSIN_CI
cos impair-sin pair alternes, cos pour m=0
Coefficients storage for the multi-domain spectral method.
Base_val base
Bases of the spectral expansions.
int get_nt(int l) const
Returns the number of points in the co-latitude direction ( ) in domain no. l.
#define R_CHEBU
base de Chebychev ordinaire (fin), dev. en 1/r
#define P_COSSIN_P
dev. sur Phi = 2*phi, freq. paires
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...
#define T_COSSIN_CP
cos pair-sin impair alternes, cos pour m=0
void annule_hard()
Sets the Tbl to zero in a hard way.
Tbl ** t
Array (size nzone ) of pointers on the Tbl 's which contain the spectral coefficients in each domain...
const Valeur & get_spectral_va() const
Returns va (read only version)
#define T_COSSIN_S
dev. cos-sin alternes, sin pour m=0
#define R_CHEB
base de Chebychev ordinaire (fin)