LORENE
|
#include <binaire.h>
Public Member Functions | |
Binaire (Map &mp1, int nzet1, const Eos &eos1, int irrot1, Map &mp2, int nzet2, const Eos &eos2, int irrot2, int relat) | |
Standard constructor. | |
Binaire (const Binaire &) | |
Binaire (Map &mp1, const Eos &eos1, Map &mp2, const Eos &eos2, FILE *fich) | |
Copy constructor. | |
void | operator= (const Binaire &) |
Assignment to another {\tt Binaire}. | |
Etoile_bin & | set (int i) |
Read/write of the star no. i. | |
double & | set_omega () |
Sets the orbital angular velocity [{\tt f_unit}]. | |
double & | set_x_axe () |
Sets the absolute coordinate X of the rotation axis [{\tt r_unit}]. | |
const Etoile_bin & | operator() (int i) const |
Returns a reference to the star no. i. | |
double | get_omega () const |
Returns the orbital angular velocity [{\tt f_unit}]. | |
double | get_x_axe () const |
Returns the absolute coordinate X of the rotation axis [{\tt r_unit}]. | |
double | separation () const |
Returns the coordinate separation of the two stellar centers [{\tt r_unit}]. | |
void | sauve (FILE *) const |
void | display_poly (ostream &) const |
Display in polytropic units. | |
void | write_global (ostream &) const |
Write global quantities in a formatted file. | |
double | mass_adm () const |
Total ADM mass. | |
double | mass_kom () const |
Total Komar mass. | |
const Tbl & | angu_mom () const |
Total angular momentum. | |
double | total_ener () const |
Total energy (excluding the rest mass energy). | |
double | virial () const |
Estimates the relative error on the virial theorem (for a relativistic one, it returns $|1 - M_{\rm Komar} / M_{\rm ADM}|$) | |
double | virial_gb () const |
Estimates the relative error on the virial theorem calculated by E.Gourgoulhon and S.Bonazzola (Class. | |
double | virial_fus () const |
Estimates the relative error on the virial theorem calculated by J.L.Friedman, K.Uryu, and M.Shibata (PRD accepted, gr-qc/0108070) | |
double | ham_constr () const |
Estimates the relative error on the Hamiltonian constraint equation by comparing $\underline\Delta\ln A$ with \begin{equation} -4\pi A^2 E - {A^2\over 4} K_{ij} K^{ij} - {1\over 2} {\overline\nabla}_i \ln A {\overline\nabla}^i \ln A \end{equation}. | |
const Tbl & | mom_constr () const |
Estimates the relative error on the momentum constraint equation by comparing ${\overline\nabla}_j K^{ij}$ with \begin{equation} 8\pi J^i - 5 K^{ij} {\overline\nabla}_j \ln A \end{equation}. | |
void | orbit (double fact_omeg_min, double fact_omeg_max, double &xgg1, double &xgg2) |
Computes the orbital angular velocity {\tt omega} and the position of the rotation axis {\tt x_axe}. | |
void | orbit_eqmass (double fact_omeg_min, double fact_omeg_max, double mass1, double mass2, double &xgg1, double &xgg2) |
Computes the orbital angular velocity {\tt omega} and the position of the rotation axis {\tt x_axe}. | |
void | analytical_omega () |
Sets the orbital angular velocity to some 2-PN analytical value (Keplerian value in the Newtonian case) | |
void | analytical_shift () |
Sets some analytical template for the shift vector (via the members {\tt w_shift} and {\tt khi_shift} of the two {\tt Etoile_bin}. | |
Private Member Functions | |
void | del_deriv () const |
Destructor. | |
void | set_der_0x0 () const |
Sets to {\tt 0x0} all the pointers on derived quantities. | |
ostream & | operator>> (ostream &) const |
Operator >> (function called by the operator <<). | |
Private Attributes | |
const Base_vect_cart | ref_triad |
Cartesian triad of the absolute reference frame. | |
Etoile_bin | star1 |
First star of the system. | |
Etoile_bin | star2 |
Second star of the system. | |
Etoile_bin * | et [2] |
Array of the two stars (to perform loops on the stars): {\tt et[0]} contains the address of {\tt star1} and {\tt et[1]} that of {\tt star2}. | |
double | omega |
Angular velocity with respect to an asymptotically inertial observer. | |
double | x_axe |
Absolute X coordinate of the rotation axis. | |
double * | p_mass_adm |
Total ADM mass of the system. | |
double * | p_mass_kom |
Total Komar mass of the system. | |
Tbl * | p_angu_mom |
Total angular momentum of the system. | |
double * | p_total_ener |
Total energy of the system. | |
double * | p_virial |
Virial theorem error. | |
double * | p_virial_gb |
Virial theorem error by E.Gourgoulhon and S.Bonazzola. | |
double * | p_virial_fus |
Virial theorem error by J.L.Friedman, K.Uryu, and M.Shibata. | |
double * | p_ham_constr |
Relative error on the Hamiltonian constraint. | |
Tbl * | p_mom_constr |
Relative error on the momentum constraint. | |
Friends | |
ostream & | operator<< (ostream &, const Binaire &) |
Save in a file. | |
Lorene::Binaire::Binaire | ( | Map & | mp1, |
int | nzet1, | ||
const Eos & | eos1, | ||
int | irrot1, | ||
Map & | mp2, | ||
int | nzet2, | ||
const Eos & | eos2, | ||
int | irrot2, | ||
int | relat | ||
) |
Standard constructor.
mp1 | Mapping on which {\tt star1} will be defined |
nzet1 | Number of domains occupied by {\tt star1} |
eos1 | Equation of state of {\tt star1} |
irrot1 | should be {\tt true} if {\tt star1} is irrotational, {\tt false} if {\tt star1} is corotating |
mp2 | Mapping on which {\tt star2} will be defined |
nzet2 | Number of domains occupied by {\tt star2} |
eos2 | Equation of state of {\tt star2} |
irrot2 | should be {\tt true} if {\tt star2} is irrotational, {\tt false} if {\tt star2} is corotating |
relat | should be {\tt true} for a relativistic configuration, {\tt false} for a Newtonian one |
Definition at line 109 of file binaire.C.
References et, omega, set_der_0x0(), star1, star2, and x_axe.
Copy constructor.
Constructor from a file (see {\tt sauve(FILE* )}).
mp1 | Mapping on which {\tt star1} will be defined |
eos1 | Equation of state of {\tt star1} |
mp2 | Mapping on which {\tt star2} will be defined |
eos2 | Equation of state of {\tt star2} |
fich | input file (must have been created by the function {\tt sauve}) |
Definition at line 145 of file binaire.C.
References et, Lorene::fread_be(), omega, set_der_0x0(), star1, star2, and x_axe.
void Lorene::Binaire::analytical_omega | ( | ) |
Sets the orbital angular velocity to some 2-PN analytical value (Keplerian value in the Newtonian case)
Definition at line 63 of file binaire_omega_ana.C.
References del_deriv(), Lorene::Etoile_bin::is_irrotational(), Lorene::Etoile::is_relativistic(), Lorene::Etoile_bin::mass_g(), omega, Lorene::pow(), Lorene::Etoile::ray_eq(), separation(), Lorene::sqrt(), star1, and star2.
void Lorene::Binaire::analytical_shift | ( | ) |
Sets some analytical template for the shift vector (via the members {\tt w_shift} and {\tt khi_shift} of the two {\tt Etoile_bin}.
Definition at line 69 of file binaire_ana_shift.C.
References Lorene::Cmp::annule(), et, Lorene::Map::get_mg(), Lorene::Etoile::get_mp(), Lorene::Etoile::get_nzet(), Lorene::Mg3d::get_nzone(), Lorene::Etoile::is_relativistic(), Lorene::Etoile_bin::mass_g(), omega, Lorene::Map::r, Lorene::Etoile::ray_eq(), separation(), Lorene::Tenseur::set(), Lorene::Tenseur::set_etat_qcq(), Lorene::Etoile_bin::set_khi_shift(), Lorene::Tenseur::set_std_base(), Lorene::Etoile_bin::set_w_shift(), Lorene::Map::sinp, Lorene::Map::sint, star1, star2, and Lorene::Map::y.
Total angular momentum.
Definition at line 198 of file binaire_global.C.
References Lorene::Tbl::annule_hard(), et, Lorene::Etoile::get_a_car(), Lorene::Etoile::get_ener_euler(), Lorene::Etoile::get_mp(), Lorene::Etoile::get_nbar(), Lorene::Etoile::get_press(), Lorene::Etoile::get_u_euler(), Lorene::Cmp::integrale(), p_angu_mom, Lorene::pow(), Lorene::Tbl::set(), Lorene::Cmp::std_base_scal(), Lorene::Cmp::va, Lorene::Map::xa, Lorene::Map::ya, and Lorene::Map::za.
|
private |
Destructor.
Deletes all the derived quantities
Definition at line 177 of file binaire.C.
References p_angu_mom, p_ham_constr, p_mass_adm, p_mass_kom, p_mom_constr, p_total_ener, p_virial, p_virial_fus, p_virial_gb, and set_der_0x0().
Display in polytropic units.
Definition at line 284 of file binaire.C.
References angu_mom(), Lorene::Etoile::get_eos(), Lorene::Eos_poly::get_gam(), Lorene::Eos_poly::get_kap(), mass_adm(), Lorene::Etoile_bin::mass_b(), mass_kom(), omega, Lorene::pow(), Lorene::Etoile::ray_eq(), Lorene::Etoile::ray_eq_pi(), separation(), Lorene::sqrt(), star1, star2, total_ener(), and Lorene::Etoile_bin::xa_barycenter().
|
inline |
|
inline |
double Lorene::Binaire::ham_constr | ( | ) | const |
Estimates the relative error on the Hamiltonian constraint equation by comparing $\underline\Delta\ln A$ with \begin{equation} -4\pi A^2 E - {A^2\over 4} K_{ij} K^{ij} - {1\over 2} {\overline\nabla}_i \ln A {\overline\nabla}^i \ln A \end{equation}.
Definition at line 69 of file binaire_constr.C.
References Lorene::abs(), Lorene::diffrel(), et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_akcar_auto(), Lorene::Etoile_bin::get_akcar_comp(), Lorene::Etoile::get_beta_auto(), Lorene::Etoile_bin::get_d_beta_auto(), Lorene::Etoile_bin::get_d_beta_comp(), Lorene::Etoile_bin::get_d_logn_auto(), Lorene::Etoile_bin::get_d_logn_comp(), Lorene::Etoile::get_ener_euler(), Lorene::Etoile::get_logn_auto(), Lorene::Etoile::get_mp(), Lorene::max(), p_ham_constr, star1, and star2.
double Lorene::Binaire::mass_adm | ( | ) | const |
Total ADM mass.
Definition at line 88 of file binaire_global.C.
References et, Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_akcar_auto(), Lorene::Etoile_bin::get_akcar_comp(), Lorene::Etoile::get_ener_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), Lorene::Etoile_bin::mass_b(), p_mass_adm, Lorene::pow(), star1, star2, and Lorene::Cmp::std_base_scal().
double Lorene::Binaire::mass_kom | ( | ) | const |
Total Komar mass.
Definition at line 136 of file binaire_global.C.
References et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_akcar_auto(), Lorene::Etoile_bin::get_akcar_comp(), Lorene::Etoile_bin::get_d_beta_auto(), Lorene::Etoile_bin::get_d_beta_comp(), Lorene::Etoile_bin::get_d_logn_auto(), Lorene::Etoile_bin::get_d_logn_comp(), Lorene::Etoile::get_ener_euler(), Lorene::Etoile::get_nnn(), Lorene::Etoile::get_s_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), Lorene::Etoile_bin::mass_b(), p_mass_kom, star1, star2, and Lorene::Cmp::std_base_scal().
Estimates the relative error on the momentum constraint equation by comparing ${\overline\nabla}_j K^{ij}$ with \begin{equation} 8\pi J^i - 5 K^{ij} {\overline\nabla}_j \ln A \end{equation}.
Definition at line 158 of file binaire_constr.C.
References Lorene::abs(), Lorene::Tenseur::change_triad(), Lorene::contract(), Lorene::Tenseur::dec2_dzpuis(), Lorene::diffrel(), et, Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_d_beta_auto(), Lorene::Etoile_bin::get_d_beta_comp(), Lorene::Etoile_bin::get_d_logn_auto(), Lorene::Etoile_bin::get_d_logn_comp(), Lorene::Etoile::get_ener_euler(), Lorene::Etoile::get_mp(), Lorene::Etoile::get_press(), Lorene::Etoile_bin::get_tkij_auto(), Lorene::Etoile::get_u_euler(), Lorene::Tenseur::gradient(), Lorene::max(), Lorene::norme(), p_mom_constr, ref_triad, Lorene::Tbl::set(), Lorene::Tbl::set_etat_qcq(), star1, and star2.
|
inline |
void Lorene::Binaire::orbit | ( | double | fact_omeg_min, |
double | fact_omeg_max, | ||
double & | xgg1, | ||
double & | xgg2 | ||
) |
Computes the orbital angular velocity {\tt omega} and the position of the rotation axis {\tt x_axe}.
fact_omeg_min | [input] : determines the lower bound of the interval {\tt [omega_min, omega_max]} in which {\tt omega} is searched by {\tt omega_min = fact_omeg_min * omega}, where {\tt omega} is the previous value of the angular velocity (typical value : {\tt fact_omeg_min = 0.5}) |
fact_omeg_max | [input] : determines the higher bound of the interval {\tt [omega_min, omega_max]} in which {\tt omega} is searched by {\tt omega_max = fact_omeg_max * omega}, where {\tt omega} is the previous value of the angular velocity. (typical value : {\tt fact_omeg_max = 1.5}) |
xgg1 | [output] : x coordinate (relative to star 1 mapping) of the `‘center of mass’' of star 1 |
xgg2 | [output] : x coordinate (relative to star 2 mapping) of the `‘center of mass’' of star 2 |
Definition at line 122 of file binaire_orbite.C.
References Lorene::Param::add_double(), Lorene::Param::add_int(), Lorene::Tenseur::change_triad(), Lorene::Cmp::dsdx(), et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Map::get_bvect_cart(), Lorene::Etoile::get_d_logn_auto_div(), Lorene::Etoile_bin::get_loggam(), Lorene::Etoile::get_logn_auto_regu(), Lorene::Etoile_bin::get_logn_comp(), Lorene::Etoile::get_mp(), Lorene::Etoile::get_nnn(), Lorene::Map::get_rot_phi(), Lorene::Etoile::get_shift(), Lorene::Tbl::get_taille(), Lorene::Tenseur::get_triad(), Lorene::Etoile::is_relativistic(), omega, ref_triad, save_profile(), x_axe, Lorene::Etoile_bin::xa_barycenter(), Lorene::zero_list(), Lorene::zerosec(), and Lorene::zerosec_b().
void Lorene::Binaire::orbit_eqmass | ( | double | fact_omeg_min, |
double | fact_omeg_max, | ||
double | mass1, | ||
double | mass2, | ||
double & | xgg1, | ||
double & | xgg2 | ||
) |
Computes the orbital angular velocity {\tt omega} and the position of the rotation axis {\tt x_axe}.
fact_omeg_min | [input] : determines the lower bound of the interval {\tt [omega_min, omega_max]} in which {\tt omega} is searched by {\tt omega_min = fact_omeg_min * omega}, where {\tt omega} is the previous value of the angular velocity (typical value : {\tt fact_omeg_min = 0.5}) |
fact_omeg_max | [input] : determines the higher bound of the interval {\tt [omega_min, omega_max]} in which {\tt omega} is searched by {\tt omega_max = fact_omeg_max * omega}, where {\tt omega} is the previous value of the angular velocity. (typical value : {\tt fact_omeg_max = 1.5}) |
mass1 | [input] : baryon rest mass of NS1 |
mass2 | [input] : baryon rest mass of NS2 |
xgg1 | [output] : x coordinate (relative to star 1 mapping) of the `‘center of mass’' of star 1 |
xgg2 | [output] : x coordinate (relative to star 2 mapping) of the `‘center of mass’' of star 2 |
Definition at line 464 of file binaire_orbite.C.
References Lorene::Param::add_double(), Lorene::Param::add_int(), Lorene::Tenseur::change_triad(), Lorene::Cmp::dsdx(), et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Map::get_bvect_cart(), Lorene::Etoile::get_d_logn_auto_div(), Lorene::Etoile_bin::get_loggam(), Lorene::Etoile::get_logn_auto_regu(), Lorene::Etoile_bin::get_logn_comp(), Lorene::Etoile::get_mp(), Lorene::Etoile::get_nnn(), Lorene::Map::get_rot_phi(), Lorene::Etoile::get_shift(), Lorene::Tbl::get_taille(), Lorene::Tenseur::get_triad(), Lorene::Etoile::is_relativistic(), omega, ref_triad, x_axe, Lorene::Etoile_bin::xa_barycenter(), Lorene::zero_list(), Lorene::zerosec(), and Lorene::zerosec_b().
double Lorene::Binaire::separation | ( | ) | const |
Returns the coordinate separation of the two stellar centers [{\tt r_unit}].
Definition at line 457 of file binaire.C.
References Lorene::Etoile::get_mp(), Lorene::Map::get_ori_x(), Lorene::Map::get_ori_y(), Lorene::Map::get_ori_z(), Lorene::sqrt(), star1, and star2.
|
inline |
Read/write of the star no. i.
Definition at line 223 of file binaire.h.
References del_deriv(), and et.
|
private |
Sets to {\tt 0x0} all the pointers on derived quantities.
Definition at line 195 of file binaire.C.
References p_angu_mom, p_ham_constr, p_mass_adm, p_mass_kom, p_mom_constr, p_total_ener, p_virial, p_virial_fus, and p_virial_gb.
|
inline |
|
inline |
double Lorene::Binaire::total_ener | ( | ) | const |
Total energy (excluding the rest mass energy).
In the Newtonian case, it is defined as the sum of kinetic, internal, and gravitational potential energies.
In the relativistic case, it is defined as $M_{\rm ADM} - M_{\rm bar,1} - M_{\rm bar,2}$.
Definition at line 289 of file binaire_global.C.
References et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_ener(), Lorene::Etoile::get_logn_auto(), Lorene::Etoile_bin::get_logn_comp(), Lorene::Etoile::get_nbar(), Lorene::Etoile::get_u_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), mass_adm(), Lorene::Etoile_bin::mass_b(), p_total_ener, star1, and star2.
double Lorene::Binaire::virial | ( | ) | const |
Estimates the relative error on the virial theorem (for a relativistic one, it returns $|1 - M_{\rm Komar} / M_{\rm ADM}|$)
Definition at line 345 of file binaire_global.C.
References et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_logn_auto(), Lorene::Etoile_bin::get_logn_comp(), Lorene::Etoile::get_nbar(), Lorene::Etoile::get_press(), Lorene::Etoile::get_u_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), mass_adm(), mass_kom(), p_virial, star1, and star2.
double Lorene::Binaire::virial_fus | ( | ) | const |
Estimates the relative error on the virial theorem calculated by J.L.Friedman, K.Uryu, and M.Shibata (PRD accepted, gr-qc/0108070)
The expression used in the LORENE is Eq.(5.7) in the paper by M.Shibata and K.Uryu (PRD64, 104017 (2001))
Definition at line 481 of file binaire_global.C.
References et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_akcar_auto(), Lorene::Etoile_bin::get_akcar_comp(), Lorene::Etoile_bin::get_d_beta_auto(), Lorene::Etoile_bin::get_d_beta_comp(), Lorene::Etoile_bin::get_d_logn_auto(), Lorene::Etoile_bin::get_d_logn_comp(), Lorene::Etoile::get_nnn(), Lorene::Etoile::get_s_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), mass_adm(), p_virial_fus, Lorene::sqrt(), star1, star2, Lorene::Cmp::std_base_scal(), and virial().
double Lorene::Binaire::virial_gb | ( | ) | const |
Estimates the relative error on the virial theorem calculated by E.Gourgoulhon and S.Bonazzola (Class.
Quantum Grav. 11, 443 (1994): Eq.(29)) normalized by $2 \pi G$.
Definition at line 408 of file binaire_global.C.
References et, Lorene::flat_scalar_prod(), Lorene::Etoile::get_a_car(), Lorene::Etoile_bin::get_akcar_auto(), Lorene::Etoile_bin::get_akcar_comp(), Lorene::Etoile_bin::get_d_beta_auto(), Lorene::Etoile_bin::get_d_beta_comp(), Lorene::Etoile_bin::get_d_logn_auto(), Lorene::Etoile_bin::get_d_logn_comp(), Lorene::Etoile::get_s_euler(), Lorene::Cmp::integrale(), Lorene::Etoile::is_relativistic(), mass_adm(), p_virial_gb, Lorene::sqrt(), star1, star2, Lorene::Cmp::std_base_scal(), and virial().
Write global quantities in a formatted file.
This file can be read by an external program.
Definition at line 334 of file binaire.C.
References angu_mom(), Lorene::Etoile::get_ener(), Lorene::Etoile::get_ent(), Lorene::Etoile::get_eos(), Lorene::Eos_poly::get_gam(), Lorene::Eos_poly::get_kap(), Lorene::Map::get_mg(), Lorene::Etoile::get_mp(), Lorene::Mg3d::get_np(), Lorene::Mg3d::get_nr(), Lorene::Mg3d::get_nt(), Lorene::Mg3d::get_nzone(), mass_adm(), Lorene::Etoile_bin::mass_b(), omega, Lorene::pow(), Lorene::Etoile::ray_eq(), Lorene::Etoile::ray_eq_pis2(), Lorene::Etoile::ray_pole(), separation(), Lorene::sqrt(), star1, star2, Lorene::Map::val_r(), virial(), virial_fus(), virial_gb(), and Lorene::Etoile_bin::xa_barycenter().
|
private |
|
private |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
mutableprivate |
|
private |
|
private |
|
private |
|
private |