/usr/include/lorene/C++/Include/type_parite.h is in liblorene-dev 0.0.0~cvs20161116+dfsg-1ubuntu4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 | /*
* Lorene's macros
*
*/
/*
* Copyright (c) 1999-2000 Jean-Alain Marck
* Copyright (c) 1999-2001 Eric Gourgoulhon
* Copyright (c) 2000-2003 Jerome Novak
*
* This file is part of LORENE.
*
* LORENE is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* LORENE is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with LORENE; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*/
#ifndef __TYPE_PARITE_H_
#define __TYPE_PARITE_H_
/*
* Constantes utilisees dans les types de grilles et les parites
*/
/*
* $Id: type_parite.h,v 1.14 2013/06/05 15:00:26 j_novak Exp $
* $Log: type_parite.h,v $
* Revision 1.14 2013/06/05 15:00:26 j_novak
* Suppression of all classes derived from Grille3d. Now Grille3d is no
* longer an abstract class. r-samplings are only one of RARE, FIN or
* UNSURR (FINJAC has been removed). Instead, Mg3d possesses a new member
* colloc_r[nzone] defining the type of collocation points (spectral
* bases) in each domain.
*
* Revision 1.13 2013/01/11 08:20:10 j_novak
* New radial spectral bases with Legendre polynomials (R_LEG, R_LEGP, R_LEGI).
*
* Revision 1.12 2012/01/17 15:06:54 j_penner
* Added a definition for MAX_BASE_2 for the phi coordinate and possible higher dimensions
*
* Revision 1.11 2012/01/17 10:12:54 j_penner
* modified phi mask MSQ_P to index using only one hex value
*
* Revision 1.10 2009/10/23 12:55:46 j_novak
* New base T_LEG_MI
*
* Revision 1.9 2009/10/08 16:19:32 j_novak
* Addition of new bases T_COS and T_SIN.
*
* Revision 1.8 2008/10/17 10:48:28 j_novak
* Increase of the macro MAX_DAL
*
* Revision 1.7 2007/12/11 15:28:05 jl_cornou
* Jacobi(0,2) polynomials partially implemented
*
* Revision 1.6 2004/11/04 15:40:14 e_gourgoulhon
* Added definition of symbol T_LEG.
*
* Revision 1.5 2004/08/24 09:14:40 p_grandclement
* Addition of some new operators, like Poisson in 2d... It now requieres the
* GSL library to work.
*
* Also, the way a variable change is stored by a Param_elliptic is changed and
* no longer uses Change_var but rather 2 Scalars. The codes using that feature
* will requiere some modification. (It should concern only the ones about monopoles)
*
* Revision 1.4 2004/03/22 13:12:43 j_novak
* Modification of comments to use doxygen instead of doc++
*
* Revision 1.3 2003/09/16 08:53:05 j_novak
* Addition of the T_LEG_II base (odd in theta, only for odd m) and the
* transformation functions from and to T_SIN_P.
*
* Revision 1.2 2002/03/07 15:41:12 n_chamel
* New class for dealing with Cartesian grids
* Added the sampling type UNIFORM in type_parite.h
*
* Revision 1.1.1.1 2001/11/20 15:19:27 e_gourgoulhon
* LORENE
*
* Revision 2.3 2000/12/04 13:09:55 novak
* Added constants for the dalembertian
*
* Revision 2.2 2000/09/28 08:55:52 eric
* Ajout de T_LEG_IP et T_LEG_PI.
*
* Revision 2.1 1999/10/01 15:22:13 eric
* Vire les jacobiennes.
*
* Revision 2.0 1999/02/15 10:41:51 hyc
* *** empty log message ***
*
* $Header: /cvsroot/Lorene/C++/Include/type_parite.h,v 1.14 2013/06/05 15:00:26 j_novak Exp $
*
*/
/**
* \defgroup def_mac LORENE's macros.
*
* @{
*/
/* Etat des tbl et autres */
/* ---------------------- */
#define ETATZERO 0
#define ETATUN 1
#define ETATQCQ 2
#define ETATNONDEF 3
/* Uniform sampling on a Cartesian grid */
#define UNIFORM 3
/* Echantillonage fin en r */
/* ----------------------- */
#define RARE 1
#define FIN 0
#define UNSURR 2
/* Symetries en theta */
/* ------------------ */
#define SYM 1
#define NONSYM 0
/* Types de bases en r */
/* ------------------- */
#define BASE_CHEB 0
#define BASE_LEG 1
#define BASE_JAC02 2
/* Les bases de developement */
/* ------------------------- */
/// Nombre max. de bases differentes
#define MAX_BASE 32
/// Smaller maximum bases used for phi (and higher dimensions for now)
#define MAX_BASE_2 16
/* Divers (masques, nulls,...) */
/// base inconnue
#define NONDEF 0x00000000
/// Extraction de l'info sur R
#define MSQ_R 0x000000ff
/// Extraction de l'info sur Theta
#define MSQ_T 0x0000ff00
/// Extraction de l'info sur Phi
#define MSQ_P 0x000f0000//0x00ff0000 <- was this
/// Translation en R, used for a bitwise shift (in hex)
#define TRA_R 0
/// Translation en Theta, used for a bitwise shift (in hex)
#define TRA_T 8
/// Translation en Phi, used for a bitwise shift (in hex)
#define TRA_P 16
/* R */
/// base de Chebychev ordinaire (fin)
#define R_CHEB 0x00000001
/// base de Cheb. paire (rare) seulement
#define R_CHEBP 0x00000002
/// base de Cheb. impaire (rare) seulement
#define R_CHEBI 0x00000003
/// Cheb. pair-impair suivant l pair pour l=0
#define R_CHEBPI_P 0x00000004
/// Cheb. pair-impair suivant l impair pour l=0
#define R_CHEBPI_I 0x00000005
/// Cheb. pair-impair suivant m, pair pour m=0
#define R_CHEBPIM_P 0x00000006
/// Cheb. pair-impair suivant m, impair pour m=0
#define R_CHEBPIM_I 0x00000007
/// base de Chebychev ordinaire (fin), dev. en 1/r
#define R_CHEBU 0x00000008
/// base de Legendre ordinaire (fin)
#define R_LEG 0x00000009
/// base de Legendre paire (rare) seulement
#define R_LEGP 0x0000000a
/// base de Legendre impaire (rare) seulement
#define R_LEGI 0x0000000b
/// base de Jacobi(0,2) ordinaire (finjac)
#define R_JACO02 0x0000000c
/* Theta */
/// dev. cos-sin alternes, cos pour m=0
#define T_COSSIN_C 0x00000100
/// dev. cos-sin alternes, sin pour m=0
#define T_COSSIN_S 0x00000200
/// dev. cos seulement
#define T_COS 0x00000300
/// dev. sin seulement
#define T_SIN 0x00000400
/// dev. cos seulement, harmoniques paires
#define T_COS_P 0x00000500
/// dev. sin seulement, harmoniques paires
#define T_SIN_P 0x00000600
/// dev. cos seulement, harmoniques impaires
#define T_COS_I 0x00000700
/// dev. sin seulement, harmoniques impaires
#define T_SIN_I 0x00000800
/// cos pair-sin impair alternes, cos pour m=0
#define T_COSSIN_CP 0x00000900
/// sin pair-cos impair alternes, sin pour m=0
#define T_COSSIN_SP 0x00000a00
/// cos impair-sin pair alternes, cos pour m=0
#define T_COSSIN_CI 0x00000b00
/// sin impair-cos pair alternes, sin pour m=0
#define T_COSSIN_SI 0x00000c00
/// fct. de Legendre associees paires
#define T_LEG_P 0x00000d00
/// fct. de Legendre associees paires avec m pair
#define T_LEG_PP 0x00000e00
/// fct. de Legendre associees impaires
#define T_LEG_I 0x00000f00
/// fct. de Legendre associees impaires avec m pair
#define T_LEG_IP 0x00001000
/// fct. de Legendre associees paires avec m impair
#define T_LEG_PI 0x00001100
/// fct. de Legendre associees impaires avec m impair
#define T_LEG_II 0x00001200
/// CL of even cosines
#define T_CL_COS_P 0x00001300
/// CL of even sines
#define T_CL_SIN_P 0x00001400
/// CL of odd cosines
#define T_CL_COS_I 0x00001500
/// CL of odd sines.
#define T_CL_SIN_I 0x00001600
/// fct. de Legendre associees
#define T_LEG 0x00001700
/// fct. de Legendre associees avec m pair
#define T_LEG_MP 0x00001800
/// fct. de Legendre associees avec m impair
#define T_LEG_MI 0x00001900
/* Phi */
/// dev. standart
#define P_COSSIN 0x00010000
/// dev. sur Phi = 2*phi, freq. paires
#define P_COSSIN_P 0x00020000
/// dev. sur Phi = 2*phi, freq. impaires
#define P_COSSIN_I 0x00030000
/// dev. cos seulement
#define P_COS 0x00040000
/// dev. sin seulement
#define P_SIN 0x00050000
/************/
/* Type EOS */
/************/
/// eos polytropique
#define POLYTROPE 0x000000001
/// eos incompressible
#define INCOMP 0x000000002
/// eos polytropique (cas newtonien)
#define POLYTROPE_NEWT 0x000000003
/// eos incompressible (cas newtonien)
#define INCOMP_NEWT 0x000000004
/*******************************/
/* Type operateur dalembertien */
/* (uniquement pour le noyau */
/* pour l'instant) */
/*******************************/
/// Nombre max d'operateurs (pour l'instant)
#define MAX_DAL 32
/// Operateur du premier ordre, \f$\delta < \delta_{crit}\f$
#define ORDRE1_SMALL 0x000000001
/// Operateur du premier ordre \f$\delta > \delta_{crit}\f$
#define ORDRE1_LARGE 0x000000002
/// Operateur du deuxieme ordre degenere \f$\delta < \delta_{crit}\f$
#define O2DEGE_SMALL 0x000000003
/// Operateur du deuxieme ordre degenere \f$\delta > \delta_{crit}\f$
#define O2DEGE_LARGE 0x000000004
/// Operateur du deuxieme ordre non degenere \f$\delta < \delta_{crit}\f$
#define O2NOND_SMALL 0x000000005
/// Operateur du deuxieme ordre non degenere \f$\delta > \delta_{crit}\f$
#define O2NOND_LARGE 0x000000006
/**@} */
#endif
|