LORENE
grilles.h
1 /*
2  * Definition of Lorene classes Grille3d and Mg3d
3  *
4  */
5 
6 /*
7  * Copyright (c) 1999-2000 Jean-Alain Marck
8  * Copyright (c) 1999-2001 Eric Gourgoulhon
9  *
10  * This file is part of LORENE.
11  *
12  * LORENE is free software; you can redistribute it and/or modify
13  * it under the terms of the GNU General Public License as published by
14  * the Free Software Foundation; either version 2 of the License, or
15  * (at your option) any later version.
16  *
17  * LORENE is distributed in the hope that it will be useful,
18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20  * GNU General Public License for more details.
21  *
22  * You should have received a copy of the GNU General Public License
23  * along with LORENE; if not, write to the Free Software
24  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25  *
26  */
27 
28 
29 #ifndef __GRILLES_H_
30 #define __GRILLES_H_
31 
32 /*
33  * $Id: grilles.h,v 1.26 2025/03/26 10:12:20 j_novak Exp $
34  * $Log: grilles.h,v $
35  * Revision 1.26 2025/03/26 10:12:20 j_novak
36  * New derived grid containing 50% more points in every direction, additional tool for de-aliasing.
37  *
38  * Revision 1.25 2023/05/24 09:48:50 g_servignat
39  * Added plus_half grid in angular direction for dealiasing
40  *
41  * Revision 1.24 2018/12/05 15:03:20 j_novak
42  * New Mg3d constructor from a formatted file.
43  *
44  * Revision 1.23 2014/10/13 08:52:35 j_novak
45  * Lorene classes and functions now belong to the namespace Lorene.
46  *
47  * Revision 1.22 2014/10/06 15:09:39 j_novak
48  * Modified #include directives to use c++ syntax.
49  *
50  * Revision 1.21 2013/06/05 15:00:26 j_novak
51  * Suppression of all classes derived from Grille3d. Now Grille3d is no
52  * longer an abstract class. r-samplings are only one of RARE, FIN or
53  * UNSURR (FINJAC has been removed). Instead, Mg3d possesses a new member
54  * colloc_r[nzone] defining the type of collocation points (spectral
55  * bases) in each domain.
56  *
57  * Revision 1.20 2013/01/11 15:44:53 j_novak
58  * Addition of Legendre bases (part 2).
59  *
60  * Revision 1.19 2012/01/17 10:10:15 j_penner
61  * added a constructor in which the nucleus and outer domain are both of type FIN
62  *
63  * Revision 1.18 2008/10/29 08:17:51 jl_cornou
64  * Standard spectral bases for pseudo vectors added
65  *
66  * Revision 1.17 2008/02/18 13:53:37 j_novak
67  * Removal of special indentation instructions.
68  *
69  * Revision 1.16 2007/12/11 15:28:05 jl_cornou
70  * Jacobi(0,2) polynomials partially implemented
71  *
72  * Revision 1.15 2006/05/17 13:17:02 j_novak
73  * New member g_angu_1dom, the one-domain angular grid associated with the
74  * current grid.
75  *
76  * Revision 1.14 2005/10/25 08:56:34 p_grandclement
77  * addition of std_spectral_base in the case of odd functions near the origin
78  *
79  * Revision 1.13 2005/10/07 08:47:20 j_novak
80  * Addition of the pointer g_non_axi on a grid, with at least 5 points in the
81  * theta direction and 4 in the phi one (for tensor rotations).
82  *
83  * Revision 1.12 2005/03/25 14:54:04 e_gourgoulhon
84  * Corrected documentation.
85  *
86  * Revision 1.11 2004/07/06 13:36:27 j_novak
87  * Added methods for desaliased product (operator |) only in r direction.
88  *
89  * Revision 1.10 2004/06/22 08:49:56 p_grandclement
90  * Addition of everything needed for using the logarithmic mapping
91  *
92  * Revision 1.9 2004/03/22 13:12:41 j_novak
93  * Modification of comments to use doxygen instead of doc++
94  *
95  * Revision 1.8 2003/06/20 14:16:57 f_limousin
96  * Add the operator== to compare two Mg3d
97  *
98  * Revision 1.7 2003/06/18 08:45:26 j_novak
99  * In class Mg3d: added the member get_radial, returning only a radial grid
100  * For dAlembert solver: the way the coefficients of the operator are defined has been changed.
101  *
102  * Revision 1.6 2002/10/16 14:36:29 j_novak
103  * Reorganization of #include instructions of standard C++, in order to
104  * use experimental version 3 of gcc.
105  *
106  * Revision 1.5 2002/08/13 08:02:45 j_novak
107  * Handling of spherical vector/tensor components added in the classes
108  * Mg3d and Tenseur. Minor corrections for the class Metconf.
109  *
110  * Revision 1.4 2002/06/17 14:05:16 j_novak
111  * friend functions are now also declared outside the class definition
112  *
113  * Revision 1.3 2001/12/12 09:23:46 e_gourgoulhon
114  * Parameter compact added to the simplified constructor of class Mg3d
115  *
116  * Revision 1.2 2001/12/11 06:47:42 e_gourgoulhon
117  * Simplified constructor for class Mg3d
118  *
119  * Revision 1.1.1.1 2001/11/20 15:19:27 e_gourgoulhon
120  * LORENE
121  *
122  * Revision 2.10 2001/06/13 14:23:40 eric
123  * Les fonctions Mg3d::del_deriv() et Mg3d::set_deriv_0x0() ne sont plus
124  * virtuelles puisque Mg3d n'a aucune classe derivee.
125  *
126  * Revision 2.9 2001/05/26 13:24:49 eric
127  * Ajout du membre g_twice (grille double pour le desaliasing)
128  * Modif de la declaration de g_angu (pointeur mutable)
129  * g_twice et g_angu ne sont calcules que si necessaire (cad si
130  * on appelle la fonction get_twice() ou get_angu()).
131  *
132  * Revision 2.8 1999/11/16 14:15:57 eric
133  * Ajout de la fonction Mg3d::get_angu().
134  *
135  * Revision 2.7 1999/10/12 14:54:11 eric
136  * Ajout du membre Base_val std_base_scal() const.
137  *
138  * Revision 2.6 1999/10/01 10:35:42 eric
139  * Amelioration des commentaires.
140  *
141  * Revision 2.5 1999/09/30 14:58:00 eric
142  * Operator!= declare const/
143  *
144  * Revision 2.4 1999/09/30 14:11:43 eric
145  * sauve et std_base_vect_cart declarees const.
146  *
147  * Revision 2.3 1999/09/30 12:52:38 eric
148  * Depoussierage.
149  * Documentation.
150  *
151  * Revision 2.2 1999/09/24 14:23:24 eric
152  * Declaration de methodes const.
153  *
154  * Revision 2.1 1999/09/14 15:24:04 phil
155  * ajout de std_base_vect_cart
156  *
157  * Revision 2.0 1999/02/15 10:41:51 hyc
158  * *** empty log message ***
159  *
160  * Revision 2.1 1999/02/15 09:59:50 hyc
161  * *** empty log message ***
162  *
163  * Revision 2.0 1998/12/01 14:28:00 hyc
164  * Version 2
165  *
166  *
167  * $Header: /cvsroot/Lorene/C++/Include/grilles.h,v 1.26 2025/03/26 10:12:20 j_novak Exp $
168  *
169  */
170 
171 // Lorene include files
172 #include "headcpp.h"
173 #include "type_parite.h"
174 
175 namespace Lorene {
176 class Base_val ;
177 
178  //-------------//
179  // Mono-grille //
180  //-------------//
181 
182 // Classe de base
197 class Grille3d {
198  protected:
199  const int nr ;
200  const int nt ;
201  const int np ;
202 
204  int type_r ;
205  int type_t ;
206  int type_p ;
207  int base_r ;
209 
210  public:
212  double* x ;
214  double* tet ;
216  double* phi ;
217 
219  Grille3d(int n_r, int n_t, int n_p, int typer, int typet,
220  int typep, int baser) ;
221 
223  Grille3d(const Grille3d& ) ;
224 
226  void operator=(const Grille3d& ) ;
227 
228  public:
229  virtual ~Grille3d() ;
230 
231  public:
233  int get_nr() const {return nr ;} ;
235  int get_nt() const {return nt ;} ;
237  int get_np() const {return np ;} ;
238 
240  int get_type_r() const {return type_r ;} ;
242  int get_type_t() const {return type_t ;} ;
244  int get_type_p() const {return type_p ;} ;
246  int get_base_r() const {return base_r ;} ;
247 
248  protected:
250  void compute_radial_grid() ;
251 };
252 
253 
254 
255  //---------------//
256  // Multi-grilles //
257  //---------------//
258 
276 class Mg3d {
277 
278  // Data
279  // ----
280  protected:
281  int nzone ;
282 
283  int* nr ;
284  int* nt ;
285  int* np ;
286 
290  int* type_r ;
291 
293  int type_t ;
294 
296  int type_p ;
297 
302  int* colloc_r ;
303 
305  Grille3d** g ;
306 
307  mutable Mg3d* g_angu ;
308  mutable Mg3d* g_angu_1dom ;
310  mutable Mg3d* g_radial ;
311 
315  mutable Mg3d* g_three_halves ;
316 
320  mutable Mg3d* g_twice ;
321 
325  mutable Mg3d* g_plus_half ;
326 
330  mutable Mg3d* g_plus_half_angu ;
331 
336  mutable Mg3d* g_non_axi ;
337 
338  // Constructors - Destructor
339  // -------------------------
340 
341  public:
342 
359  Mg3d(int nz, int nbr[], int typr[], int nbt[], int typt, int nbp[],
360  int typp, int* base_r = 0x0) ;
361 
400  Mg3d(int nz, int nbr, int nbt, int nbp, int typt, int typp,
401  bool compact, bool legendre=false) ;
402 
428  Mg3d(int nz, int nbr, int nbt, int nbp, int typt, int typp) ;
429 
430 
434  explicit Mg3d(const string& filename) ;
435 
441  Mg3d(FILE* fd, bool read_base=false) ;
442 
443  public:
448  Mg3d(const Mg3d& ) ;
449 
450  public:
451 
452  ~Mg3d() ;
453 
454  // Assignement
455  // -----------
456  private:
461  void operator=(const Mg3d& ) ;
462 
463  // Extraction of information
464  // -------------------------
465  public:
467  int get_nzone() const {
468  return nzone ;
469  } ;
471  int get_nr(int l) const {
472  assert(l>=0 && l<nzone) ;
473  return nr[l] ;
474  } ;
476  int get_nt(int l) const {
477  assert(l>=0 && l<nzone) ;
478  return nt[l] ;
479  } ;
481  int get_np(int l) const {
482  assert(l>=0 && l<nzone) ;
483  return np[l] ;
484  } ;
485 
493  int get_type_r(int l) const {
494  assert(l>=0 && l<nzone) ;
495  return type_r[l] ;
496  } ;
497 
504  int get_type_t() const {
505  return type_t ;
506  } ;
507 
514  int get_type_p() const {
515  return type_p ;
516  } ;
517 
519  const Grille3d* get_grille3d(int l) const {
520  assert(l>=0 && l<nzone) ;
521  return g[l] ;
522  } ;
523 
530  int get_colloc_r(int l) const {
531  assert(l>=0 && l<nzone) ;
532  return colloc_r[l] ;
533  }
534 
536  const Mg3d* get_angu() const ;
537 
541  const Mg3d* get_angu_1dom() const ;
542 
544  const Mg3d* get_radial() const ;
545 
549  const Mg3d* get_three_halves() const ;
550 
554  const Mg3d* get_twice() const ;
555 
559  const Mg3d* plus_half() const ;
560 
564  const Mg3d* plus_half_angu() const ;
565 
570  const Mg3d* get_non_axi() const ;
571 
573  bool operator==(const Mg3d& ) const ;
574 
575 
576 
577  // Outputs
578  // -------
579  public:
587  void sauve(FILE* fd, bool save_base=false) const ;
588 
589  friend ostream& operator<<(ostream& , const Mg3d & ) ;
590 
591  // Management of derived quantities
592  // --------------------------------
593  protected:
597  void del_deriv() const ;
598 
602  void set_deriv_0x0() const ;
603 
604 
605  // Miscellaneous
606  // -------------
607  public:
608  bool operator!=(const Mg3d & ) const ;
609 
611  Base_val std_base_scal() const ;
612 
614  Base_val std_base_scal_odd() const ;
615 
619  Base_val** std_base_vect_cart() const ;
620 
624  Base_val** std_base_vect_spher() const ;
625 
629  Base_val** pseudo_base_vect_cart() const ;
630 
634  Base_val** pseudo_base_vect_spher() const ;
635 
636 };
637 ostream& operator<<(ostream& , const Mg3d & ) ;
638 
639 
640 //======================================
641 // One domain standard bases definitions
642 //======================================
643 int std_base_scal_1z(int type_r, int type_t, int type_p) ;
644 int std_base_scal_odd_1z(int type_r, int type_t, int type_p) ;
645 int leg_base_scal_1z(int type_r, int type_t, int type_p) ;
646 int leg_base_scal_odd_1z(int type_r, int type_t, int type_p) ;
647 int jac02_base_scal_1z(int type_r, int type_t, int type_p) ;
648 int jac02_base_scal_odd_1z(int type_r, int type_t, int type_p) ;
649 
650 }
651 #endif
void set_deriv_0x0() const
Sets to 0x0 all the pointers on derived quantities (g_radial , g_angu, g_twice, ...
Definition: mg3d.C:592
int get_type_p() const
Returns the type of sampling in the direction: SYM : : symmetry with respect to the transformatio...
Definition: grilles.h:514
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 ...
Definition: mg3d.C:834
Base_val ** std_base_vect_cart() const
Returns the standard spectral bases for the Cartesian components of a vector.
const Grille3d * get_grille3d(int l) const
Returns a pointer on the 3D mono-grid for domain no. l.
Definition: grilles.h:519
Mg3d * g_non_axi
Pointer on the grid which has at least 4 points in the direction and at least 5 in the direction (f...
Definition: grilles.h:336
int get_np() const
Returns np.
Definition: grilles.h:237
int get_type_r() const
Returns type_r.
Definition: grilles.h:240
int get_np(int l) const
Returns the number of points in the azimuthal direction ( ) in domain no. l.
Definition: grilles.h:481
int type_t
Type of sampling in (SYM,NONSYM)
Definition: grilles.h:205
const int nr
Number of points in r ( )
Definition: grilles.h:199
int type_p
Type of sampling in (SYM, NONSYM)
Definition: grilles.h:296
Lorene prototypes.
Definition: app_hor.h:67
Mg3d * g_plus_half
Pointer on the grid which has 50% more points in r dimension (for desaliasing).
Definition: grilles.h:325
virtual ~Grille3d()
Destructor.
Definition: grille3d.C:169
int * np
Array (size: nzone) of nb. of points in .
Definition: grilles.h:285
double * phi
Array of values of at the np collocation points.
Definition: grilles.h:216
Mg3d * g_angu_1dom
Pointer on the associated angular grid with only one domain.
Definition: grilles.h:309
const Mg3d * get_twice() const
Returns the pointer on the grid which has twice the number of points in each dimension (for desaliasi...
Definition: mg3d.C:720
void del_deriv() const
Deletes all the derived quantities (g_radial , g_angu, g_twice, ...)
Definition: mg3d.C:577
void operator=(const Grille3d &)
Assignement operator.
int get_type_t() const
Returns the type of sampling in the direction: SYM : : symmetry with respect to the equatorial pl...
Definition: grilles.h:504
const Mg3d * get_radial() const
Returns the pointer on the associated radial grid.
Definition: mg3d.C:654
bool operator==(const Mg3d &) const
Comparison operator (egality)
Definition: mg3d.C:865
double * x
Array of values of at the nr collocation points.
Definition: grilles.h:212
int get_type_t() const
Returns type_t.
Definition: grilles.h:242
int type_t
Type of sampling in (SYM, NONSYM)
Definition: grilles.h:293
Base_val ** pseudo_base_vect_cart() const
Returns the standard spectral bases for the Cartesian components of a pseudo-vector.
void compute_radial_grid()
Computes the collocation point coordinates in the radial direction.
Definition: grille3d.C:175
int get_colloc_r(int l) const
Returns the type of collocation points used in domain no.
Definition: grilles.h:530
Base_val ** pseudo_base_vect_spher() const
Returns the standard spectral bases for the spherical components of a pseudo-vector.
Base_val std_base_scal_odd() const
Returns the standard odd spectral bases for a scalar.
~Mg3d()
Destructor.
Definition: mg3d.C:483
Mg3d * g_plus_half_angu
Pointer on the grid which has 50% more points in and dimension (for desaliasing).
Definition: grilles.h:330
void sauve(FILE *fd, bool save_base=false) const
Saves into a file.
Definition: mg3d.C:503
const Mg3d * get_angu() const
Returns the pointer on the associated angular grid.
Definition: mg3d.C:609
int type_p
Type of sampling in (SYM,NONSYM)
Definition: grilles.h:206
double * tet
Array of values of at the nt collocation points.
Definition: grilles.h:214
int nzone
Number of domains (zones)
Definition: grilles.h:281
Mg3d * g_angu
Pointer on the associated angular grid.
Definition: grilles.h:307
Base_val ** std_base_vect_spher() const
Returns the standard spectral bases for the spherical components of a vector.
const int np
Number of points in .
Definition: grilles.h:201
int get_nzone() const
Returns the number of domains.
Definition: grilles.h:467
int base_r
Type of radial spectral basis (BASE_CHEB, BASE_LEG, BASE_JAC02 )
Definition: grilles.h:208
int get_base_r() const
Returns base_r.
Definition: grilles.h:246
Mg3d * g_twice
Pointer on the grid which has twice the number of points in each dimension (for desaliasing).
Definition: grilles.h:320
Mg3d * g_radial
Pointer on the associated radial grid.
Definition: grilles.h:310
const Mg3d * plus_half() const
Returns the pointer on the grid which has 50% more points in r dimension (for desaliasing).
Definition: mg3d.C:768
Grille3d ** g
Array (size: nzone) of pointers on the Grille3d&#39;s.
Definition: grilles.h:305
int * type_r
Array (size: nzone) of type of sampling in r ( ) (RARE,FIN, UNSURR)
Definition: grilles.h:290
int get_nr(int l) const
Returns the number of points in the radial direction ( ) in domain no. l.
Definition: grilles.h:471
int * colloc_r
Array (size: nzone) of type of collocation points in r ( ) and related decompoisition bases (BASE_CHE...
Definition: grilles.h:302
Multi-domain grid.
Definition: grilles.h:276
Bases of the spectral expansions.
Definition: base_val.h:325
Base_val std_base_scal() const
Returns the standard spectral bases for a scalar.
int get_type_p() const
Returns type_p.
Definition: grilles.h:244
const Mg3d * plus_half_angu() const
Returns the pointer on the grid which has 50% more points in and dimension (for desaliasing)...
Definition: mg3d.C:796
friend ostream & operator<<(ostream &, const Mg3d &)
Display.
Definition: mg3d.C:531
int get_nr() const
Returns nr.
Definition: grilles.h:233
int type_r
Type of sampling in r ( ) (RARE,FIN,UNSURR )
Definition: grilles.h:204
int get_nt() const
Returns nt.
Definition: grilles.h:235
int get_nt(int l) const
Returns the number of points in the co-latitude direction ( ) in domain no. l.
Definition: grilles.h:476
bool operator!=(const Mg3d &) const
Operator !=.
Definition: mg3d.C:552
int get_type_r(int l) const
Returns the type of sampling in the radial direction in domain no.
Definition: grilles.h:493
Mg3d(int nz, int nbr[], int typr[], int nbt[], int typt, int nbp[], int typp, int *base_r=0x0)
General constructor.
Definition: mg3d.C:175
int * nt
Array (size: nzone) of nb. of points in .
Definition: grilles.h:284
const Mg3d * get_angu_1dom() const
Returns the pointer on the associated mono-domain angular grid.
Definition: mg3d.C:630
Grille3d(int n_r, int n_t, int n_p, int typer, int typet, int typep, int baser)
Constructor.
Definition: grille3d.C:125
const Mg3d * get_three_halves() const
Returns the pointer on the associated grid with 50% points in every direction for dealiasing...
Definition: mg3d.C:671
void operator=(const Mg3d &)
Assignement operator (private and not implemented to make Mg3d a non-copyable class) ...
Mg3d * g_three_halves
Pointer on the grid having 50% more points in every direction, for dealiasing.
Definition: grilles.h:315
3D grid class in one domain.
Definition: grilles.h:197
const int nt
Number of points in .
Definition: grilles.h:200
int * nr
Array (size: nzone) of nb. of points in r ( )
Definition: grilles.h:283