|
| Mg3d (int nz, int nbr[], int typr[], int nbt[], int typt, int nbp[], int typp, int *base_r=0x0) |
| General constructor. More...
|
|
| Mg3d (int nz, int nbr, int nbt, int nbp, int typt, int typp, bool compact, bool legendre=false) |
| Simplified constructor for a standard multi-grid. More...
|
|
| Mg3d (int nz, int nbr, int nbt, int nbp, int typt, int typp) |
| Simplified constructor for a standard multi-grid only with shells and Chebyshev. More...
|
|
| Mg3d (const string &filename) |
| Constructor from a formatted file, given by its name (string). More...
|
|
| Mg3d (FILE *fd, bool read_base=false) |
| Constructor from a file (see sauve(FILE*) ). More...
|
|
| Mg3d (const Mg3d &) |
| Copy constructor (private and not implemented to make Mg3d a non-copyable class) More...
|
|
| ~Mg3d () |
| Destructor. More...
|
|
int | get_nzone () const |
| Returns the number of domains. More...
|
|
int | get_nr (int l) const |
| Returns the number of points in the radial direction ( ) in domain no. l. More...
|
|
int | get_nt (int l) const |
| Returns the number of points in the co-latitude direction ( ) in domain no. l. More...
|
|
int | get_np (int l) const |
| Returns the number of points in the azimuthal direction ( ) in domain no. l. More...
|
|
int | get_type_r (int l) const |
| Returns the type of sampling in the radial direction in domain no. More...
|
|
int | get_type_t () const |
| Returns the type of sampling in the direction:
SYM : : symmetry with respect to the equatorial plane
NONSYM : : no symmetry with respect to the equatorial plane. More...
|
|
int | get_type_p () const |
| Returns the type of sampling in the direction:
SYM : : symmetry with respect to the transformation
NONSYM : : no symmetry with respect to the transformation
More...
|
|
const Grille3d * | get_grille3d (int l) const |
| Returns a pointer on the 3D mono-grid for domain no. l. More...
|
|
int | get_colloc_r (int l) const |
| Returns the type of collocation points used in domain no. More...
|
|
const Mg3d * | get_angu () const |
| Returns the pointer on the associated angular grid. More...
|
|
const Mg3d * | get_angu_1dom () const |
| Returns the pointer on the associated mono-domain angular grid. More...
|
|
const Mg3d * | get_radial () const |
| Returns the pointer on the associated radial grid. More...
|
|
const Mg3d * | get_three_halves () const |
| Returns the pointer on the associated grid with 50% points in every direction for dealiasing. More...
|
|
const Mg3d * | get_twice () const |
| Returns the pointer on the grid which has twice the number of points in each dimension (for desaliasing). More...
|
|
const Mg3d * | plus_half () const |
| Returns the pointer on the grid which has 50% more points in r dimension (for desaliasing). More...
|
|
const Mg3d * | plus_half_angu () const |
| Returns the pointer on the grid which has 50% more points in and dimension (for desaliasing). More...
|
|
const Mg3d * | get_non_axi () const |
| Returns the pointer on the grid which has at least 4 points in the direction and at least 5 in the direction (for tensor rotations). More...
|
|
bool | operator== (const Mg3d &) const |
| Comparison operator (egality) More...
|
|
void | sauve (FILE *fd, bool save_base=false) const |
| Saves into a file. More...
|
|
bool | operator!= (const Mg3d &) const |
| Operator !=. More...
|
|
Base_val | std_base_scal () const |
| Returns the standard spectral bases for a scalar. More...
|
|
Base_val | std_base_scal_odd () const |
| Returns the standard odd spectral bases for a scalar. More...
|
|
Base_val ** | std_base_vect_cart () const |
| Returns the standard spectral bases for the Cartesian components of a vector. More...
|
|
Base_val ** | std_base_vect_spher () const |
| Returns the standard spectral bases for the spherical components of a vector. More...
|
|
Base_val ** | pseudo_base_vect_cart () const |
| Returns the standard spectral bases for the Cartesian components of a pseudo-vector. More...
|
|
Base_val ** | pseudo_base_vect_spher () const |
| Returns the standard spectral bases for the spherical components of a pseudo-vector. More...
|
|
|
int | nzone |
| Number of domains (zones) More...
|
|
int * | nr |
| Array (size: nzone ) of nb. of points in r ( ) More...
|
|
int * | nt |
| Array (size: nzone ) of nb. of points in . More...
|
|
int * | np |
| Array (size: nzone ) of nb. of points in . More...
|
|
int * | type_r |
| Array (size: nzone ) of type of sampling in r ( ) (RARE ,FIN , UNSURR ) More...
|
|
int | type_t |
| Type of sampling in (SYM , NONSYM ) More...
|
|
int | type_p |
| Type of sampling in (SYM , NONSYM ) More...
|
|
int * | colloc_r |
| Array (size: nzone ) of type of collocation points in r ( ) and related decompoisition bases (BASE_CHEB , BASE_LEG , BASE_JAC02 ). More...
|
|
Grille3d ** | g |
| Array (size: nzone ) of pointers on the Grille3d's . More...
|
|
Mg3d * | g_angu |
| Pointer on the associated angular grid. More...
|
|
Mg3d * | g_angu_1dom |
| Pointer on the associated angular grid with only one domain. More...
|
|
Mg3d * | g_radial |
| Pointer on the associated radial grid. More...
|
|
Mg3d * | g_three_halves |
| Pointer on the grid having 50% more points in every direction, for dealiasing. More...
|
|
Mg3d * | g_twice |
| Pointer on the grid which has twice the number of points in each dimension (for desaliasing). More...
|
|
Mg3d * | g_plus_half |
| Pointer on the grid which has 50% more points in r dimension (for desaliasing). More...
|
|
Mg3d * | g_plus_half_angu |
| Pointer on the grid which has 50% more points in and dimension (for desaliasing). More...
|
|
Mg3d * | g_non_axi |
| Pointer on the grid which has at least 4 points in the direction and at least 5 in the direction (for tensor rotations). More...
|
|
Multi-domain grid.
()
A multi-domain grid is a set of 3D grids for the implementation of the multi-domain spectral method described in Bonazzola, Gourgoulhon & Marck, Phys. Rev. D 58, 104020 (1998). Each domain is represented by a 3D mono grid (Grille3d
) and is called a zone. For each direction, the Number of Degrees of Freedom (NDF) is a priori independent of the zone. However, some methods or routines may refuse to work if the NDF of some
direction is not identical in all the zones. This holds for the type of sampling (symmetry) too.
- Version
- #$Id: grilles.h,v 1.26 2025/03/26 10:12:20 j_novak Exp $#
Definition at line 276 of file grilles.h.
Lorene::Mg3d::Mg3d |
( |
int |
nz, |
|
|
int |
nbr, |
|
|
int |
nbt, |
|
|
int |
nbp, |
|
|
int |
typt, |
|
|
int |
typp, |
|
|
bool |
compact, |
|
|
bool |
legendre = false |
|
) |
| |
Lorene::Mg3d::Mg3d |
( |
FILE * |
fd, |
|
|
bool |
read_base = false |
|
) |
| |
Constructor from a file (see sauve(FILE*)
).
If the boolean flag read_base
is false
(default) the spectral basis is not saved, for compatibility with older versions. If it is set to true
, the basis is saved.
Definition at line 445 of file mg3d.C.
References colloc_r, Lorene::fread_be(), g, np, nr, nt, nzone, type_p, type_r, and type_t.
void Lorene::Mg3d::sauve |
( |
FILE * |
fd, |
|
|
bool |
save_base = false |
|
) |
| const |
Saves into a file.
By default, if save_base
is false, the spectral decomposition basis colloc_r
is not saved (for compatibility reasons). If save_base
is true
, then colloc_r
is save, too. The same value for the flag read_base
must be given in the contructor reading the file.
Definition at line 503 of file mg3d.C.
References colloc_r, Lorene::fwrite_be(), np, nr, nt, nzone, type_p, type_r, and type_t.