OpenFCST: The open-source Fuel Cell Simulation Toolbox
|
Dual Pore Size Distribution. More...
#include <PSD_dual.h>
Public Member Functions | |
Constructors, declarations and Initalization | |
DualPSD () | |
Consturctor. More... | |
DualPSD (std::string name) | |
Constructor. More... | |
virtual | ~DualPSD () |
Destructor. More... | |
void | declare_parameters (ParameterHandler ¶m) const |
Declare parameters for a parameter file. More... | |
void | initialize (ParameterHandler ¶m) |
Member function used to read in data and initialize the necessary data to compute the coefficients. More... | |
void | set_temperature (const SolutionVariable &T_in) |
Member function used to set the temperature [Kelvin ] at every quadrature point inside the cell. More... | |
void | set_capillary_pressure (const SolutionVariable &C_in) |
Member function used to set the capillary pressure [psi ] at every quadrature point inside the cell. More... | |
void | set_critical_radius () |
Member function used to set the critical radius [nm ] at every quadrature point inside the cell. More... | |
void | set_saturation () |
Member function used to set the saturation at every quadrature point inside the cell. More... | |
Accessors and info | |
virtual void | get_saturation (std::vector< double > &S) const |
This function is used to compute the saturation by using PSD The saturation iof a porous medium can be obtained by integrating the change of cumulative pore volume fraction as a function of effective pore radius over the whole pore size domain. More... | |
virtual void | get_global_saturated_permeability (double &saturated_permeability) const |
This function is used to compute the saturated_permeability by using PSD. More... | |
virtual void | get_relative_liquid_permeability (std::vector< double > &liquid_permeability) const |
This function is used to compute the liquid_permeability by using PSD. More... | |
virtual void | get_relative_gas_permeability (std::vector< double > &gas_permeability) const |
This function is used to compute the gas_permeability by using PSD. More... | |
virtual void | get_liquid_gas_interfacial_surface (std::vector< double > &liquid_gas_interfacial_surface) const |
This function is used to compute the liquid_gas_interfacial_surface by using PSD. More... | |
virtual void | get_wetted_wall_surface_area (std::vector< double > &wetted_wall_surface_area) const |
This function is used to compute the pore_wetted_wall by using PSD. More... | |
virtual void | get_knudsen_radius (std::vector< double > &knudsen_radius) const |
This function is used to compute the knudsen_radius by using PSD. More... | |
virtual void | get_diffusivity () const |
This function is used to compute the diffusivity by using PSD. More... | |
virtual const double | get_critical_radius (double &p_c) const |
This function is used to compute the critical radius. More... | |
virtual void | get_critical_radius (std::vector< double > &dst) const |
This function is used to compute the critical radius. More... | |
Public Member Functions inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
virtual | ~BasePSD () |
Destructor. More... | |
void | set_porosity (double porosity) |
double | get_porosity () const |
void | set_derivative_flags (const std::vector< VariableNames > &flags) |
Set the names of FCST solution variables with respect to which you would like to compute the derivatives of material properties. 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 psd depend on the solution, the solution for a given cell should be passed to the class using this member function. More... | |
const std::string & | name_psd () const |
Return the name of the PSD. More... | |
virtual void | print_psd_properties () const |
This function prints out the psd properties. More... | |
Static Public Attributes | |
concrete_name | |
static const std::string | concrete_name |
Concrete name used for objects of this class. More... | |
Protected Member Functions | |
Instance Delivery (Replica creator) | |
virtual boost::shared_ptr < FuelCellShop::MicroScale::BasePSD < dim > > | create_replica (const std::string &psd_section_name) |
This member function is used to create an object of type psd. More... | |
Protected Member Functions inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
BasePSD () | |
Constructor. More... | |
BasePSD (const std::string &name) | |
Constructor. More... | |
void | declare_parameters (ParameterHandler ¶m) const |
Declare parameters for a parameter file. More... | |
void | initialize (ParameterHandler ¶m) |
Member function used to read in data and initialize the necessary data to compute the coefficients. More... | |
Protected Attributes | |
PSD properties | |
HIPSD< dim > * | psd_hi |
Creating a pointer of PSD hydrophilic class. More... | |
HOPSD< dim > * | psd_ho |
Creating a pointer of PSD hydrophobic class. More... | |
SolutionVariable | T_vector |
Temperature at every quadrature point inside the cell. More... | |
SolutionVariable | Capillary_pressure_vector |
Capillary pressure at every quadrature point inside the cell. More... | |
Protected Attributes inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
const std::string | name |
Name of the psd. More... | |
std::vector< VariableNames > | derivative_flags |
Flags for derivatives: These flags are used to request derivatives of material properties. More... | |
std::map< VariableNames, double > | constant_solutions |
Map storing values of solution variables constant in a particular application. More... | |
double | gamma |
The gamma is the Water-air interface surface tension. More... | |
double | contact_angle |
The contact_angle is the contact angle between air and water. More... | |
double | lamda |
The lamda is measured from the mercury intrusion experiment. More... | |
double | P_b |
The effects of pore interconnectivity is represented by probability P_b. More... | |
double | F_HI |
The F_HI is the fraction of the total volume corresponding to the hydrophilic pores. More... | |
double | F_HO |
The F_HO is the fraction of the total volume corresponding to the hydrophobic pores. More... | |
std::vector< double > | f_k |
The f_k is the contribution of the log-normal distribution k to the total PSD. More... | |
std::vector< double > | r_k |
The r_k is the characteristic pore size of the distribution k. More... | |
std::vector< double > | s_k |
The s_k is the spread of the distribution k. More... | |
double | por |
The por is the porosity inherited from the layer class. More... | |
Static Protected Attributes | |
Instance Delivery (Prototype) | |
static DualPSD< dim > const * | PROTOTYPE |
PROTOTYPE is the pointer is the dynamic pointer pointing to the DualPSD class itself. More... | |
Additional Inherited Members | |
Static Public Member Functions inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
static void | declare_PSD_parameters (ParameterHandler ¶m) |
Function used to declare all the data necessary in the parameter files for all BasePSD children. More... | |
static boost::shared_ptr < FuelCellShop::MicroScale::BasePSD < dim > > | create_PSD (const std::string &psd_section_name, ParameterHandler ¶m) |
Function used to select the appropriate CatalystLayer type as specified in the ParameterHandler under line. More... | |
Protected Types inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
typedef std::map< std::string, BasePSD< dim > * > | _mapFactory |
This object is used to store all objects of type psd. More... | |
Static Protected Member Functions inherited from FuelCellShop::MicroScale::BasePSD< dim > | |
static _mapFactory * | get_mapFactory () |
Return the map library that stores all childrens of this class. More... | |
Dual Pore Size Distribution.
Based on the results of the mecury intrusion experiment, this class calculates the coefficients such as relative liquid permeability, permeability and knudsen radius...
This class is the child class of the all the BasePSD class which reimplements all the functions that are decleared in the BasePSD class.
The input parameters for this class are:Mode probability global, Mode characteristic radius global, Mode width global, Volume fraction Hydrophobic, Volume fraction Hydrophilic... All data below is from the Hydrophilic unit test
If you want to use the object of the DualPSD, use the following code, but you should not create an object of the DualPSD out of the PSD scope. If you want to use the PSD in the layer level, use the code in BasePSD.
[1] Pedro Abdiel Mateo Villanueva, A MIXED WETTABILITY PORE SIZE DISTRIBUTION MODEL FOR THE ANALYSIS OF WATER TRANSPORT IN PEMFC MATERIALS, M. Sc. thesis, University of Alberta, 2013
Marc Secanell
FuelCellShop::MicroScale::DualPSD< dim >::DualPSD | ( | ) |
Consturctor.
FuelCellShop::MicroScale::DualPSD< dim >::DualPSD | ( | std::string | name | ) |
Constructor.
|
virtual |
Destructor.
|
inlineprotectedvirtual |
This member function is used to create an object of type psd.
Reimplemented from FuelCellShop::MicroScale::BasePSD< dim >.
void FuelCellShop::MicroScale::DualPSD< dim >::declare_parameters | ( | ParameterHandler & | param | ) | const |
Declare parameters for a parameter file.
|
virtual |
This function is used to compute the critical radius.
|
virtual |
This function is used to compute the critical radius.
|
virtual |
This function is used to compute the diffusivity by using PSD.
|
virtual |
This function is used to compute the saturated_permeability by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the knudsen_radius by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the liquid_gas_interfacial_surface by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the gas_permeability by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the liquid_permeability by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the saturation by using PSD The saturation iof a porous medium can be obtained by integrating the change of cumulative pore volume fraction as a function of effective pore radius over the whole pore size domain.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
|
virtual |
This function is used to compute the pore_wetted_wall by using PSD.
Implements FuelCellShop::MicroScale::BasePSD< dim >.
void FuelCellShop::MicroScale::DualPSD< dim >::initialize | ( | ParameterHandler & | param | ) |
Member function used to read in data and initialize the necessary data to compute the coefficients.
|
inline |
Member function used to set the capillary pressure [psi
] at every quadrature point inside the cell.
This function should particulary be used in the case of non-isothermal application.
References capillary_pressure, and FuelCellShop::SolutionVariable::get_variablename().
|
inline |
Member function used to set the critical radius [nm
] at every quadrature point inside the cell.
This function should particulary be used in the case of non-isothermal application. It needs to be implemented at each iteration to reduce the computational time.
|
inline |
Member function used to set the saturation at every quadrature point inside the cell.
This function should particulary be used in the case of non-isothermal application. It needs to be implemented at each iteration to reduce the computational time.
|
inline |
Member function used to set the temperature [Kelvin
] at every quadrature point inside the cell.
This function should particulary be used in the case of non-isothermal application.
References FuelCellShop::SolutionVariable::get_variablename(), and temperature_of_REV.
|
protected |
Capillary pressure at every quadrature point inside the cell.
|
static |
Concrete name used for objects of this class.
This name is used when setting up the subsection where the data is stored in the input file.
The data will be store under
|
staticprotected |
PROTOTYPE is the pointer is the dynamic pointer pointing to the DualPSD class itself.
|
protected |
Creating a pointer of PSD hydrophilic class.
|
protected |
Creating a pointer of PSD hydrophobic class.
|
protected |
Temperature at every quadrature point inside the cell.