LORENE
star_rot_diff.h
1 /*
2  * Definition of Lorene class Star_rot_diff
3  *
4  */
5 
6 /*
7  * Copyright (c) 2025 Santiago Jaraba
8  *
9  * This file is part of LORENE.
10  *
11  * LORENE is free software; you can redistribute it and/or modify
12  * it under the terms of the GNU General Public License version 2
13  * as published by the Free Software Foundation.
14  *
15  * LORENE is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with LORENE; if not, write to the Free Software
22  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23  *
24  */
25 
26 #ifndef __STAR_ROT_DIFF_H_
27 #define __STAR_ROT_DIFF_H_
28 
29 // Headers Lorene
30 #include "star_rot.h"
31 
32 namespace Lorene {
39  class Star_rot_diff : public Star_rot {
40  // Data :
41  // -----
42  protected:
53  double (*omega_frot)(double, const Tbl&) ;
54 
61  double (*primfrot)(double, const Tbl&) ;
62 
71 
74 
75  double omega_min ;
76  double omega_max ;
77 
80 
81  // Constructors - Destructor
82  // -------------------------
83  public:
99  Star_rot_diff(Map& mp_i, int nzet_i, bool relat, const Eos& eos_i,
100  double (*omega_frot_i)(double, const Tbl&),
101  double (*primfrot_i)(double, const Tbl&),
102  const Tbl& par_frot_i) ;
103 
104  Star_rot_diff(const Star_rot_diff& ) ;
105 
116  Star_rot_diff(Map& mp_i, const Eos& eos_i, FILE* fich,
117  double (*omega_frot_i)(double, const Tbl&),
118  double (*primfrot_i)(double, const Tbl&) ) ;
119 
120  virtual ~Star_rot_diff() ;
121 
122 
123  // Memory management
124  // -----------------
125 
126  // Everything is inherited from Star_rot
127 
128  // Mutators / assignment
129  // ---------------------
130  public:
132  void operator=(const Star_rot_diff& ) ;
133 
134  // Accessors
135  // ---------
136  public:
138  const Scalar& get_omega_field() const {return omega_field;} ;
139 
143  virtual double get_omega_c() const ;
144 
145  // Outputs
146  // -------
147  public:
148  virtual void sauve(FILE *) const ;
149 
151  virtual void display_poly(ostream& ) const ;
152 
154  friend ostream& operator<<(ostream& , const Star& ) ;
155 
156 
157  protected:
159  virtual ostream& operator>>(ostream& ) const ;
160 
161 
162  // Computational routines
163  // ----------------------
164  public:
165 
166  virtual double tsw() const ;
167 
179  virtual void hydro_euler() ;
180 
199  void fait_omega_field(double omeg_min, double omeg_max,
200  double precis, int nitermax) ;
201 
203  void fait_prim_field() ;
204 
219  double omega_funct(double F) const ;
220 
228  double prim_funct_omega(double F) const ;
229 
311  virtual void equilibrium(double ent_c, double omega0, double fact_omega,
312  int nzadapt, const Tbl& ent_limit,
313  const Itbl& icontrol, const Tbl& control,
314  double mbar_wanted, double aexp_mass,
315  Tbl& diff, Param* = 0x0) ;
316 
317  };
318 
319 }
320 #endif
virtual ~Star_rot_diff()
Destructor.
void operator=(const Star_rot_diff &)
Assignment to another Star_rot_diff.
Class for differentially rotating stars in quasi-isotropic gauge and maximal slicing.
Definition: star_rot_diff.h:39
Scalar prim_field
Field .
Definition: star_rot_diff.h:79
Tbl par_frot
Parameters of the function .
Definition: star_rot_diff.h:70
Lorene prototypes.
Definition: app_hor.h:67
Equation of state base class.
Definition: eos.h:209
Tensor field of valence 0 (or component of a tensorial field).
Definition: scalar.h:399
Base class for coordinate mappings.
Definition: map.h:697
Basic integer array class.
Definition: itbl.h:122
void fait_prim_field()
Computes the member prim_field from omega_field .
double omega_funct(double F) const
Evaluates , where F is linked to the components of the fluid 4-velocity by .
Base class for stars.
Definition: star.h:175
virtual void hydro_euler()
Computes the hydrodynamical quantities relative to the Eulerian observer from those in the fluid fram...
Class for isolated rotating stars.
Definition: star_rot.h:98
const Scalar & get_omega_field() const
Returns the angular velocity field .
virtual void sauve(FILE *) const
Save in a file.
virtual void equilibrium(double ent_c, double omega0, double fact_omega, int nzadapt, const Tbl &ent_limit, const Itbl &icontrol, const Tbl &control, double mbar_wanted, double aexp_mass, Tbl &diff, Param *=0x0)
Computes an equilibrium configuration.
double prim_funct_omega(double F) const
Evaluates the primitive of .
virtual ostream & operator>>(ostream &) const
Operator >> (virtual function called by the operator <<).
virtual double get_omega_c() const
Returns the central value of the rotation angular velocity ([f_unit] )
Parameter storage.
Definition: param.h:125
virtual double tsw() const
Ratio T/W.
double omega_max
Maximum value of .
Definition: star_rot_diff.h:76
Star_rot_diff(Map &mp_i, int nzet_i, bool relat, const Eos &eos_i, double(*omega_frot_i)(double, const Tbl &), double(*primfrot_i)(double, const Tbl &), const Tbl &par_frot_i)
Standard constructor.
Definition: star_rot_diff.C:44
virtual void display_poly(ostream &) const
Display in polytropic units.
double(* omega_frot)(double, const Tbl &)
Function defining the rotation profile.
Definition: star_rot_diff.h:53
friend ostream & operator<<(ostream &, const Star &)
Display.
Definition: star.C:415
Basic array class.
Definition: tbl.h:164
double omega_min
Minimum value of .
Definition: star_rot_diff.h:75
double(* primfrot)(double, const Tbl &)
Primitive of the function , which vanishes at the stellar center.
Definition: star_rot_diff.h:61
void fait_omega_field(double omeg_min, double omeg_max, double precis, int nitermax)
Computes (member omega_field ).
Scalar omega_field
Field .
Definition: star_rot_diff.h:73