LORENE
proto.h
1 /*
2  * Prototypes of non class-member functions
3  *
4  */
5 
6 /*
7  * Copyright (c) 1999-2000 Jean-Alain Marck
8  * Copyright (c) 1999-2001 Philippe Grandclement
9  * Copyright (c) 1999-2002 Eric Gourgoulhon
10  * Copyright (c) 2002-2003 Jerome Novak
11  *
12  * This file is part of LORENE.
13  *
14  * LORENE is free software; you can redistribute it and/or modify
15  * it under the terms of the GNU General Public License as published by
16  * the Free Software Foundation; either version 2 of the License, or
17  * (at your option) any later version.
18  *
19  * LORENE is distributed in the hope that it will be useful,
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22  * GNU General Public License for more details.
23  *
24  * You should have received a copy of the GNU General Public License
25  * along with LORENE; if not, write to the Free Software
26  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
27  *
28  */
29 
30 
31 #ifndef __PROTO_H_
32 #define __PROTO_H_
33 
34 
35 /*
36  * $Id: proto.h,v 1.53 2024/07/03 09:54:34 j_novak Exp $
37  * $Log: proto.h,v $
38  * Revision 1.53 2024/07/03 09:54:34 j_novak
39  * New functions for computing spectral summations for the \xi(r) variable.
40  *
41  * Revision 1.52 2021/11/24 13:12:17 g_servignat
42  * Addition of new method mult_xm1_shell(int) to multiply by (\xi +1) in a given shell.
43  *
44  * Revision 1.51 2014/10/13 08:52:36 j_novak
45  * Lorene classes and functions now belong to the namespace Lorene.
46  *
47  * Revision 1.50 2013/06/13 14:18:18 j_novak
48  * Inclusion of new bases R_LEG, R_LEGP and R_LEGI.
49  *
50  * Revision 1.49 2013/06/06 15:31:31 j_novak
51  * Functions to compute Legendre coefficients (not fully tested yet).
52  *
53  * Revision 1.48 2013/06/05 15:06:10 j_novak
54  * Legendre bases are treated as standard bases, when the multi-grid
55  * (Mg3d) is built with BASE_LEG.
56  *
57  * Revision 1.47 2010/10/22 08:08:40 j_novak
58  * Removal of the method Star_rot_dirac::lambda_grv2() and call to the C++ version of integrale2d.
59  *
60  * Revision 1.46 2010/01/20 14:53:50 n_vasset
61  * Adding spectral cutoff functions for use in elliptic tensor equations.
62  *
63  * Revision 1.45 2009/10/23 12:55:46 j_novak
64  * New base T_LEG_MI
65  *
66  * Revision 1.44 2009/10/13 13:50:39 j_novak
67  * New base T_LEG_MP.
68  *
69  * Revision 1.43 2009/08/31 19:39:07 n_vasset
70  * removal of obsolete function get_kerr()
71  *
72  * Revision 1.42 2008/11/27 12:12:38 j_novak
73  * New function to initialize parameters for wave equation.
74  *
75  * Revision 1.41 2008/08/20 11:51:25 n_vasset
76  * new functions to solve the Kerr problem, using degenerate elliptic operators
77  *
78  * Revision 1.40 2008/08/19 06:41:59 j_novak
79  * Minor modifications to avoid warnings with gcc 4.3. Most of them concern
80  * cast-type operations, and constant strings that must be defined as const char*
81  *
82  * Revision 1.39 2008/07/18 12:28:41 j_novak
83  * Corrected some mistakes.
84  *
85  * Revision 1.38 2008/07/18 09:17:35 j_novak
86  * New function tilde_laplacian().
87  *
88  * Revision 1.37 2008/07/11 13:20:08 j_novak
89  * Miscellaneous functions for the system wave equation.
90  *
91  * Revision 1.36 2008/07/10 10:34:35 p_grandclement
92  * forgot this one
93  *
94  * Revision 1.35 2007/12/11 15:28:05 jl_cornou
95  * Jacobi(0,2) polynomials partially implemented
96  *
97  * Revision 1.34 2007/05/06 10:48:08 p_grandclement
98  * Modification of a few operators for the vorton project
99  *
100  * Revision 1.33 2007/01/23 17:08:43 j_novak
101  * New function pois_vect_r0.C to solve the l=0 part of the vector Poisson
102  * equation, which involves only the r-component.
103  *
104  * Revision 1.32 2006/04/27 09:12:29 p_grandclement
105  * First try at irrotational black holes
106  *
107  * Revision 1.31 2006/04/10 15:19:18 j_novak
108  * New definition of 1D operators dsdx and sx in the nucleus (bases R_CHEBP and
109  * R_CHEBI).
110  *
111  * Revision 1.30 2005/11/30 11:09:03 p_grandclement
112  * Changes for the Bin_ns_bh project
113  *
114  * Revision 1.29 2005/08/26 14:02:38 p_grandclement
115  * Modification of the elliptic solver that matches with an oscillatory exterior solution
116  * small correction in Poisson tau also...
117  *
118  * Revision 1.28 2005/06/09 07:56:25 f_limousin
119  * Implement a new function sol_elliptic_boundary() and
120  * Vector::poisson_boundary(...) which solve the vectorial poisson
121  * equation (method 6) with an inner boundary condition.
122  *
123  * Revision 1.27 2005/05/13 08:50:29 j_novak
124  * Added the function int1d_chebi.
125  *
126  * Revision 1.26 2005/02/16 15:04:07 m_forot
127  * Add int1D_cheb function
128  *
129  * Revision 1.25 2005/02/08 10:08:57 f_limousin
130  * Add neumann_binaire(...), dirichlet_binaire(...) and
131  * poisson_vect_binaire(...) with Scalars and Vectors in argument.
132  *
133  * Revision 1.24 2004/12/17 13:35:00 m_forot
134  * Add the case T_LEG
135  *
136  * Revision 1.23 2004/11/23 15:05:40 m_forot
137  * Added prototypes for all new functions in the case there is no
138  * symmetry in theta.
139  *
140  * Revision 1.22 2004/09/28 15:59:47 f_limousin
141  * Add function poisson_vect_boundary which is the same as
142  * poisson_vect_frontiere but for the new classes Tensor and Scalar.
143  *
144  * Revision 1.21 2004/08/24 09:14:40 p_grandclement
145  * Addition of some new operators, like Poisson in 2d... It now requieres the
146  * GSL library to work.
147  *
148  * Also, the way a variable change is stored by a Param_elliptic is changed and
149  * no longer uses Change_var but rather 2 Scalars. The codes using that feature
150  * will requiere some modification. (It should concern only the ones about monopoles)
151  *
152  * Revision 1.20 2004/06/22 08:49:57 p_grandclement
153  * Addition of everything needed for using the logarithmic mapping
154  *
155  * Revision 1.19 2004/03/17 15:58:47 p_grandclement
156  * Slight modification of sol_elliptic_no_zec
157  *
158  * Revision 1.18 2004/02/17 09:21:38 j_novak
159  * New functions for calculating values of the derivatives of a function
160  * using its Chebyshev coefficients.
161  *
162  * Revision 1.17 2004/02/11 09:47:44 p_grandclement
163  * Addition of a new elliptic solver, matching with the homogeneous solution
164  * at the outer shell and not solving in the external domain (more details
165  * coming soon ; check your local Lorene dealer...)
166  *
167  * Revision 1.16 2004/02/09 08:55:30 j_novak
168  * Corrected error in the arguments of _solp_r_chebu_cinq
169  *
170  * Revision 1.15 2004/02/06 10:53:51 j_novak
171  * New dzpuis = 5 -> dzpuis = 3 case (not ready yet).
172  *
173  * Revision 1.14 2004/01/28 16:46:22 p_grandclement
174  * Addition of the sol_elliptic_fixe_der_zero stuff
175  *
176  * Revision 1.13 2004/01/15 09:15:36 p_grandclement
177  * Modification and addition of the Helmholtz operators
178  *
179  * Revision 1.12 2003/12/11 14:48:47 p_grandclement
180  * Addition of ALL (and that is a lot !) the files needed for the general elliptic solver ... UNDER DEVELOPEMENT...
181  *
182  * Revision 1.11 2003/09/16 13:07:40 j_novak
183  * New files for coefficient trnasformation to/from the T_LEG_II base.
184  *
185  * Revision 1.10 2003/09/16 08:53:05 j_novak
186  * Addition of the T_LEG_II base (odd in theta, only for odd m) and the
187  * transformation functions from and to T_SIN_P.
188  *
189  * Revision 1.9 2003/06/18 08:45:26 j_novak
190  * In class Mg3d: added the member get_radial, returning only a radial grid
191  * For dAlembert solver: the way the coefficients of the operator are defined has been changed.
192  *
193  * Revision 1.8 2003/02/13 16:40:24 p_grandclement
194  * Addition of various things for the Bin_ns_bh project, non of them being
195  * completely tested
196  *
197  * Revision 1.7 2002/11/12 17:45:19 j_novak
198  * Added transformation function for T_COS basis.
199  *
200  * Revision 1.6 2002/09/09 13:00:39 e_gourgoulhon
201  * Modification of declaration of Fortran 77 prototypes for
202  * a better portability (in particular on IBM AIX systems):
203  * All Fortran subroutine names are now written F77_* and are
204  * defined in the new file C++/Include/proto_f77.h.
205  *
206  * Revision 1.5 2002/05/11 12:39:08 e_gourgoulhon
207  * Added declaration of som_tet_cossin_si.
208  *
209  * Revision 1.4 2002/05/05 16:24:48 e_gourgoulhon
210  * Added som_tet_cossin_sp
211  *
212  * Revision 1.3 2002/01/03 15:30:27 j_novak
213  * Some comments modified.
214  *
215  * Revision 1.2 2002/01/02 14:07:56 j_novak
216  * Dalembert equation is now solved in the shells. However, the number of
217  * points in theta and phi must be the same in each domain. The solver is not
218  * completely tested (beta version!).
219  *
220  * Revision 1.1.1.1 2001/11/20 15:19:27 e_gourgoulhon
221  * LORENE
222  *
223  * Revision 2.69 2001/05/07 09:11:26 phil
224  * *** empty log message ***
225  *
226  * Revision 2.68 2001/04/03 12:41:23 phil
227  * modification de itemax dans separation
228  *
229  * Revision 2.67 2001/03/22 10:40:13 phil
230  * modification prototypage se separation
231  *
232  * Revision 2.66 2001/03/02 10:21:26 phil
233  * *** empty log message ***
234  *
235  * Revision 2.65 2001/03/02 10:18:47 phil
236  * modif parametrage separation
237  *
238  * Revision 2.64 2001/02/28 11:23:30 phil
239  * ajout separation
240  *
241  * Revision 2.63 2001/01/29 14:30:10 phil
242  * ajout type rotation
243  *
244  * Revision 2.62 2000/12/13 15:42:14 phil
245  * ajout des trucs relatifs a Lindquist
246  *
247  * Revision 2.61 2000/12/04 13:33:28 novak
248  * *** empty log message ***
249  *
250  * Revision 2.60 2000/12/04 13:29:08 novak
251  * Added prototypes for the dalembertian
252  *
253  * Revision 2.59 2000/10/19 10:07:49 phil
254  * ajout de regle
255  *
256  * Revision 2.58 2000/10/19 09:35:44 phil
257  * *** empty log message ***
258  *
259  * Revision 2.57 2000/10/04 14:40:34 eric
260  * *** empty log message ***
261  *
262  * Revision 2.56 2000/09/29 14:02:06 eric
263  * *** empty log message ***
264  *
265  * Revision 2.55 2000/09/28 10:01:36 eric
266  * *** empty log message ***
267  *
268  * Revision 2.54 2000/09/08 16:26:26 eric
269  * *** empty log message ***
270  *
271  * Revision 2.53 2000/09/08 16:07:43 eric
272  * *** empty log message ***
273  *
274  * Revision 2.52 2000/09/07 15:07:40 eric
275  * *** empty log message ***
276  *
277  * Revision 2.51 2000/09/06 13:59:53 eric
278  * *** empty log message ***
279  *
280  * Revision 2.50 2000/06/06 12:42:55 phil
281  * ajout de Cmp division_xpun (const Cmp&,int)
282  *
283  * Revision 2.49 2000/05/22 13:33:15 phil
284  * ajout des trucs pour poisson avec dzpuis == 3
285  *
286  * Revision 2.48 2000/04/03 17:01:01 phil
287  * ajout de sxpun_1d
288  *
289  * Revision 2.47 2000/03/16 16:28:30 phil
290  * *** empty log message ***
291  *
292  * Revision 2.46 2000/03/09 13:52:55 phil
293  * *** empty log message ***
294  *
295  * Revision 2.45 2000/03/09 13:42:34 phil
296  * vire les trucs relatifs a Poisson compacts
297  *
298  * Revision 2.44 2000/03/06 10:27:07 eric
299  * Ajout des protos som_*_symy et som_*_asymy.
300  *
301  * Revision 2.43 2000/01/20 14:07:59 phil
302  * vire poisson_vect et xksk
303  *
304  * Revision 2.42 1999/12/15 09:41:52 eric
305  * *** empty log message ***
306  *
307  *
308  * $Header: /cvsroot/Lorene/C++/Include/proto.h,v 1.53 2024/07/03 09:54:34 j_novak Exp $
309  *
310  */
311 
312 namespace Lorene {
313 class Param ;
314 class Tbl ;
315 class Mtbl ;
316 class Mtbl_cf ;
317 class Map_af ;
318 class Matrice ;
319 class Valeur ;
320 class Base_val ;
321 class Cmp ;
322 class Tenseur ;
323 class Scalar ;
324 class Tensor ;
325 class Sym_tensor ;
326 class Vector ;
327 class Param_elliptic ;
328 
329 
330 // Routines calcul de coefficients
331 // -------------------------------
332 double* cheb_ini(const int) ;
333 double* chebimp_ini(const int) ;
334 void four1d(const int, double* ) ;
335 void chebyf1d(const int, double* ) ;
336 void chebyr1d(const int, double* ) ;
337 void cfpcossin(const int* ,const int* , double* ) ;
338 void cfpcossini(const int* ,const int* , double* ) ;
339 void cftcos(const int*, const int*, double*, const int*, double*) ;
340 void cftsin(const int*, const int*, double*, const int*, double*) ;
341 void cftcosp(const int*, const int*, double*, const int*, double*) ;
342 void cftcosi(const int*, const int*, double*, const int*, double*) ;
343 void cftsinp(const int*, const int*, double*, const int*, double*) ;
344 void cftsini(const int*, const int*, double*, const int*, double*) ;
345 void cftcossincp(const int*, const int*, double*, const int*, double*) ;
346 void cftcossinsi(const int*, const int*, double*, const int*, double*) ;
347 void cftcossinsp(const int*, const int*, double*, const int*, double*) ;
348 void cftcossinci(const int*, const int*, double*, const int*, double*) ;
349 void cftcossins(const int*, const int*, double*, const int*, double*) ;
350 void cftcossinc(const int*, const int*, double*, const int*, double*) ;
351 void cftleg(const int*, const int*, double*, const int*, double*) ;
352 void cftlegmp(const int*, const int*, double*, const int*, double*) ;
353 void cftlegmi(const int*, const int*, double*, const int*, double*) ;
354 void cftlegp(const int*, const int*, double*, const int*, double*) ;
355 void cftlegpp(const int*, const int*, double*, const int*, double*) ;
356 void cftlegi(const int*, const int*, double*, const int*, double*) ;
357 void cftlegip(const int*, const int*, double*, const int*, double*) ;
358 void cftlegpi(const int*, const int*, double*, const int*, double*) ;
359 void cftlegii(const int*, const int*, double*, const int*, double*) ;
360 void cfrcheb(const int*, const int*, double*, const int*, double*) ;
361 void cfrchebp(const int*, const int*, double*, const int*, double*) ;
362 void cfrchebi(const int*, const int*, double*, const int*, double*) ;
363 void cfrchebpimp(const int*, const int*, double*, const int*, double*) ;
364 void cfrchebpimi(const int*, const int*, double*, const int*, double*) ;
365 void cfrchebpip(const int*, const int*, double*, const int*, double*) ;
366 void cfrchebpii(const int*, const int*, double*, const int*, double*) ;
367 void cipcossin(const int* , const int* , const int* , double* , double* ) ;
368 void cipcossini(const int* , const int* , const int* , double* , double* ) ;
369 void citcos(const int*, const int*, double*, const int*, double*) ;
370 void citcosp(const int*, const int*, double*, const int*, double*) ;
371 void citcosi(const int*, const int*, double*, const int*, double*) ;
372 void citsinp(const int*, const int*, double*, const int*, double*) ;
373 void citsini(const int*, const int*, double*, const int*, double*) ;
374 void citcossincp(const int*, const int*, double*, const int*, double*) ;
375 void citcossinsi(const int*, const int*, double*, const int*, double*) ;
376 void citcossinsp(const int*, const int*, double*, const int*, double*) ;
377 void citcossinci(const int*, const int*, double*, const int*, double*) ;
378 void citcossins(const int*, const int*, double*, const int*, double*) ;
379 void citcossinc(const int*, const int*, double*, const int*, double*) ;
380 void citleg(const int*, const int*, double*, const int*, double*) ;
381 void citlegmp(const int*, const int*, double*, const int*, double*) ;
382 void citlegmi(const int*, const int*, double*, const int*, double*) ;
383 void citlegp(const int*, const int*, double*, const int*, double*) ;
384 void citlegpp(const int*, const int*, double*, const int*, double*) ;
385 void citlegi(const int*, const int*, double*, const int*, double*) ;
386 void citlegip(const int*, const int*, double*, const int*, double*) ;
387 void citlegpi(const int*, const int*, double*, const int*, double*) ;
388 void citlegii(const int*, const int*, double*, const int*, double*) ;
389 void circheb(const int*, const int*, double*, const int*, double*) ;
390 void circhebp(const int*, const int*, double*, const int*, double*) ;
391 void circhebi(const int*, const int*, double*, const int*, double*) ;
392 void cirleg(const int*, const int*, double*, const int*, double*) ;
393 void cirlegp(const int*, const int*, double*, const int*, double*) ;
394 void cirlegi(const int*, const int*, double*, const int*, double*) ;
395 void circhebpimp(const int*, const int*, double*, const int*, double*) ;
396 void circhebpimi(const int*, const int*, double*, const int*, double*) ;
397 void circhebpip(const int*, const int*, double*, const int*, double*) ;
398 void circhebpii(const int*, const int*, double*, const int*, double*) ;
399 double* legendre(int , int ) ;
400 double* legendre_norm(int , int ) ;
401 double* mat_cossincp_legp(int, int) ;
402 double* mat_cossinci_legi(int, int) ;
403 double* mat_cossinc_leg(int, int) ;
404 double* mat_cosp_legpp(int, int) ;
405 double* mat_cosi_legip(int, int) ;
406 double* mat_sini_legpi(int, int) ;
407 double* mat_sinp_legii(int, int) ;
408 double* mat_cos_legmp(int, int) ;
409 double* mat_sin_legmi(int, int) ;
410 double* mat_legp_cossincp(int, int) ;
411 double* mat_legi_cossinci(int, int) ;
412 double* mat_leg_cossinc(int, int) ;
413 double* mat_legpp_cosp(int, int) ;
414 double* mat_legip_cosi(int, int) ;
415 double* mat_legpi_sini(int, int) ;
416 double* mat_legii_sinp(int, int) ;
417 double* mat_legmp_cos(int, int) ;
418 double* mat_legmi_sin(int, int) ;
419 void chb_cossincp_legp(const int* , const double* , double* ) ;
420 void chb_legp_cossincp(const int* , const double* , double* ) ;
421 void chb_cossinc_leg(const int* , const double* , double* ) ;
422 void chb_leg_cossinc(const int* , const double* , double* ) ;
423 void chb_cosp_legpp(const int* , const double* , double* ) ;
424 void chb_legpp_cosp(const int* , const double* , double* ) ;
425 void chb_cosi_legip(const int* , const double* , double* ) ;
426 void chb_legip_cosi(const int* , const double* , double* ) ;
427 void chb_sini_legpi(const int* , const double* , double* ) ;
428 void chb_legpi_sini(const int* , const double* , double* ) ;
429 void chb_cossinci_legi(const int* , const double* , double* ) ;
430 void chb_legi_cossinci(const int* , const double* , double* ) ;
431 void chb_sinp_legii(const int* , const double* , double* ) ;
432 void chb_legii_sinp(const int* , const double* , double* ) ;
433 void chb_cos_legmp(const int* , const double* , double* ) ;
434 void chb_legmp_cos(const int* , const double* , double* ) ;
435 void chb_sin_legmi(const int* , const double* , double* ) ;
436 void chb_legmi_sin(const int* , const double* , double* ) ;
437 
438 double int1d_chebp(int, const double* ) ;
439 double int1d_chebi(int, const double* ) ;
440 double int1d_cheb(int, const double* ) ;
441 
442 //Routines Legendre en r
443 void cirleg(const int*, const int*, double*, const int*, double*) ;
444 void cirlegp(const int*, const int*, double*, const int*, double*) ;
445 void cirlegi(const int*, const int*, double*, const int*, double*) ;
446 void cfrleg(const int*, const int*, double*, const int*, double*) ;
447 void cfrlegp(const int*, const int*, double*, const int*, double*) ;
448 void cfrlegi(const int*, const int*, double*, const int*, double*) ;
449 void legendre_collocation_points(int, double*) ;
450 
451 // Routines Jacobi
452 double* jacobi(int, double) ;
453 double* pointsgausslobatto(int) ;
454 Tbl jacobipointsgl(int) ;
455 double* coeffjaco(int, double*) ;
456 void cfrjaco02(const int*, const int*, double*, const int*, double*);
457 
458 // Routines calcul de coef inverse
459 void cipcossin(const int* , const int* , const int* , double* , double* ) ;
460 void citcosp(const int*, const int*, double*, const int*, double*) ;
461 void citcosi(const int*, const int*, double*, const int*, double*) ;
462 void citcos(const int*, const int*, double*, const int*, double*) ;
463 void citsin(const int*, const int*, double*, const int*, double*) ;
464 void citsinp(const int*, const int*, double*, const int*, double*) ;
465 void citsini(const int*, const int*, double*, const int*, double*) ;
466 void citcossincp(const int*, const int*, double*, const int*, double*) ;
467 void citcossinsi(const int*, const int*, double*, const int*, double*) ;
468 void citcossinsp(const int*, const int*, double*, const int*, double*) ;
469 void citcossinci(const int*, const int*, double*, const int*, double*) ;
470 void citcossins(const int*, const int*, double*, const int*, double*) ;
471 void citcossinc(const int*, const int*, double*, const int*, double*) ;
472 void citlegp(const int*, const int*, double*, const int*, double*) ;
473 void citlegpp(const int*, const int*, double*, const int*, double*) ;
474 void citlegi(const int*, const int*, double*, const int*, double*) ;
475 void circheb(const int*, const int*, double*, const int*, double*) ;
476 void circhebp(const int*, const int*, double*, const int*, double*) ;
477 void circhebi(const int*, const int*, double*, const int*, double*) ;
478 void circhebpimp(const int*, const int*, double*, const int*, double*) ;
479 void circhebpimi(const int*, const int*, double*, const int*, double*) ;
480 void cirjaco02(const int*, const int*, double* , const int*, double*) ;
481 
482 // Routines calculant la matrice du laplacien
483 Matrice _laplacien_mat_pas_prevu(int, int, double, int) ;
484 Matrice _laplacien_mat_r_chebp(int, int, double, int) ;
485 Matrice _laplacien_mat_r_chebi(int, int, double, int) ;
486 Matrice _laplacien_mat_r_chebu(int, int, double, int) ;
487 Matrice _laplacien_mat_r_chebu_deux(int, int) ;
488 Matrice _laplacien_mat_r_chebu_trois(int, int) ;
489 Matrice _laplacien_mat_r_chebu_quatre(int, int) ;
490 Matrice _laplacien_mat_r_chebu_cinq(int, int) ;
491 Matrice _laplacien_mat_r_cheb(int, int, double, int) ;
492 Matrice laplacien_mat(int , int , double , int, int ) ;
493 
494 //Routines de passage a bande versions Matrice et Tbl
495 Matrice _cl_pas_prevu (const Matrice&, int, double, int) ;
496 Matrice _cl_r_cheb (const Matrice&, int, double, int) ;
497 Matrice _cl_r_chebi (const Matrice&, int, double, int) ;
498 Matrice _cl_r_chebu (const Matrice&, int, double, int) ;
499 Matrice _cl_r_chebu_cinq (const Matrice&, int) ;
500 Matrice _cl_r_chebu_quatre (const Matrice&, int) ;
501 Matrice _cl_r_chebu_trois (const Matrice&, int) ;
502 Matrice _cl_r_chebu_deux (const Matrice&, int) ;
503 Matrice _cl_r_chebp (const Matrice&, int, double, int) ;
504 Matrice combinaison (const Matrice&, int, double, int, int) ;
505 
506 Tbl _cl_pas_prevu (const Tbl&, int) ;
507 Tbl _cl_r_cheb (const Tbl&, int) ;
508 Tbl _cl_r_chebi (const Tbl&, int) ;
509 Tbl _cl_r_chebu (const Tbl&, int) ;
510 Tbl _cl_r_chebu_deux (const Tbl&) ;
511 Tbl _cl_r_chebu_trois (const Tbl&) ;
512 Tbl _cl_r_chebu_quatre (const Tbl&) ;
513 Tbl _cl_r_chebu_cinq (const Tbl&) ;
514 Tbl _cl_r_chebp (const Tbl&, int) ;
515 Tbl combinaison (const Tbl&, int, int) ;
516 
517 
518 // Routines de preparation du laplacien inversible
519 Matrice _prepa_nondege_pas_prevu(const Matrice &, int , double, int) ;
520 Matrice _prepa_nondege_r_cheb (const Matrice&, int, double, int) ;
521 Matrice _prepa_nondege_r_chebp (const Matrice&, int, double, int) ;
522 Matrice _prepa_nondege_r_chebi (const Matrice&, int, double, int) ;
523 Matrice _prepa_nondege_r_chebu (const Matrice&, int, double, int) ;
524 Matrice _prepa_nondege_r_chebu_deux (const Matrice&, int) ;
525 Matrice _prepa_nondege_r_chebu_trois (const Matrice&, int) ;
526 Matrice _prepa_nondege_r_chebu_quatre (const Matrice&, int) ;
527 Matrice _prepa_nondege_r_chebu_cinq (const Matrice&, int) ;
528 Matrice prepa_nondege (const Matrice&, int, double, int, int) ;
529 
530 //Routines de calcul de la solution particuliere
531 Tbl _solp_pas_prevu(const Matrice&, const Matrice&, double, double, const Tbl&, int) ;
532 Tbl _solp_r_cheb (const Matrice&, const Matrice&, double, double, const Tbl&, int) ;
533 Tbl _solp_r_chebp (const Matrice&, const Matrice&, double, double, const Tbl&, int) ;
534 Tbl _solp_r_chebi (const Matrice&, const Matrice&, double, double, const Tbl&, int) ;
535 Tbl _solp_r_chebu (const Matrice&, const Matrice&, double, double, const Tbl&, int) ;
536 Tbl _solp_r_chebu_deux (const Matrice&, const Matrice&, const Tbl&) ;
537 Tbl _solp_r_chebu_trois (const Matrice&, const Matrice&, double, const Tbl&) ;
538 Tbl _solp_r_chebu_quatre (const Matrice&, const Matrice&, double, const Tbl&) ;
539 Tbl _solp_r_chebu_cinq (const Matrice&, const Matrice&, const Tbl&) ;
540 Tbl solp (const Matrice&, const Matrice&, double, double, const Tbl&, int, int) ;
541 
542 //Routines de calcul des solutions homogenes
543 Tbl _solh_pas_prevu (int, int, double) ;
544 Tbl _solh_r_cheb (int, int, double) ;
545 Tbl _solh_r_chebp (int, int, double) ;
546 Tbl _solh_r_chebi (int, int, double) ;
547 Tbl _solh_r_chebu (int, int, double) ;
548 Tbl solh (int, int, double, int) ;
549 
550 // Routines helmholtz minus :
551 Matrice helmholtz_minus_mat(int , int, double , double , double, int ) ;
552 Matrice cl_helmholtz_minus (const Matrice&, int) ;
553 Tbl cl_helmholtz_minus (const Tbl&, int) ;
554 Matrice prepa_helmholtz_minus_nondege (const Matrice&, int) ;
555 Tbl solp_helmholtz_minus (const Matrice&, const Matrice&, const Tbl&,
556  double, double, int, int) ;
557 Tbl solh_helmholtz_minus (int, int, double, double, double, int) ;
558 
559 // Routines helmholtz plus :
560 Matrice helmholtz_plus_mat(int , int, double , double , double, int ) ;
561 Matrice cl_helmholtz_plus (const Matrice&, int) ;
562 Tbl cl_helmholtz_plus (const Tbl&, int) ;
563 Matrice prepa_helmholtz_plus_nondege (const Matrice&, int) ;
564 Tbl solp_helmholtz_plus (const Matrice&, const Matrice&, const Tbl&,
565  double, double, int) ;
566 Tbl solh_helmholtz_plus (int, int, double, double, double, int) ;
567 
568 
569 //Routines de calcul des valeurs limites
570 Tbl val_solh (int, double, double, int) ;
571 Tbl val_solp (const Tbl&, double, int) ;
572 
573 double val1_dern_1d (int, const Tbl&, int) ;
574 double valm1_dern_1d (int, const Tbl&, int) ;
575 
576 
577 //Routines de derivations version 1d
578 void _d2sdx2_1d_pas_prevu(int, double*, double* ) ;
579 void _d2sdx2_1d_r_chebu(int, double*, double* ) ;
580 void _d2sdx2_1d_r_cheb(int, double*, double* ) ;
581 void _d2sdx2_1d_r_chebp(int, double*, double* ) ;
582 void _d2sdx2_1d_r_chebi(int, double*, double * ) ;
583 void d2sdx2_1d(int, double** , int) ;
584 
585 void _dsdx_1d_pas_prevu(int, double*, double* ) ;
586 void _dsdx_1d_r_chebu(int, double*, double* ) ;
587 void _dsdx_1d_r_chebp(int, double*, double* ) ;
588 void _dsdx_1d_r_chebi(int, double*, double* ) ;
589 void dsdx_1d(int, double** , int) ;
590 
591 void _multx_1d_pas_prevu(int, double*, double* ) ;
592 void _multx_1d_r_cheb(int, double*, double* ) ;
593 void multx_1d(int, double **, int) ;
594 void multxpun_1d(int, double **, int) ;
595 
596 void _sx_1d_pas_prevu(int, double*, double* ) ;
597 void _sx_1d_r_chebi(int, double*, double* ) ;
598 void _sx_1d_r_chebp(int, double*, double* ) ;
599 void sx_1d(int, double **, int) ;
600 
601 void _sx2_1d_pas_prevu(int, double*, double*) ;
602 void _sx2_1d_identite(int, double*, double*) ;
603 void _sx2_1d_r_chebp(int, double*, double*) ;
604 void _sx2_1d_r_chebi(int, double*, double*) ;
605 void _sxm12_1d_r_chebu(int, double *, double*) ;
606 void sx2_1d(int, double**, int) ;
607 
608 void _sxdsdx_1d_pas_prevu(int, double*, double*) ;
609 void _dsdx_1d_r_cheb(int, double*, double*) ;
610 void _sxdsdx_1d_r_chebi(int, double*, double*) ;
611 void _sxdsdx_1d_r_chebp(int, double*, double*) ;
612 void sxdsdx_1d(int, double** , int) ;
613 
614 //Routines de derivations (pour sol_dalembert)
615 void _dsdx_r_chebp(Tbl *, int &) ;
616 void _dsdx_r_chebi(Tbl *, int &) ;
617 
618 // Resolution de l'equation de Poisson
619 int nullite_plm_sym (int, int, int, int) ;
620 int nullite_plm_nonsym (int, int, int, int) ;
621 int nullite_plm_nonsym_anti (int, int, int, int) ;
622 int nullite_plm (int, int, int, int, Base_val) ;
623 
624 void donne_lm_sym (int, int, int, int, int&, int&, int&) ;
625 void donne_lm_nonsym (int, int, int, int, int&, int&, int&) ;
626 void donne_lm_nonsym_anti (int, int, int, int, int&, int&, int&) ;
627 void donne_lm (int, int, int, int, Base_val, int&, int&, int&) ;
628 
629 
630 // Les sommations en r :
631 void som_r_pas_prevu
632  (double*, const int, const int, const int, const double, double*) ;
633 void som_r_cheb
634  (double*, const int, const int, const int, const double, double*) ;
635 void som_r_chebi
636  (double*, const int, const int, const int, const double, double*) ;
637 void som_r_chebp
638  (double*, const int, const int, const int, const double, double*) ;
639 void som_r_chebu
640  (double*, const int, const int, const int, const double, double*) ;
641 void som_r_chebpim_p
642  (double*, const int, const int, const int, const double, double*) ;
643 void som_r_chebpim_i
644  (double*, const int, const int, const int, const double, double*) ;
645 void som_r_chebpi_p
646  (double*, const int, const int, const int, const double, double*) ;
647 void som_r_chebpi_i
648  (double*, const int, const int, const int, const double, double*) ;
649 void som_r_cheb_symy
650  (double*, const int, const int, const int, const double, double*) ;
651 void som_r_chebu_symy
652  (double*, const int, const int, const int, const double, double*) ;
653 void som_r_chebpim_p_symy
654  (double*, const int, const int, const int, const double, double*) ;
655 void som_r_chebpim_i_symy
656  (double*, const int, const int, const int, const double, double*) ;
657 void som_r_cheb_asymy
658  (double*, const int, const int, const int, const double, double*) ;
659 void som_r_chebu_asymy
660  (double*, const int, const int, const int, const double, double*) ;
661 void som_r_chebpim_p_asymy
662  (double*, const int, const int, const int, const double, double*) ;
663 void som_r_chebpim_i_asymy
664  (double*, const int, const int, const int, const double, double*) ;
665 void som_r_leg
666  (double*, const int, const int, const int, const double, double*) ;
667 void som_r_legi
668  (double*, const int, const int, const int, const double, double*) ;
669 void som_r_legp
670  (double*, const int, const int, const int, const double, double*) ;
671 void som_r_jaco02
672  (double*, const int, const int, const int, const double, double*) ;
673 
674  // 1D version of sums in r
675  double som_r_1d_pas_prevu(const double*, int, double) ;
676  double som_r_1d_cheb(const double*, int, double) ;
677  double som_r_1d_chebp(const double*, int, double) ;
678  double som_r_1d_chebi(const double*, int, double) ;
679  double som_r_1d_leg(const double*, int, double) ;
680  double som_r_1d_legp(const double*, int, double) ;
681  double som_r_1d_legi(const double*, int, double) ;
682  double som_r_1d_jaco02(const double*, int, double) ;
683 
684 
685 // Les sommations en theta :
686 void som_tet_pas_prevu
687  (double*, const int, const int, const double, double*) ;
688 void som_tet_cos
689  (double*, const int, const int, const double, double* ) ;
690 void som_tet_cos_p
691  (double*, const int, const int, const double, double* ) ;
692 void som_tet_cos_i
693  (double*, const int, const int, const double, double* ) ;
694 void som_tet_sin
695  (double*, const int, const int, const double, double* ) ;
696 void som_tet_sin_p
697  (double*, const int, const int, const double, double* ) ;
698 void som_tet_sin_i
699  (double*, const int, const int, const double, double* ) ;
700 void som_tet_cossin_cp
701  (double*, const int, const int, const double, double* ) ;
702 void som_tet_cossin_ci
703  (double*, const int, const int, const double, double* ) ;
704 void som_tet_cossin_c
705  (double*, const int, const int, const double, double* ) ;
706 void som_tet_cossin_s
707  (double*, const int, const int, const double, double* ) ;
708 void som_tet_cossin_sp
709  (double*, const int, const int, const double, double* ) ;
710 void som_tet_cossin_si
711  (double*, const int, const int, const double, double* ) ;
712 void som_tet_cossin_cp_symy
713  (double*, const int, const int, const double, double* ) ;
714 void som_tet_cossin_ci_symy
715  (double*, const int, const int, const double, double* ) ;
716 void som_tet_cossin_cp_asymy
717  (double*, const int, const int, const double, double* ) ;
718 void som_tet_cossin_ci_asymy
719  (double*, const int, const int, const double, double* ) ;
720 
721 // Les sommations en phi :
722 void som_phi_pas_prevu
723  (double*, const int, const double, double* ) ;
724 void som_phi_cossin
725  (double*, const int, const double, double* ) ;
726 void som_phi_cossin_p
727  (double*, const int, const double, double* ) ;
728 void som_phi_cossin_i
729  (double*, const int, const double, double* ) ;
730 void som_phi_cossin_symy
731  (double*, const int, const double, double* ) ;
732 void som_phi_cossin_asymy
733  (double*, const int, const double, double* ) ;
734 
735 // les divisions et multiplications par x-1 :
736 void sxm1_1d_cheb(int, double*) ;
737 void mult_xm1_1d_cheb(int, const double*, double*) ;
738 void mult2_xm1_1d_cheb(int, const double*, double*) ;
739 
740 // Multiplication par x+1
741 void mult_xp1_1d_cheb(int, const double*, double*) ;
742 
743 // x * dsdx ...
744 void _xdsdx_1d_pas_prevu (int, double*, double*) ;
745 void _xdsdx_1d_r_cheb (int, double*, double*) ;
746 void _xdsdx_1d_r_chebp (int, double*, double*) ;
747 void _xdsdx_1d_r_chebi (int, double*, double*) ;
748 void xdsdx_1d(int, double**, int) ;
749 
750 // Multiplication par x^2
751 void multx2_1d(int, double **, int) ;
752 void _multx2_1d_r_cheb(int, double* , double *);
753 void _multx2_1d_r_chebp(int, double* , double *);
754 void _multx2_1d_r_chebi(int, double* , double *);
755 void _multx2_1d_pas_prevu(int, double* , double *);
756 
757 // division par (x+1)
758 void sxpun_1d(int, double **, int) ;
759 void _sxpun_1d_r_cheb(int, double* , double *);
760 void _sxpun_1d_pas_prevu(int, double* , double *);
761 Cmp division_xpun (const Cmp&, int) ;
762 
763 // Fonctions liees a la resolution des l'equation des ondes
764 void get_operateur_dal(const Param&, const int&, const int&,
765  int&, Matrice& );
766 Tbl dal_inverse(const int&, const int&, const Matrice&, const Tbl&,
767  const bool) ;
768 Mtbl_cf sol_dalembert(Param&, const Map_af&, const Mtbl_cf&) ;
769 
770 void runge_kutta3_wave_sys(double, const Scalar&, const Scalar&, Scalar& , Scalar&, int dl=0 ) ;
771 void evolve_outgoing_BC(double, int, const Scalar&, Scalar&, Tbl&, Tbl&, Tbl&, int dl=0) ;
772 void tilde_laplacian(const Scalar& B_in, Scalar& tilde_lap, int dl=-1) ;
773 void initialize_outgoing_BC(int, const Scalar& , const Scalar& , Tbl&) ;
774 
775 // Fonctions liees aux operateurs elliptiques degeneres: obtention d'espaces-temps de type Kerr
776 void tensorelliptic ( Scalar source, Scalar& resu, double fitd1, double fit2d1, double fit0d2 = 0., double fit1d2 = 0., double fit0d3 = 0., double fit1d3 = 0.);
777  void tensorellipticBt ( Scalar source, Scalar& resu, double fitd1, double fit2d1, double fit0d2 = 0., double fit1d2 = 0., double fit0d3 = 0., double fit1d3 = 0.);
778 void tensorellipticCt ( Scalar source, Scalar& resu, double fitd1, double fit2d1, double fit0d2, double fit1d2, double fit0d3, double fit1d3);
779 
780  Sym_tensor secmembre_kerr ( const Sym_tensor& hij, const Sym_tensor& aa,const Scalar& nn,const Scalar& ppsi,const Vector& bb);
781 
782  Sym_tensor boundfree_tensBC( Sym_tensor source, Vector Beta, Scalar Psi, Scalar Nn, Sym_tensor hij_guess, double precision , int loopmax = 250) ;
783 
784 // Trucs utilises pour poisson_compact :
785 Matrice lap_cpt_mat(int, int, int) ;
786 Matrice xdsdx_mat(int, int, int) ;
787 Matrice combinaison_cpt (const Matrice &, int, int) ;
788 Tbl combinaison_cpt (const Tbl &, int) ;
789 
790 // Trucs binaires :
791 void dirichlet_binaire (const Cmp& source_un, const Cmp& source_deux,
792  const Valeur& boundary_un, const Valeur& boundary_deux,
793  Cmp& sol_un, Cmp& sol_deux, int num_front,
794  double precision) ;
795 void dirichlet_binaire (const Cmp& source_un, const Cmp& source_deux,
796  double bound_un, double bound_deux,
797  Cmp& sol_un, Cmp& sol_deux, int num_front,
798  double precision) ;
799 void dirichlet_binaire (const Scalar& source_un, const Scalar& source_deux,
800  const Valeur& boundary_un, const Valeur& boundary_deux,
801  Scalar& sol_un, Scalar& sol_deux, int num_front,
802  double precision) ;
803 
804 void neumann_binaire (const Cmp& source_un, const Cmp& source_deux,
805  const Valeur& boundary_un, const Valeur& boundary_deux,
806  Cmp& sol_un, Cmp& sol_deux, int num_front,
807  double precision) ;
808 void neumann_binaire (const Cmp& source_un, const Cmp& source_deux,
809  double bound_un, double bound_deux,
810  Cmp& sol_un, Cmp& sol_deux, int num_front,
811  double precision) ;
812 void neumann_binaire (const Scalar& source_un, const Scalar& source_deux,
813  const Valeur& boundary_un, const Valeur& boundary_deux,
814  Scalar& sol_un, Scalar& sol_deux, int num_front,
815  double precision) ;
816 
817 void poisson_vect_frontiere (double lambda, const Tenseur& source, Tenseur& shift,
818  const Valeur& lim_x, const Valeur& lim_y, const Valeur& lim_z,
819  int num_front, double precision, int itermax) ;
820 void poisson_vect_boundary (double lambda, const Vector& source, Vector& shift,
821  const Valeur& lim_x, const Valeur& lim_y, const Valeur& lim_z,
822  int num_front, double precision, int itermax) ;
823 
824 void poisson_vect_binaire ( double lambda,
825  const Tenseur& source_un, const Tenseur& source_deux,
826  const Valeur& bound_x_un, const Valeur& bound_y_un,
827  const Valeur& bound_z_un, const Valeur& bound_x_deux,
828  const Valeur& bound_y_deux, const Valeur& bound_z_deux,
829  Tenseur& sol_un, Tenseur& sol_deux, int num_front, double precision) ;
830 void poisson_vect_binaire ( double lambda,
831  const Vector& source_un, const Vector& source_deux,
832  const Valeur& bound_x_un, const Valeur& bound_y_un,
833  const Valeur& bound_z_un, const Valeur& bound_x_deux,
834  const Valeur& bound_y_deux, const Valeur& bound_z_deux,
835  Vector& sol_un, Vector& sol_deux, int num_front, double precision) ;
836 
837 // Elliptic solvers :
838 Mtbl_cf elliptic_solver (const Param_elliptic&, const Mtbl_cf&) ;
839 
840 Mtbl_cf elliptic_solver_boundary (const Param_elliptic& ope_var, const Mtbl_cf& source, const Mtbl_cf& bound, double fact_dir, double fact_neu ) ;
841 
842 Mtbl_cf elliptic_solver_no_zec (const Param_elliptic&, const Mtbl_cf&,
843  double val) ;
844 Mtbl_cf elliptic_solver_only_zec (const Param_elliptic&, const Mtbl_cf&,
845  double val) ;
846 Mtbl_cf elliptic_solver_sin_zec (const Param_elliptic&, const Mtbl_cf&, double*, double*) ;
847 Mtbl_cf elliptic_solver_fixe_der_zero (double,
848  const Param_elliptic&,
849  const Mtbl_cf&) ;
850 
851 // Integrale 2D pour les etoiles en rotation
852 double integrale2d(const Scalar&) ;
853 
854 // Solution de la composante r de Poisson vectoriel, pour l=0 uniquement
855 Scalar pois_vect_r0(const Scalar& ) ;
856 
857 // Regularisation du shift :
858 double regle (Tenseur& shift_auto, const Tenseur& shift_comp, double omega, double) ;
859 
860 // Trucs pour la solution de Misner-Lindquist
861 double serie_lindquist_plus (double rayon, double distance, double xa, double ya,
862  double za, double precision, double itemax) ;
863 
864 double serie_lindquist_moins (double rayon, double distance, double xa, double ya,
865  double za, double precision, double itemax) ;
866 
867 double adm_serie (double rayon, double distance, double precision) ;
868 
869 double bare_serie (double rayon, double distance, double precision) ;
870 
871 void set_lindquist (Cmp& psi_un, Cmp& psi_deux, double rayon, double precision) ;
872 
873 void separation (const Cmp& c1, const Cmp& c2, Cmp& res1, Cmp& res2, int decrois,
874  int puiss, int lmax, double precision, const double relax = 0.5, const int itemax = 100, const int flag = 1) ;
875 
876 // Spectral cutoff used in tensor elliptic solvers, and solving for stationary black hole spacetimes
877 
878 void coupe_l_tous( Sym_tensor& hij,Sym_tensor& aa, Scalar& nn,Scalar& ppsi, Vector& bb, int ntt, int cutoff);
879 void tensor_coupe_l( Sym_tensor& ten, int ntt, int cutoff);
880 
881 
882 }
883 #endif
Lorene prototypes.
Definition: app_hor.h:67