OpenFCST: The open-source Fuel Cell Simulation Toolbox
|
Classes | |
class | InitialOrBoundaryDataBase |
This class is a means to make variable initial or boundary data. More... | |
Functions | |
template<typename COMPONENT_xxxID_VALUE_MAP > | |
const bool | check (const std::vector< COMPONENT_xxxID_VALUE_MAP > &maps) |
This function does some checkings on its argument maps . More... | |
template<typename VECTOR , typename DH > | |
void | make_piece_wise_constant_initial_data (VECTOR &dst, const Mapping< DH::dimension, DH::space_dimension > &mapping, const DH &dof, const FuelCell::SystemManagement &system_management, const std::vector< component_materialID_value_map > &maps) |
This function makes piece wise constant initial data. More... | |
template<typename DH > | |
void | make_constant_DirichletBC_values (std::map< unsigned int, double > &dst, const Mapping< DH::dimension, DH::space_dimension > &mapping, const DH &dof, const FuelCell::SystemManagement &system_management, const std::vector< component_boundaryID_value_map > &maps) |
template<typename VECTOR , typename DH > | |
void | apply_piece_wise_constant_DirichletBCs (VECTOR &dst, const Mapping< DH::dimension, DH::space_dimension > &mapping, const DH &dof, const FuelCell::SystemManagement &system_management, const std::vector< component_boundaryID_value_map > &maps) |
This function applies piece wise constant Dirichlet BCs. More... | |
template<typename DH > | |
void | make_zero_boundary_values (std::map< unsigned int, double > &dst, const Mapping< DH::dimension, DH::space_dimension > &mapping, const DH &dof, const FuelCell::SystemManagement &system_management, const std::vector< component_boundaryID_value_map > &maps) |
This function makes zero boundary values. More... | |
template<typename MATRIX , typename VECTOR , typename DH > | |
void | apply_zero_boundary_values_to_linear_system (MATRIX &matrix, VECTOR &solution, VECTOR &rhs, const Mapping< DH::dimension, DH::space_dimension > &mapping, const DH &dof, const FuelCell::SystemManagement &system_management, const std::vector< component_boundaryID_value_map > &maps, const bool &repair_diagonal=false) |
This function applies zero boundary values to the linear system of equations. More... | |
void FuelCell::InitialAndBoundaryData::apply_piece_wise_constant_DirichletBCs | ( | VECTOR & | dst, |
const Mapping< DH::dimension, DH::space_dimension > & | mapping, | ||
const DH & | dof, | ||
const FuelCell::SystemManagement & | system_management, | ||
const std::vector< component_boundaryID_value_map > & | maps | ||
) |
This function applies piece wise constant Dirichlet BCs.
dst | : Solution vector of size DOF. This is usually an FEVector. |
mapping | : This parameter contains the geometrical map. It is stored in DoFApplication under *this->mapping |
dof,: | DoFHandler object. It is stored in DoFApplication under *this->dof |
system_management,: | This object stores the solution variable names and number as well as equation couplings. It should be in your application. |
maps,: | This object is a vector of component_materialID_value_map. The component_materialID_value_map object is generated in the linear applications and should be initialized with the EquationBase objects using a statement as follows: * component_boundaryID_value_map.push_back( ficks_transport_equation.get_component_boundaryID_value() );
* component_boundaryID_value_map.push_back( electron_transport_equation.get_component_boundaryID_value() );
* component_boundaryID_value_map.push_back( proton_transport_equation.get_component_boundaryID_value() );
*
|
References _IS_NOT_CONSTANT_, FuelCell::SystemManagement::get_number_of_solution_names(), and FuelCell::SystemManagement::solution_name_to_index().
void FuelCell::InitialAndBoundaryData::apply_zero_boundary_values_to_linear_system | ( | MATRIX & | matrix, |
VECTOR & | solution, | ||
VECTOR & | rhs, | ||
const Mapping< DH::dimension, DH::space_dimension > & | mapping, | ||
const DH & | dof, | ||
const FuelCell::SystemManagement & | system_management, | ||
const std::vector< component_boundaryID_value_map > & | maps, | ||
const bool & | repair_diagonal = false |
||
) |
This function applies zero boundary values to the linear system of equations.
References SolverUtils::repair_diagonal().
const bool FuelCell::InitialAndBoundaryData::check | ( | const std::vector< COMPONENT_xxxID_VALUE_MAP > & | maps | ) |
This function does some checkings on its argument maps
.
References FcstUtilities::log.
void FuelCell::InitialAndBoundaryData::make_constant_DirichletBC_values | ( | std::map< unsigned int, double > & | dst, |
const Mapping< DH::dimension, DH::space_dimension > & | mapping, | ||
const DH & | dof, | ||
const FuelCell::SystemManagement & | system_management, | ||
const std::vector< component_boundaryID_value_map > & | maps | ||
) |
dst | : Solution vector of size DOF. This is usually an FEVector. |
mapping | : This parameter contains the geometrical map. It is stored in DoFApplication under *this->mapping |
dof,: | DoFHandler object. It is stored in DoFApplication under *this->dof |
system_management,: | This object stores the solution variable names and number as well as equation couplings. It should be in your application. |
maps,: | This object is a vector of component_materialID_value_map. The component_materialID_value_map object is generated in the linear applications and should be initialized with the EquationBase objects using a statement as follows: |
References FuelCell::SystemManagement::get_number_of_solution_names(), and FuelCell::SystemManagement::solution_name_to_index().
void FuelCell::InitialAndBoundaryData::make_piece_wise_constant_initial_data | ( | VECTOR & | dst, |
const Mapping< DH::dimension, DH::space_dimension > & | mapping, | ||
const DH & | dof, | ||
const FuelCell::SystemManagement & | system_management, | ||
const std::vector< component_materialID_value_map > & | maps | ||
) |
This function makes piece wise constant initial data.
dst | : Solution vector of size DOF. This is usually an FEVector. |
mapping | : This parameter contains the geometrical map. It is stored in DoFApplication under *this->mapping |
dof,: | DoFHandler object. It is stored in DoFApplication under *this->dof |
system_management,: | This object stores the solution variable names and number as well as equation couplings. It should be in your application. |
maps,: | This object is a vector of component_materialID_value_map. The component_materialID_value_map object is generated in the linear applications and should be initialized with the EquationBase objects using a statement as follows: * component_materialID_value_maps.push_back( ficks_transport_equation.get_component_materialID_value() );
* component_materialID_value_maps.push_back( electron_transport_equation.get_component_materialID_value() );
* component_materialID_value_maps.push_back( proton_transport_equation.get_component_materialID_value() );
*
|
References _IS_NOT_CONSTANT_, FuelCell::SystemManagement::get_number_of_solution_names(), and FuelCell::SystemManagement::solution_name_to_index().
void FuelCell::InitialAndBoundaryData::make_zero_boundary_values | ( | std::map< unsigned int, double > & | dst, |
const Mapping< DH::dimension, DH::space_dimension > & | mapping, | ||
const DH & | dof, | ||
const FuelCell::SystemManagement & | system_management, | ||
const std::vector< component_boundaryID_value_map > & | maps | ||
) |
This function makes zero boundary values.
References FuelCell::SystemManagement::get_number_of_solution_names(), and FuelCell::SystemManagement::solution_name_to_index().