31 #include "star_rot_diff.h" 32 #include "utilitaires.h" 36 double strot_diff_fzero(
double omeg,
const Param& par) ;
37 double strot_diff_fzero_omegae(
double omeg,
const Param& par) ;
44 double precis,
int nitermax) {
84 for (l=0; l<
nzet+1; l++) {
86 for (k=0; k<mg.
get_np(l); k++) {
87 for (j=0; j<mg.
get_nt(l); j++) {
88 for (i=0; i<mg.
get_nr(l); i++) {
90 double& omeg = tom.
set(k, j, i) ;
92 double omeg_min1, omeg_max1 ;
93 if ( prev_zero || omeg ==
double(0)) {
94 omeg_min1 = omeg_min ;
95 omeg_max1 = omeg_max ;
98 omeg_min1 = 0.8 * omeg ;
99 omeg_max1 = 1.2 * omeg ;
105 omeg =
zerosec(strot_diff_fzero, par, omeg_min1,
106 omeg_max1, precis, nitermax, niter) ;
118 for (l=
nzet+1; l<nz; l++) {
128 for (l=1; l<
nzet; l++) {
146 double strot_diff_fzero(
double omeg,
const Param& par) {
187 brst2 = brst2*brst2 ;
196 for (
int l=0; l<
nzet+1; l++) {
198 for (
int k=0; k<mg.
get_np(l); k++) {
199 for (
int j=0; j<mg.
get_nt(l); j++) {
200 for (
int i=0; i<mg.
get_nr(l); i++) {
202 double F = brst2.val_grid_point(l, k, j, i) * omnp /
204 brst2.val_grid_point(l, k, j, i) * omnp * omnp ) ;
216 for (
int l=
nzet+1; l<nz; l++) {
void annule_domain(int l)
Sets the Tensor to zero in a given domain.
Class for differentially rotating stars in quasi-isotropic gauge and maximal slicing.
void add_int(const int &n, int position=0)
Adds the address of a new int to the list.
Map & mp
Mapping associated with the star.
int get_np(int l) const
Returns the number of points in the azimuthal direction ( ) in domain no. l.
Tbl par_frot
Parameters of the function .
const Tbl & domain(int l) const
Read-only of the value in a given domain.
Scalar bbb
Metric factor B.
const Mg3d * get_mg() const
Gives the Mg3d on which the mapping is defined.
double & set(int i)
Read/write of a particular element (index i) (1D case)
Tensor field of valence 0 (or component of a tensorial field).
const Star & get_star(int position=0) const
Returns the reference of a Star stored in the list.
void fait_prim_field()
Computes the member prim_field from omega_field .
virtual void std_spectral_base()
Sets the spectral bases of the Valeur va to the standard ones for a scalar field. ...
double omega_funct(double F) const
Evaluates , where F is linked to the components of the fluid 4-velocity by .
virtual void allocate_all()
Sets the logical state to ETATQCQ (ordinary state) and performs the memory allocation of all the elem...
int get_etat() const
Returns the logical state ETATNONDEF (undefined), ETATZERO (null) or ETATQCQ (ordinary).
Tbl min(const Cmp &)
Minimum values of a Cmp in each domain.
Tbl & set_domain(int l)
Read/write of the value in a given domain.
double zerosec(double(*f)(double, const Param &), const Param &par, double a, double b, double precis, int nitermax, int &niter, bool abort=true)
Finding the zero a function.
double val_grid_point(int l, int k, int j, int i) const
Returns the value of the field at a specified grid point.
int nzet
Number of domains of *mp occupied by the star.
Scalar nphi
Metric coefficient .
void add_star(const Star &eti, int position=0)
Adds the address of a new Star to the list.
const Scalar & get_scalar(int position=0) const
Returns the reference of a Scalar stored in the list.
const int & get_int(int position=0) const
Returns the reference of a int stored in the list.
int get_nzone() const
Returns the number of domains.
Tbl max(const Cmp &)
Maximum values of a Cmp in each domain.
void mult_rsint()
Multiplication by everywhere; dzpuis is not changed.
double omega_max
Maximum value of .
int get_nr(int l) const
Returns the number of points in the radial direction ( ) in domain no. l.
void add_scalar(const Scalar &ti, int position=0)
Adds the address of a new Scalar to the list.
Scalar nn
Lapse function N .
int get_nt(int l) const
Returns the number of points in the co-latitude direction ( ) in domain no. l.
double omega_min
Minimum value of .
double(* primfrot)(double, const Tbl &)
Primitive of the function , which vanishes at the stellar center.
void fait_omega_field(double omeg_min, double omeg_max, double precis, int nitermax)
Computes (member omega_field ).
Scalar omega_field
Field .