KADATH
|
The Space_bispheric
class fills the space with bispherical coordinates (see the constructor for more details).
More...
#include <bispheric.hpp>
Public Member Functions | |
int | get_ndom_minus () const |
Accessor ndom_minus. More... | |
int | get_ndom_plus () const |
Accessor ndom_plus. More... | |
int | get_nshells () const |
Accessor nshells. More... | |
Space_bispheric (int ttype, double dist, double r1, double r2, double rext, int nr) | |
Standard constructor More... | |
Space_bispheric (int ttype, double dist, double r1, double r2, int nshells, const Array< double > &rr, int nr) | |
Constructor with several outer shells. More... | |
Space_bispheric (int ttype, double dist, double r1, double r2, int nshells, const Array< double > &rr, const Array< int > &type_r, int nr) | |
Constructor with several outer shells possibly of various types (log or ![]() | |
Space_bispheric (int ttype, double dist, int nminus, const Array< double > &rminus, int nplus, const Array< double > &rplus, int nshells, const Array< double > &rr, const Array< int > &type_r, int nr, bool withnuc=true) | |
Constructor with several outer shells possibly of various types (log or ![]() | |
Space_bispheric (int ttype, double dist, int nminus, const Array< double > &rminus, const Array< int > &type_r_minus, int nplus, const Array< double > &rplus, const Array< int > &type_r_plus, int nshells, const Array< double > &rr, const Array< int > &type_r, int nr, bool withnuc=true) | |
Constructor with several outer shells possibly of various types (log or ![]() | |
Space_bispheric (int ttype, double dist, double rhor1, double rshell1, double rhor2, double rshell2, double rext, int nr) | |
Constructor without nucleus and one shell around each holes ; a compactified outer domain. More... | |
Space_bispheric (int ttype, double dist, double rhor1, double rshell1, double rhor2, double rshell2, double rext, Dim_array **resol) | |
Constructor without nucleus and one shell around each holes ; a compactified outer domain. More... | |
Space_bispheric (int ttype, double dist, double rhor1, double rshell1, double rhor2, double rshell2, int nshells, const Array< double > &rshells, int nr) | |
Constructor without nucleus and one shell around each holes ; a compactified outer domain. More... | |
Space_bispheric (FILE *, int shell_type=0, bool old=false) | |
Constructor from a file. More... | |
Space_bispheric (FILE *, int type_minus, int type_plus, int shell_type) | |
Constructor from a file where the types of shelles are passed as integers. More... | |
void | add_bc_sphere_one (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets a boundary condition at the inner radius of the first sphere. More... | |
void | add_bc_sphere_two (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets a boundary condition at the inner radius of the second sphere. More... | |
void | add_bc_outer_sphere (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets a boundary condition at the outer sphere of the bispheric coordinates. More... | |
void | add_bc_outer (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets a boundary condition at the outer boundary. More... | |
void | add_eq (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets an equation inside every domains (assumed to be second order). More... | |
void | add_eq_full (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets an equation inside every domains (assumed to be zeroth order). More... | |
void | add_eq_one_side (System_of_eqs &syst, const char *eq, int nused=-1, Array< int > **pused=0x0) |
Sets an equation inside every domains (assumed to be first order). More... | |
void | add_matching (System_of_eqs &syst, const char *rac, const List_comp &list) |
Sets a matching condition accross all the bispheric domain (intended for a second order equation). More... | |
void | add_matching (System_of_eqs &syst, const char *rac, int nused=-1, Array< int > **pused=0x0) |
Sets a matching condition accross all the bispheric domain (intended for a second order equation). More... | |
void | add_matching_one_side (System_of_eqs &syst, const char *rac, int nused=-1, Array< int > **pused=0x0) |
Sets a matching condition accross all the bispheric domain (intended for a first order equation). More... | |
void | add_eq (System_of_eqs &syst, const char *eq, const char *rac, const char *rac_der, int nused=-1, Array< int > **pused=0x0) |
Adds a bulk equation and two matching conditions. More... | |
void | add_eq (System_of_eqs &syst, const char *eq, const char *rac, const char *rac_der, const List_comp &list) |
Adds a bulk equation and two matching conditions. More... | |
void | add_eq_no_nucleus (System_of_eqs &syst, const char *eq, const char *rac, const char *rac_der, int nused=-1, Array< int > **pused=0x0) |
Adds a bulk equation and two matching conditions for a space without nucleii. More... | |
void | add_eq_no_nucleus (System_of_eqs &syst, const char *eq, const char *rac, const char *rac_der, const List_comp &list) |
Adds a bulk equation and two matching conditions for a space without nucleii. More... | |
void | add_eq_int_inf (System_of_eqs &syst, const char *eq) |
Adds an equation being a surface integral at infinity. More... | |
void | add_eq_int_sphere_one (System_of_eqs &syst, const char *eq) |
Adds an equation being a surface integral on the first sphere. More... | |
void | add_eq_int_sphere_two (System_of_eqs &syst, const char *eq) |
Adds an equation being a surface integral on the second sphere. More... | |
void | add_eq_zero_mode_inf (System_of_eqs &syst, const char *f, int jtarget, int ktarget) |
Adds an equation saying that one coefficient of a field is zero (at infinity) More... | |
double | get_a_minus () const |
Returns the location of the center of the first sphere. More... | |
double | get_a_plus () const |
Returns the location of the center of the second sphere. More... | |
double | int_sphere_one (const Scalar &so) const |
Computes the surface integral on the first sphere. More... | |
double | int_sphere_two (const Scalar &so) const |
Computes the surface integral on the second sphere. More... | |
double | int_inf (const Scalar &so) const |
Computes the surface integral at infinity. More... | |
virtual | ~Space_bispheric () |
Destructor. More... | |
virtual void | save (FILE *) const |
Saving function. More... | |
virtual Array< int > | get_indices_matching_non_std (int, int) const |
Gives the number of the other domains, touching a given boundary. More... | |
int | get_ndim () const |
Returns the number of dimensions. More... | |
int | get_nbr_domains () const |
Returns the number of Domains . More... | |
int | get_type_base () const |
Returns the type of basis. More... | |
const Domain * | get_domain (int i) const |
returns a pointer on the domain. More... | |
virtual int | nbr_unknowns_from_variable_domains () const |
Gives the number of unknowns coming from the variable shape of the domain. More... | |
virtual void | affecte_coef_to_variable_domains (int &conte, int cc, Array< int > &doms) const |
The variation of the functions describing the shape of the Domain are affected from the unknowns of the system. More... | |
virtual void | xx_to_ders_variable_domains (const Array< double > &xx, int &conte) const |
Update the vairable domains from a set of values. More... | |
virtual void | xx_to_vars_variable_domains (System_of_eqs *syst, const Array< double > &xx, int &conte) const |
Update the variables of a system, from the variation of the shape of the domains. More... | |
Protected Attributes | |
double | a_minus |
X-absolute coordinate of the center of the first sphere. More... | |
double | a_plus |
X-absolute coordinate of the center of the second sphere. More... | |
int | ndom_minus |
Number of spherical domains inside the first sphere. More... | |
int | ndom_plus |
Number of spherical domains inside the second sphere. More... | |
int | nshells |
Number of shells outside the bispheric region. More... | |
int | nbr_domains |
Number od Domains . More... | |
int | ndim |
Number of dimensions (should be the same for all the Domains ). More... | |
int | type_base |
Type of basis used (i.e. using either Chebyshev or Legendre polynomials). More... | |
Domain ** | domains |
Pointers on the various Domains . More... | |
The Space_bispheric
class fills the space with bispherical coordinates (see the constructor for more details).
Definition at line 1241 of file bispheric.hpp.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | r1, | ||
double | r2, | ||
double | rext, | ||
int | nr | ||
) |
Standard constructor
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
r1 | [input] : radius ![]() |
r2 | [input] : radius ![]() |
rext | [input] : radius ![]() |
nr | [input] : number of points in each dimension ( ![]() ![]() |
The scale for the bispherical coordinates is determined such that :
The first sphere is described by , centered at
.
The second sphere is described by , centered at
.
The cutoffs for the bispherical coordinates are and
The various domains are then :
Domain_nucleus
, of radius Domain_nucleus
, of radius Domain_bispheric_chi_first
near the first sphere. Domain_bispheric_rect
near the first sphere. Domain_bispheric_eta_first
inbetween the two spheres. Domain_bispheric_rect
near the second sphere. Domain_bispheric_chi_first
near the second sphere. Domain_compact
centered on the origin, with inner radius Definition at line 42 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | r1, | ||
double | r2, | ||
int | nshells, | ||
const Array< double > & | rr, | ||
int | nr | ||
) |
Constructor with several outer shells.
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
r1 | [input] : radius ![]() |
r2 | [input] : radius ![]() |
nshells | [input] : number of outer shells. |
rr | [input] : radiii of the outer shells. |
nr | [input] : number of points in each dimension ( ![]() ![]() |
The various domains are then :
Domain_nucleus
, of radius Domain_nucleus
, of radius Domain_bispheric_chi_first
near the first sphere. Domain_bispheric_rect
near the first sphere. Domain_bispheric_eta_first
inbetween the two spheres. Domain_bispheric_rect
near the second sphere. Domain_bispheric_chi_first
near the second sphere. Domain_shells
outside the bispheric region, centered on the origin. Domain_compact
centered on the origin. Definition at line 102 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | r1, | ||
double | r2, | ||
int | nshells, | ||
const Array< double > & | rr, | ||
const Array< int > & | type_r, | ||
int | nr | ||
) |
Constructor with several outer shells possibly of various types (log or mappings).
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
r1 | [input] : radius ![]() |
r2 | [input] : radius ![]() |
nshells | [input] : number of outer shells. |
rr | [input] : radiii of the outer shells. |
type_r | [input] : types of the various outer shells. |
nr | [input] : number of points in each dimension ( ![]() ![]() |
The various domains are then :
Domain_nucleus
, of radius Domain_nucleus
, of radius Domain_bispheric_chi_first
near the first sphere. Domain_bispheric_rect
near the first sphere. Domain_bispheric_eta_first
inbetween the two spheres. Domain_bispheric_rect
near the second sphere. Domain_bispheric_chi_first
near the second sphere. Domain_shell
, Domain_shell_log
or Domain_shell_surr
Domain_compact
centered on the origin. Definition at line 167 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
int | nminus, | ||
const Array< double > & | rminus, | ||
int | nplus, | ||
const Array< double > & | rplus, | ||
int | nshells, | ||
const Array< double > & | rr, | ||
const Array< int > & | type_r, | ||
int | nr, | ||
bool | withnuc = true |
||
) |
Constructor with several outer shells possibly of various types (log or mappings).
Each hole can be described by several shells.
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
nminus | [input] : number of domains inside the first sphere. |
rminus | [input] : radii of the domains inside the first sphere. |
nplus | [input] : number of domains inside the second sphere. |
rplus | [input] : radii of the domains inside the second sphere. |
nshells | [input] : number of outer shells. |
rr | [input] : radiii of the outer shells. |
type_r | [input] : types of the various outer shells. |
nr | [input] : number of points in each dimension |
withnuc | [input] : states wheather a nucleus is present or not ( ![]() ![]() |
The various domains are then :
Domain_nucleus
centered at Domain_shell
centered at Domain_nucleus
centered at Domain_shell
centered at Domain_bispheric_chi_first
near the first sphere. Domain_bispheric_rect
near the first sphere. Domain_bispheric_eta_first
inbetween the two spheres. Domain_bispheric_rect
near the second sphere. Domain_bispheric_chi_first
near the second sphere. Domain_shell
, Domain_shell_log
or Domain_shell_surr
Domain_compact
centered on the origin. Definition at line 244 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
int | nminus, | ||
const Array< double > & | rminus, | ||
const Array< int > & | type_r_minus, | ||
int | nplus, | ||
const Array< double > & | rplus, | ||
const Array< int > & | type_r_plus, | ||
int | nshells, | ||
const Array< double > & | rr, | ||
const Array< int > & | type_r, | ||
int | nr, | ||
bool | withnuc = true |
||
) |
Constructor with several outer shells possibly of various types (log or mappings).
Each hole can be described by several shells also possibly with various types of mappings
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
nminus | [input] : number of domains inside the first sphere. |
rminus | [input] : radii of the domains inside the first sphere. |
type_r_minus | [input] : types of the various shells around the first hole. |
nplus | [input] : number of domains inside the second sphere. |
rplus | [input] : radii of the domains inside the second sphere. |
type_r_plus | [input] : types of the various shells around the second hole. |
nshells | [input] : number of outer shells. |
rr | [input] : radiii of the outer shells. |
type_r | [input] : types of the various outer shells. |
nr | [input] : number of points in each dimension |
withnuc | [input] : states wheather a nucleus is present or not ( ![]() ![]() |
The various domains are then :
Domain_nucleus
centered at Shells
centered at Domain_shell
, Domain_shell_log
or Domain_shell_surr
Domain_nucleus
centered at Shells
centered at Domain_shell
, Domain_shell_log
or Domain_shell_surr
Domain_bispheric_chi_first
near the first sphere. Domain_bispheric_rect
near the first sphere. Domain_bispheric_eta_first
inbetween the two spheres. Domain_bispheric_rect
near the second sphere. Domain_bispheric_chi_first
near the second sphere. Domain_shell
, Domain_shell_log
or Domain_shell_surr
Domain_compact
centered on the origin. Definition at line 351 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | rhor1, | ||
double | rshell1, | ||
double | rhor2, | ||
double | rshell2, | ||
double | rext, | ||
int | nr | ||
) |
Constructor without nucleus and one shell around each holes ; a compactified outer domain.
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
rhor1 | [input] : radius of the first horizon. |
rshell1 | [input] : radius of the first shell. |
rhor2 | [input] : radius of the second horizon. |
rshell2 | [input] : radius of the second shell. |
rext | [input] : radius of the bispherical domains. |
nr | [input] : number of points in each dimension ( ![]() ![]() |
Definition at line 490 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | rhor1, | ||
double | rshell1, | ||
double | rhor2, | ||
double | rshell2, | ||
double | rext, | ||
Dim_array ** | resol | ||
) |
Constructor without nucleus and one shell around each holes ; a compactified outer domain.
The resolution of each domain is speceified by hand
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
rhor1 | [input] : radius of the first horizon. |
rshell1 | [input] : radius of the first shell. |
rhor2 | [input] : radius of the second horizon. |
rshell2 | [input] : radius of the second shell. |
rext | [input] : radius of the bispherical domains. |
resol | [input] : resolution in each domains |
Definition at line 556 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | int | ttype, |
double | dist, | ||
double | rhor1, | ||
double | rshell1, | ||
double | rhor2, | ||
double | rshell2, | ||
int | nshells, | ||
const Array< double > & | rshells, | ||
int | nr | ||
) |
Constructor without nucleus and one shell around each holes ; a compactified outer domain.
ttype | [input] : the type of basis. |
dist | [input] : distance ![]() |
rhor1 | [input] : radius of the first horizon. |
rshell1 | [input] : radius of the first shell. |
rhor2 | [input] : radius of the second horizon. |
rshell2 | [input] : radius of the second shell. |
nshells | [input] : number of outer shells. |
rshells | [input] : radiii of the outer shells. |
nr | [input] : number of points in each dimension ( ![]() ![]() |
Definition at line 616 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Param::add_double(), Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, Kadath::Dim_array::set(), Kadath::Point::set(), and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | FILE * | fd, |
int | shell_type = 0 , |
||
bool | old = false |
||
) |
Constructor from a file.
fd | : the file |
shell_type | : type of the outer shells (assumed to be the same for each one). |
old | : deprecated for backward compatibility. |
Definition at line 685 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, and Kadath::Space::type_base.
Kadath::Space_bispheric::Space_bispheric | ( | FILE * | fd, |
int | type_minus, | ||
int | type_plus, | ||
int | shell_type | ||
) |
Constructor from a file where the types of shelles are passed as integers.
fd | : the file |
type_minus | : type of the shells around hole 1(assumed to be the same for each one). |
type_plus | : type of the shells around hole 2 (assumed to be the same for each one). |
shell_type | : type of the outer shells (assumed to be the same for each one). |
Definition at line 768 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, and Kadath::Space::type_base.
|
virtual |
Destructor.
Definition at line 874 of file space_bispheric.cpp.
void Kadath::Space_bispheric::add_bc_outer | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a boundary condition at the outer boundary.
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 55 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_bc(), and Kadath::Space::nbr_domains.
void Kadath::Space_bispheric::add_bc_outer_sphere | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a boundary condition at the outer sphere of the bispheric coordinates.
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 49 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_bc(), ndom_minus, and ndom_plus.
void Kadath::Space_bispheric::add_bc_sphere_one | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a boundary condition at the inner radius of the first sphere.
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 26 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_bc(), ndom_minus, and ndom_plus.
void Kadath::Space_bispheric::add_bc_sphere_two | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a boundary condition at the inner radius of the second sphere.
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 38 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_bc(), ndom_minus, and ndom_plus.
void Kadath::Space_bispheric::add_eq | ( | System_of_eqs & | syst, |
const char * | eq, | ||
const char * | rac, | ||
const char * | rac_der, | ||
const List_comp & | list | ||
) |
Adds a bulk equation and two matching conditions.
syst | : the System_of_eqs . |
eq | : the string describing the bulk equation. |
rac | : the string describing the first matching condition. |
rac_der | : the string describing the second matching condition. |
list | : list of the components to be considered. |
Definition at line 156 of file bispheric_add_eq.cpp.
References add_eq(), Kadath::List_comp::get_ncomp(), and Kadath::List_comp::get_pcomp().
void Kadath::Space_bispheric::add_eq | ( | System_of_eqs & | syst, |
const char * | eq, | ||
const char * | rac, | ||
const char * | rac_der, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Adds a bulk equation and two matching conditions.
syst | : the System_of_eqs . |
eq | : the string describing the bulk equation. |
rac | : the string describing the first matching condition. |
rac_der | : the string describing the second matching condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 92 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_inside(), Kadath::System_of_eqs::add_eq_matching(), and Kadath::System_of_eqs::add_eq_matching_import().
void Kadath::Space_bispheric::add_eq | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets an equation inside every domains (assumed to be second order).
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 59 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_inside(), Kadath::System_of_eqs::get_dom_max(), and Kadath::System_of_eqs::get_dom_min().
void Kadath::Space_bispheric::add_eq_full | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets an equation inside every domains (assumed to be zeroth order).
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 64 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_full(), Kadath::System_of_eqs::get_dom_max(), and Kadath::System_of_eqs::get_dom_min().
void Kadath::Space_bispheric::add_eq_int_inf | ( | System_of_eqs & | syst, |
const char * | eq | ||
) |
Adds an equation being a surface integral at infinity.
syst | : the System_of_eqs . |
eq | : the string describing the equation (should contain something like integ(f)=b) |
Definition at line 214 of file bispheric_add_eq.cpp.
References Kadath::Space::domains, Kadath::System_of_eqs::eq_int, Kadath::System_of_eqs::give_ope(), Kadath::System_of_eqs::is_ope_bin(), Kadath::System_of_eqs::nbr_conditions, Kadath::Space::nbr_domains, and Kadath::System_of_eqs::neq_int.
void Kadath::Space_bispheric::add_eq_int_sphere_one | ( | System_of_eqs & | syst, |
const char * | eq | ||
) |
Adds an equation being a surface integral on the first sphere.
syst | : the System_of_eqs . |
eq | : the string describing the equation (should contain something like integ(f)=b) |
Definition at line 252 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::eq_int, Kadath::System_of_eqs::give_ope(), Kadath::System_of_eqs::is_ope_bin(), Kadath::System_of_eqs::nbr_conditions, ndom_minus, ndom_plus, and Kadath::System_of_eqs::neq_int.
void Kadath::Space_bispheric::add_eq_int_sphere_two | ( | System_of_eqs & | syst, |
const char * | eq | ||
) |
Adds an equation being a surface integral on the second sphere.
syst | : the System_of_eqs . |
eq | : the string describing the equation (should contain something like integ(f)=b) |
Definition at line 305 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::eq_int, Kadath::System_of_eqs::give_ope(), Kadath::System_of_eqs::is_ope_bin(), Kadath::System_of_eqs::nbr_conditions, ndom_minus, ndom_plus, and Kadath::System_of_eqs::neq_int.
void Kadath::Space_bispheric::add_eq_no_nucleus | ( | System_of_eqs & | syst, |
const char * | eq, | ||
const char * | rac, | ||
const char * | rac_der, | ||
const List_comp & | list | ||
) |
Adds a bulk equation and two matching conditions for a space without nucleii.
syst | : the System_of_eqs . |
eq | : the string describing the bulk equation. |
rac | : the string describing the first matching condition. |
rac_der | : the string describing the second matching condition. |
list | : list of the components to be considered. |
Definition at line 211 of file bispheric_add_eq.cpp.
References add_eq(), Kadath::List_comp::get_ncomp(), and Kadath::List_comp::get_pcomp().
void Kadath::Space_bispheric::add_eq_no_nucleus | ( | System_of_eqs & | syst, |
const char * | eq, | ||
const char * | rac, | ||
const char * | rac_der, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Adds a bulk equation and two matching conditions for a space without nucleii.
syst | : the System_of_eqs . |
eq | : the string describing the bulk equation. |
rac | : the string describing the first matching condition. |
rac_der | : the string describing the second matching condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 160 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_inside(), Kadath::System_of_eqs::add_eq_matching(), and Kadath::System_of_eqs::add_eq_matching_import().
void Kadath::Space_bispheric::add_eq_one_side | ( | System_of_eqs & | syst, |
const char * | eq, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets an equation inside every domains (assumed to be first order).
syst | : the System_of_eqs . |
eq | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 69 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_one_side(), Kadath::System_of_eqs::get_dom_max(), and Kadath::System_of_eqs::get_dom_min().
void Kadath::Space_bispheric::add_eq_zero_mode_inf | ( | System_of_eqs & | syst, |
const char * | f, | ||
int | jtarget, | ||
int | ktarget | ||
) |
Adds an equation saying that one coefficient of a field is zero (at infinity)
syst | : the System_of_eqs . |
f | : the field |
jtarget | : the index ![]() |
ktarget | : the index ![]() |
Definition at line 358 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_mode(), Kadath::Space::domains, Kadath::Space::nbr_domains, and Kadath::Index::set().
void Kadath::Space_bispheric::add_matching | ( | System_of_eqs & | syst, |
const char * | rac, | ||
const List_comp & | list | ||
) |
Sets a matching condition accross all the bispheric domain (intended for a second order equation).
syst | : the System_of_eqs . |
rac | : the string describing the boundary condition. |
list | : list of the components to be considered. |
Definition at line 81 of file bispheric_add_eq.cpp.
References Kadath::List_comp::get_ncomp(), and Kadath::List_comp::get_pcomp().
void Kadath::Space_bispheric::add_matching | ( | System_of_eqs & | syst, |
const char * | rac, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a matching condition accross all the bispheric domain (intended for a second order equation).
syst | : the System_of_eqs . |
rac | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 74 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_matching(), ndom_minus, and ndom_plus.
void Kadath::Space_bispheric::add_matching_one_side | ( | System_of_eqs & | syst, |
const char * | rac, | ||
int | nused = -1 , |
||
Array< int > ** | pused = 0x0 |
||
) |
Sets a matching condition accross all the bispheric domain (intended for a first order equation).
syst | : the System_of_eqs . |
rac | : the string describing the boundary condition. |
nused | : number of components of eq to be considered. All the components are used of it is -1. |
pused | : pointer on the indexes of the components to be considered. Not used of nused = -1 . |
Definition at line 85 of file bispheric_add_eq.cpp.
References Kadath::System_of_eqs::add_eq_matching_one_side(), ndom_minus, and ndom_plus.
|
inlinevirtualinherited |
The variation of the functions describing the shape of the Domain
are affected from the unknowns of the system.
conte | : current position if the unknowns. |
cc | : position of the unknown to be set. |
doms | : Array containing the index of the variable domains present in this space. |
Reimplemented in Kadath::Space_bin_ns, Kadath::Space_bin_bh, Kadath::Space_bbh, Kadath::Space_polar_adapted, Kadath::Space_adapted_bh, and Kadath::Space_spheric_adapted.
|
inline |
Returns the location of the center of the first sphere.
Definition at line 1644 of file bispheric.hpp.
References a_minus.
|
inline |
Returns the location of the center of the second sphere.
Definition at line 1648 of file bispheric.hpp.
References a_plus.
|
inlineinherited |
returns a pointer on the domain.
i | [input] : the index of the domain. |
Definition at line 1385 of file space.hpp.
References Kadath::Space::domains, and Kadath::Space::nbr_domains.
|
virtual |
Gives the number of the other domains, touching a given boundary.
It also gives the name of the boundary, as seen by the other domain.
dom | : the domain considered. |
bound | : the boundary. |
Reimplemented from Kadath::Space.
Definition at line 892 of file space_bispheric.cpp.
References ndom_minus, ndom_plus, and Kadath::Array< T >::set().
|
inlineinherited |
Returns the number of Domains
.
Definition at line 1375 of file space.hpp.
References Kadath::Space::nbr_domains.
|
inlineinherited |
Returns the number of dimensions.
Definition at line 1373 of file space.hpp.
References Kadath::Space::ndim.
|
inline |
|
inline |
|
inline |
|
inlineinherited |
Returns the type of basis.
Definition at line 1377 of file space.hpp.
References Kadath::Space::type_base.
double Kadath::Space_bispheric::int_inf | ( | const Scalar & | so | ) | const |
Computes the surface integral at infinity.
so | : the field to be integrated. |
Definition at line 1041 of file space_bispheric.cpp.
References Kadath::Space::domains, Kadath::Domain_compact::integ(), and Kadath::Space::nbr_domains.
double Kadath::Space_bispheric::int_sphere_one | ( | const Scalar & | so | ) | const |
Computes the surface integral on the first sphere.
so | : the field to be integrated. |
Definition at line 1052 of file space_bispheric.cpp.
References Kadath::Space::domains, Kadath::Domain::integ(), ndom_minus, and ndom_plus.
double Kadath::Space_bispheric::int_sphere_two | ( | const Scalar & | so | ) | const |
Computes the surface integral on the second sphere.
so | : the field to be integrated. |
Definition at line 1062 of file space_bispheric.cpp.
References Kadath::Space::domains, Kadath::Domain::integ(), ndom_minus, and ndom_plus.
|
inlinevirtualinherited |
Gives the number of unknowns coming from the variable shape of the domain.
Reimplemented in Kadath::Space_bin_ns, Kadath::Space_bin_bh, Kadath::Space_bbh, Kadath::Space_polar_adapted, Kadath::Space_adapted_bh, and Kadath::Space_spheric_adapted.
|
virtual |
Saving function.
Reimplemented from Kadath::Space.
Definition at line 879 of file space_bispheric.cpp.
References a_minus, a_plus, Kadath::Space::domains, Kadath::Space::nbr_domains, Kadath::Space::ndim, ndom_minus, ndom_plus, nshells, and Kadath::Space::type_base.
|
inlinevirtualinherited |
Update the vairable domains from a set of values.
xx | : set of values used by the affectation |
conte | : current position in the values vector. |
Reimplemented in Kadath::Space_bin_ns, Kadath::Space_bin_bh, Kadath::Space_bbh, Kadath::Space_polar_adapted, Kadath::Space_adapted_bh, and Kadath::Space_spheric_adapted.
|
inlinevirtualinherited |
Update the variables of a system, from the variation of the shape of the domains.
syst | : the System_of_eqs considered. |
xx | : set of values used by the affectation |
conte | : current position in the values vector. |
Reimplemented in Kadath::Space_bin_ns, Kadath::Space_bin_bh, Kadath::Space_bbh, Kadath::Space_polar_adapted, Kadath::Space_adapted_bh, and Kadath::Space_spheric_adapted.
|
protected |
X-absolute coordinate of the center of the first sphere.
Definition at line 1243 of file bispheric.hpp.
|
protected |
X-absolute coordinate of the center of the second sphere.
Definition at line 1244 of file bispheric.hpp.
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protected |
Number of spherical domains inside the first sphere.
Definition at line 1245 of file bispheric.hpp.
|
protected |
Number of spherical domains inside the second sphere.
Definition at line 1246 of file bispheric.hpp.
|
protected |
Number of shells outside the bispheric region.
Definition at line 1247 of file bispheric.hpp.
|
protectedinherited |