KADATH
|
Purely abstract class for metric handling. More...
#include <metric.hpp>
Public Member Functions | |
Metric (const Metric &) | |
Copy constructor. More... | |
virtual | ~Metric () |
Destructor. More... | |
virtual void | update () |
Updates the derived quantities (Christoffels etc..) This is done only for the ones that are needed, i.e. More... | |
virtual void | update (int dd) |
Updates the derived quantities (Christoffels etc..) in a given Domain This is done only for the ones that are needed, i.e. More... | |
virtual void | manipulate_ind (Term_eq &so, int ind) const |
Uses the Metric to manipulate one of the index of a Term_eq (i.e. More... | |
virtual Term_eq | derive_partial (int typeder, char nameder, const Term_eq &so) const |
Computes the partial derivative of a Term_eq (assumes Cartesian basis of decomposition). More... | |
virtual Term_eq | derive (int typeder, char nameder, const Term_eq &so) const |
Computes the covariant derivative of a Term_eq (assumes Cartesian basis of decomposition). More... | |
virtual Term_eq | derive_flat (int typeder, char nameder, const Term_eq &so) const |
Computes the covariant flat derivative of a Term_eq . More... | |
virtual const Metric * | get_background () const |
Returns a pointer on the background metric, if it exists. More... | |
virtual int | give_type (int) const |
Returns the type of tensorial basis of the covariant representation, in a given Domain . More... | |
const Term_eq * | give_term (int typemet, int dd) const |
Gives one representation of the metric, in a Domain . More... | |
const Term_eq * | give_christo (int dd) const |
Gives the Christoffel symbols, in a Domain . More... | |
const Term_eq * | give_riemann (int dd) const |
Gives the Riemann tensor, in a Domain . More... | |
const Term_eq * | give_ricci_tensor (int dd) const |
Gives the Ricci tensor, in a Domain . More... | |
const Term_eq * | give_ricci_scalar (int dd) const |
Gives the Ricci scalar, in a Domain . More... | |
const Term_eq * | give_dirac (int dd) const |
Gives the potential of the Dirac gauge, in a Domain . More... | |
const Term_eq * | give_det_cov (int dd) const |
Gives the determinant of the covariant metric, in a Domain . More... | |
Protected Member Functions | |
Metric (const Space &) | |
Constructor from a Space only (internal use only). More... | |
virtual void | compute_con (int) const |
Computes the contravariant representation, in a given Domain . More... | |
virtual void | compute_cov (int) const |
Computes the covariant representation, in a given Domain . More... | |
virtual void | compute_christo (int) const |
Computes the Christoffel symbols, in a given Domain . More... | |
virtual void | compute_riemann (int) const |
Computes the Riemann tensor, in a given Domain . More... | |
virtual void | compute_ricci_tensor (int) const |
Computes the Ricci tensor, in a given Domain . More... | |
virtual void | compute_ricci_scalar (int) const |
Computes the Ricci scalar, in a given Domain . More... | |
virtual void | compute_dirac (int) const |
Computes the Dirac gauge term, in a given Domain . More... | |
virtual void | compute_det_cov (int) const |
Computes the determinant of the covariant representation, in a given Domain . More... | |
Protected Attributes | |
const Space & | espace |
The associated Space . More... | |
const System_of_eqs * | syst |
Pointer of the system of equations where the metric is used (only one for now). More... | |
MMPtr_array< Term_eq > | p_met_cov |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_met_con |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_christo |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_riemann |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_ricci_tensor |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_ricci_scalar |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_dirac |
Array of pointers on various Term_eq . More... | |
MMPtr_array< Term_eq > | p_det_cov |
Array of pointers on various Term_eq . More... | |
int | type_tensor |
States if one works in the CON or COV representation. More... | |
Purely abstract class for metric handling.
Can not be instanciated directly. One must use the various derived classes.
Definition at line 39 of file metric.hpp.
|
protected |
Constructor from a Space
only (internal use only).
Definition at line 29 of file metric.cpp.
References espace, Kadath::Space::get_nbr_domains(), p_christo, p_det_cov, p_dirac, p_met_con, p_met_cov, p_ricci_scalar, p_ricci_tensor, and p_riemann.
Kadath::Metric::Metric | ( | const Metric & | so | ) |
Copy constructor.
Definition at line 49 of file metric.cpp.
References espace, Kadath::Space::get_nbr_domains(), p_christo, p_det_cov, p_dirac, p_met_con, p_met_cov, p_ricci_scalar, p_ricci_tensor, and p_riemann.
|
virtual |
Destructor.
Definition at line 69 of file metric.cpp.
References espace, Kadath::Space::get_nbr_domains(), p_christo, p_det_cov, p_dirac, p_met_con, p_met_cov, p_ricci_scalar, p_ricci_tensor, and p_riemann.
|
protectedvirtual |
Computes the Christoffel symbols, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_flat_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_conf, Kadath::Metric_general, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 407 of file metric.cpp.
References compute_con(), compute_cov(), espace, Kadath::Space::get_domain(), Kadath::Space::get_ndim(), Kadath::Index::inc(), p_christo, p_met_con, p_met_cov, Kadath::Tensor::set(), Kadath::Array< T >::set(), Kadath::Scalar::set_domain(), and type_tensor.
|
protectedvirtual |
Computes the contravariant representation, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS_const, Kadath::Metric_nophi_AADS, Kadath::Metric_nophi_const, Kadath::Metric_nophi, Kadath::Metric_flat_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor_const, Kadath::Metric_conf_factor, Kadath::Metric_dirac_const, Kadath::Metric_conf, Kadath::Metric_const, Kadath::Metric_general, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 740 of file metric.cpp.
|
protectedvirtual |
Computes the covariant representation, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS_const, Kadath::Metric_nophi_AADS, Kadath::Metric_nophi_const, Kadath::Metric_nophi, Kadath::Metric_flat_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor_const, Kadath::Metric_conf_factor, Kadath::Metric_dirac_const, Kadath::Metric_conf, Kadath::Metric_const, Kadath::Metric_general, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 735 of file metric.cpp.
|
protectedvirtual |
Computes the determinant of the covariant representation, in a given Domain
.
Reimplemented in Kadath::Metric_harmonic.
Definition at line 750 of file metric.cpp.
|
protectedvirtual |
Computes the Dirac gauge term, in a given Domain
.
Reimplemented in Kadath::Metric_conf, and Kadath::Metric_general.
Definition at line 745 of file metric.cpp.
|
protectedvirtual |
Computes the Ricci scalar, in a given Domain
.
Reimplemented in Kadath::Metric_harmonic, Kadath::Metric_dirac, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 590 of file metric.cpp.
References compute_con(), compute_cov(), compute_ricci_tensor(), espace, Kadath::Space::get_domain(), Kadath::Space::get_ndim(), p_met_con, p_met_cov, p_ricci_scalar, p_ricci_tensor, Kadath::Scalar::set_domain(), and type_tensor.
|
protectedvirtual |
Computes the Ricci tensor, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_harmonic, Kadath::Metric_dirac, Kadath::Metric_conf, Kadath::Metric_general, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 532 of file metric.cpp.
References compute_christo(), Kadath::Val_domain::der_abs(), espace, Kadath::Space::get_domain(), Kadath::Space::get_ndim(), Kadath::Index::inc(), p_christo, p_met_con, p_met_cov, p_ricci_tensor, Kadath::Tensor::set(), and Kadath::Scalar::set_domain().
|
protectedvirtual |
Computes the Riemann tensor, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_conf, Kadath::Metric_general, and Kadath::Metric_ADS.
Definition at line 476 of file metric.cpp.
References compute_christo(), Kadath::Val_domain::der_abs(), espace, Kadath::Space::get_domain(), Kadath::Space::get_ndim(), Kadath::Index::inc(), p_christo, p_met_con, p_met_cov, p_riemann, Kadath::Tensor::set(), Kadath::Array< T >::set(), and Kadath::Scalar::set_domain().
Computes the covariant derivative of a Term_eq
(assumes Cartesian basis of decomposition).
The index corresponding to the derivation is given a name. If need be inner summation is performed.
typeder | : the result is either ![]() ![]() |
nameder | : the name given as the derivation index. |
so | : the Term_eq to be derived. |
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_flat_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_conf, Kadath::Metric_general, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 290 of file metric.cpp.
References compute_christo(), Kadath::Term_eq::der_t, derive_partial(), Kadath::Tensor::do_summation_one_dom(), Kadath::Term_eq::get_dom(), Kadath::Tensor::get_index_type(), Kadath::Tensor::get_name_ind(), Kadath::Tensor::get_valence(), manipulate_ind(), p_christo, Kadath::Tensor::set_name_affected(), Kadath::Tensor::set_name_ind(), and Kadath::Term_eq::val_t.
Computes the covariant flat derivative of a Term_eq
.
The index corresponding to the derivation is given a name. If need be inner summation is performed.
typeder | : the result is either ![]() ![]() |
nameder | : the name given as the derivation index. |
so | : the Term_eq to be derived. |
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_conf, and Kadath::Metric_general.
Definition at line 402 of file metric.cpp.
|
virtual |
Computes the partial derivative of a Term_eq
(assumes Cartesian basis of decomposition).
The index corresponding to the derivation is given a name. If need be inner summation is performed.
typeder | : the result is either ![]() ![]() |
nameder | : the name given as the derivation index. |
so | : the Term_eq to be derived. |
Reimplemented in Kadath::Metric_flat_nophi, and Kadath::Metric_flat.
Definition at line 172 of file metric.cpp.
References compute_con(), compute_cov(), Kadath::Term_eq::der_t, Kadath::Tensor::do_summation_one_dom(), espace, Kadath::Tensor::get_basis(), Kadath::Base_tensor::get_basis(), Kadath::Term_eq::get_dom(), Kadath::Tensor::get_index_type(), Kadath::Tensor::get_name_ind(), Kadath::Term_eq::get_type_data(), Kadath::Tensor::get_valence(), Kadath::Index::inc(), Kadath::Tensor::is_name_affected(), manipulate_ind(), p_met_con, p_met_cov, Kadath::Tensor::set(), Kadath::Array< T >::set(), Kadath::Index::set(), Kadath::Scalar::set_domain(), Kadath::Tensor::set_name_affected(), Kadath::Tensor::set_name_ind(), type_tensor, and Kadath::Term_eq::val_t.
|
virtual |
Returns a pointer on the background metric, if it exists.
Reimplemented in Kadath::Metric_AADS.
Definition at line 167 of file metric.cpp.
const Term_eq * Kadath::Metric::give_christo | ( | int | dd | ) | const |
Gives the Christoffel symbols, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 124 of file metric.cpp.
References compute_christo(), espace, Kadath::Space::get_nbr_domains(), and p_christo.
const Term_eq * Kadath::Metric::give_det_cov | ( | int | dd | ) | const |
Gives the determinant of the covariant metric, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 159 of file metric.cpp.
References compute_det_cov(), espace, Kadath::Space::get_nbr_domains(), and p_det_cov.
const Term_eq * Kadath::Metric::give_dirac | ( | int | dd | ) | const |
Gives the potential of the Dirac gauge, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 152 of file metric.cpp.
References compute_dirac(), espace, Kadath::Space::get_nbr_domains(), and p_dirac.
const Term_eq * Kadath::Metric::give_ricci_scalar | ( | int | dd | ) | const |
Gives the Ricci scalar, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 145 of file metric.cpp.
References compute_ricci_scalar(), espace, Kadath::Space::get_nbr_domains(), and p_ricci_scalar.
const Term_eq * Kadath::Metric::give_ricci_tensor | ( | int | dd | ) | const |
Gives the Ricci tensor, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 138 of file metric.cpp.
References compute_ricci_tensor(), espace, Kadath::Space::get_nbr_domains(), and p_ricci_tensor.
const Term_eq * Kadath::Metric::give_riemann | ( | int | dd | ) | const |
Gives the Riemann tensor, in a Domain
.
This is the Term_eq
version.
dd | : in which Domain . |
Term_eq
). Definition at line 131 of file metric.cpp.
References compute_riemann(), espace, Kadath::Space::get_nbr_domains(), and p_riemann.
const Term_eq * Kadath::Metric::give_term | ( | int | typemet, |
int | dd | ||
) | const |
Gives one representation of the metric, in a Domain
.
This is the Term_eq
version.
typemet | : CON or COV. |
dd | : in which Domain . |
Term_eq
). Definition at line 103 of file metric.cpp.
References compute_con(), compute_cov(), espace, Kadath::Space::get_nbr_domains(), p_met_con, and p_met_cov.
|
virtual |
Returns the type of tensorial basis of the covariant representation, in a given Domain
.
Reimplemented in Kadath::Metric_nophi_AADS, Kadath::Metric_nophi, Kadath::Metric_flat_nophi, Kadath::Metric_cfc, Kadath::Metric_conf_factor, Kadath::Metric_conf, Kadath::Metric_general, and Kadath::Metric_flat.
Definition at line 118 of file metric.cpp.
References compute_cov(), and p_met_cov.
|
virtual |
Uses the Metric
to manipulate one of the index of a Term_eq
(i.e.
moves the index up or down)
so | : the Term_eq to be manipulated. |
ind | : index number. |
Reimplemented in Kadath::Metric_AADS, Kadath::Metric_ADS, Kadath::Metric_flat_nophi, and Kadath::Metric_flat.
Definition at line 645 of file metric.cpp.
References compute_con(), compute_cov(), Kadath::Term_eq::der_t, espace, Kadath::Term_eq::get_der_t(), Kadath::Term_eq::get_dom(), Kadath::Space::get_domain(), Kadath::Tensor::get_index_type(), Kadath::Tensor::get_name_ind(), Kadath::Space::get_ndim(), Kadath::Term_eq::get_val_t(), Kadath::Tensor::get_valence(), Kadath::Index::inc(), Kadath::Tensor::is_name_affected(), p_met_con, p_met_cov, Kadath::Tensor::set(), Kadath::Array< T >::set(), Kadath::Index::set(), Kadath::Term_eq::set_der_t(), Kadath::Scalar::set_domain(), Kadath::Tensor::set_name_affected(), Kadath::Tensor::set_name_ind(), Kadath::Term_eq::set_val_t(), type_tensor, and Kadath::Term_eq::val_t.
|
virtual |
Updates the derived quantities (Christoffels etc..) This is done only for the ones that are needed, i.e.
for the ones that have already been computed.
Reimplemented in Kadath::Metric_flat_nophi, Kadath::Metric_AADS, Kadath::Metric_ADS, and Kadath::Metric_flat.
Definition at line 99 of file metric.cpp.
References espace, and Kadath::Space::get_nbr_domains().
|
virtual |
Updates the derived quantities (Christoffels etc..) in a given Domain
This is done only for the ones that are needed, i.e.
for the ones that have already been computed.
dd | : the index of the Domain . |
Reimplemented in Kadath::Metric_flat_nophi, Kadath::Metric_flat, Kadath::Metric_AADS, and Kadath::Metric_ADS.
Definition at line 82 of file metric.cpp.
References compute_christo(), compute_con(), compute_cov(), compute_det_cov(), compute_dirac(), compute_ricci_scalar(), compute_ricci_tensor(), compute_riemann(), p_christo, p_det_cov, p_dirac, p_met_con, p_met_cov, p_ricci_scalar, p_ricci_tensor, p_riemann, and type_tensor.
|
protected |
The associated Space
.
Definition at line 42 of file metric.hpp.
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto one component of the Christoffel symbols, in a given Domain
.
Definition at line 60 of file metric.hpp.
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto determinant of the covariant representation, in a given Domain
.
Definition at line 85 of file metric.hpp.
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto the potential of the Dirac gauge, in a given Domain
.
Definition at line 80 of file metric.hpp.
|
mutableprotected |
|
mutableprotected |
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto the Ricci scalar, in a given Domain
.
Definition at line 75 of file metric.hpp.
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto one component of the Ricci tensor, in a given Domain
.
Definition at line 70 of file metric.hpp.
|
mutableprotected |
Array of pointers on various Term_eq
.
Each one points onto one component of the Riemann tensor, in a given Domain
.
Definition at line 65 of file metric.hpp.
|
protected |
Pointer of the system of equations where the metric is used (only one for now).
Definition at line 44 of file metric.hpp.
|
protected |
States if one works in the CON or COV representation.
Definition at line 86 of file metric.hpp.