OpenFCST: The open-source Fuel Cell Simulation Toolbox
|
This class is used to represent a solid layer. More...
#include <solid_layer.h>
Public Member Functions | |
Effective property calculators | |
virtual void | effective_electron_conductivity (Tensor< 2, dim > &) const |
Compute the effective electron conductivity in the SolidLayer. More... | |
virtual void | effective_electron_conductivity (std::vector< Tensor< 2, dim >> &) const |
Compute the effective electron conductivity in the SolidLayer This class is used for both isotropic and anisotropic materials. More... | |
virtual void | derivative_effective_electron_conductivity (std::map< VariableNames, Tensor< 2, dim >> &) const |
Compute the derivative of the effective electron conductivity in the SolidLayer with respect to temperature solutionvariable. More... | |
virtual void | derivative_effective_electron_conductivity (std::vector< std::map< VariableNames, Tensor< 2, dim > > > &) const |
Compute the derivative of the effective electron conductivity in the SolidLayer with respect to temperature solutionvariable. More... | |
virtual void | effective_thermal_conductivity (Tensor< 2, dim > &) const |
Compute the effective thermal conductivity in the SolidLayer. More... | |
virtual void | effective_thermal_conductivity (std::vector< Tensor< 2, dim > > &) const |
Compute the effective thermal conductivity in the SolidLayer, dependent on various solution variables, eg: Temperature. More... | |
virtual void | derivative_effective_thermal_conductivity (std::map< VariableNames, Tensor< 2, dim > > &) const |
Compute the derivative of the effective thermal conductivity in the SolidLayer with respect to temperature solutionvariable. More... | |
virtual void | derivative_effective_thermal_conductivity (std::vector< std::map< VariableNames, Tensor< 2, dim > > > &) const |
Compute the derivative of the effective thermal conductivity in the SolidLayer with respect to temperature solutionvariable. More... | |
void | set_solution (std::map< VariableNames, SolutionVariable > &sol) |
Member function used to set the solution [Kelvin ] at every quadrature point inside the cell. More... | |
Accessors and info | |
const std::type_info & | get_base_type () const |
This member function returns a type_info object with the name of the base layer type the inherited class belongs to, i.e. More... | |
Public Member Functions inherited from FuelCellShop::Layer::BaseLayer< dim > | |
virtual void | set_derivative_flags (const std::vector< VariableNames > &flags) |
Set the variables for which you would like to compute the derivatives. More... | |
void | set_position (const std::vector< Point< dim > > &p) |
Member function used by some applications such as dummyGDL in order to know which value to return. More... | |
void | set_local_material_id (const unsigned int &id) |
Function for setting local material id, for unit testing purposes. More... | |
void | unset_local_material_id () |
Function for unsetting local material id, so that it isn't incorrectly used later Once the key is "unset" to some invalid value, an error will be thrown if the key is requested again without being set. More... | |
virtual void | set_constant_solution (const double &value, const VariableNames &name) |
Set those solution variables which are constant in the particular application. More... | |
virtual void | set_solution (const std::vector< SolutionVariable > &) |
If the effective properties in the layer depend on the solution, the solution for a given cell should be passed to the class using this member function. More... | |
bool | belongs_to_material (const unsigned int material_id) |
Check if a given cell belongs to the catalyst layer and assign. More... | |
const std::string & | name_layer () const |
Return the name of the layer. More... | |
virtual void | print_layer_properties () const |
This member function is a virtual class that can be used to output to screen information from the layer. More... | |
virtual bool | test_layer () |
This virtual class should be used for any derived class to be able to test the functionality of the class. More... | |
std::vector< unsigned int > | get_material_ids () |
Return the local material id of the layer. More... | |
unsigned int | local_material_id () const |
Return the local material id of the layer, performs a check. More... | |
Protected Member Functions | |
Constructors, destructor, and initialization | |
Class test | |
SolidLayer (const std::string §ion_layer_name, ParameterHandler ¶m) | |
Constructor. More... | |
~SolidLayer () | |
Destructor. More... | |
void | declare_parameters (const std::string &solidlayer_section_name, ParameterHandler ¶m) const |
Function used to select the appropriate SolidLayer type as specified in the ParameterHandler under line. More... | |
void | initialize (ParameterHandler ¶m) |
Member function used to read in data and initialize the necessary data to compute the coefficients. More... | |
Protected Member Functions inherited from FuelCellShop::Layer::BaseLayer< dim > | |
BaseLayer () | |
Constructor. More... | |
BaseLayer (const std::string &name) | |
Constructor. More... | |
virtual | ~BaseLayer () |
Destructor. More... | |
virtual void | declare_parameters (ParameterHandler ¶m) const |
Declare parameters for a parameter file. More... | |
virtual void | set_parameters (const std::string &object_name, const std::vector< std::string > &name_dvar, const std::vector< double > &value_dvar, ParameterHandler ¶m) |
Member function used to change the values in the parameter file for a given list of parameters. More... | |
virtual void | set_parameters (const std::vector< std::string > &name_dvar, const std::vector< double > &value_dvar, ParameterHandler ¶m) |
Set parameters in parameter file. More... | |
Protected Attributes | |
Internal variables | |
std::vector< unsigned int > | boundary_ids |
Boundary ids. More... | |
boost::shared_ptr < FuelCellShop::Material::PureSolid > | solid |
Data member that stores the solid material the layer is made of. More... | |
std::string | concrete_solid_name |
Name in the input file used to select the material. More... | |
SolutionVariable | T_vector |
Solution Varaible at each quadrature point. More... | |
std::map< VariableNames, SolutionVariable > | Solutions |
Solutions at every quadrature point inside the cell. More... | |
std::map< VariableNames, SolutionVariable >::iterator | solution_iterator |
VariableNames | temperature_enum |
Protected Attributes inherited from FuelCellShop::Layer::BaseLayer< dim > | |
const std::string | name |
Name of the layer. More... | |
std::vector< unsigned int > | material_ids |
List of material IDs that belong to the layer. More... | |
std::vector< Point< dim > > | point |
Coordinates of the point where we would like to compute the effective properties. More... | |
std::vector< VariableNames > | derivative_flags |
Flags for derivatives: These flags are used to request derivatives. More... | |
std::map< VariableNames, double > | constant_solutions |
Map storing values of solution variables constant in a particular application. More... | |
This class is used to represent a solid layer.
It takes only two arguments from the input file, the material ID and the material name representing the mesh element number for the layer and the type of material you would like the layer to return the properties for respectively. Then, it creates a child object of PureSolid of the desired type and uses it to compute all properties such as thermal conductivity.
This class is to compute the material properties at each quadrature points base on the PureSolid class
The input parameter section for this class looks like:
*
//Create an object of SolidLayer FuelCellShop::TemplateClass example; // Set necessary variables temp = 358; example.set_variable(temp); // You can now request info from your class. double temp = example.get_variable(); //Print to screen all properties example.print_data();
|
protected |
Constructor.
|
protected |
Destructor.
|
protectedvirtual |
Function used to select the appropriate SolidLayer type as specified in the ParameterHandler under line.
current options are see FuelCellShop::Material::PureSolid
The class will read the appropriate section in the parameter file, i.e. the one with name
gld_section_name,create | an object of the desired type and return it. |
Reimplemented from FuelCellShop::Layer::BaseLayer< dim >.
|
virtual |
Compute the derivative of the effective electron conductivity in the SolidLayer with respect to temperature solutionvariable.
The map will contain the VariableNames and the derivative.
|
virtual |
Compute the derivative of the effective electron conductivity in the SolidLayer with respect to temperature solutionvariable.
The map will contain the VariableNames and the derivative.
|
virtual |
Compute the derivative of the effective thermal conductivity in the SolidLayer with respect to temperature solutionvariable.
|
virtual |
Compute the derivative of the effective thermal conductivity in the SolidLayer with respect to temperature solutionvariable.
|
virtual |
Compute the effective electron conductivity in the SolidLayer.
This class is used for both isotropic and anisotropic materials.
|
virtual |
Compute the effective electron conductivity in the SolidLayer This class is used for both isotropic and anisotropic materials.
It will return the conductivity at each quadrature point based on the the solution provided in set_solution()
|
virtual |
Compute the effective thermal conductivity in the SolidLayer.
|
virtual |
Compute the effective thermal conductivity in the SolidLayer, dependent on various solution variables, eg: Temperature.
Note it is a vector because it returns the solution at each quadrature point using set_solution to obtain the solution at each location
|
inlinevirtual |
This member function returns a type_info object with the name of the base layer type the inherited class belongs to, i.e.
Note that this is necessary if we want to find out not the name of the actual class which can be obtain using
but the name of the parent class.
Reimplemented from FuelCellShop::Layer::BaseLayer< dim >.
|
protectedvirtual |
Member function used to read in data and initialize the necessary data to compute the coefficients.
Reimplemented from FuelCellShop::Layer::BaseLayer< dim >.
|
inline |
Member function used to set the solution [Kelvin
] at every quadrature point inside the cell.
This function should particulary be used in the case of whether the solution solutionvariable is right or wrong.
|
protected |
Boundary ids.
|
protected |
Name in the input file used to select the material.
|
protected |
Data member that stores the solid material the layer is made of.
|
protected |
|
protected |
Solutions at every quadrature point inside the cell.
for this mapping key is the Enumerator of VariableName_of_REV the mapped value is of type SolutionVariable
|
protected |
Solution Varaible at each quadrature point.
|
protected |