OpenFCST: The open-source Fuel Cell Simulation Toolbox
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
List of all members
FuelCellShop::MicroScale::HOPSD< dim > Class Template Reference

Hydrophobic Pore Size Distribution. More...

#include <PSD_HO.h>

Inheritance diagram for FuelCellShop::MicroScale::HOPSD< dim >:
Inheritance graph
[legend]
Collaboration diagram for FuelCellShop::MicroScale::HOPSD< dim >:
Collaboration graph
[legend]

Public Member Functions

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 Hydrophobic saturated_permeability by using PSD. More...
 
virtual void get_pore_HO_liquid_saturated_permeability (std::vector< double > &saturated_HO_permeability) const
 This function is used to compute the Hydrophobic liquid_permeability by using PSD. More...
 
virtual void get_relative_liquid_permeability (std::vector< double > &liquid_permeability) const
 This function is used to compute the Hydrophobic liquid_permeability by using PSD. More...
 
virtual void get_pore_HO_gas_saturated_permeability (std::vector< double > &saturated_HO_permeability) const
 This function is used to compute the Hydrophobic gas_permeability by using PSD. More...
 
virtual void get_relative_gas_permeability (std::vector< double > &gas_permeability) const
 This function is used to compute the Hydrophobic gas_permeability by using PSD. More...
 
virtual void get_liquid_gas_interfacial_surface (std::vector< double > &HO_liquid_gas_interfacial_surface) const
 This function is used to compute the Hydrophobic liquid_gas_interfacial_surface by using PSD. More...
 
virtual void get_pore_HO_wetted_wall_surface_area (std::vector< double > &HO_wetted_wall_surface_area) const
 This function is used to compute the Hydrophobic pore_wetted_wall 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 Hydrophobic pore_wetted_wall by using PSD. More...
 
virtual void get_pore_knudsen_radius_C2 (std::vector< double > &knudsen_radius_C2) const
 This function is used to compute the Hydrophobic knudsen_radius C2 by using PSD. More...
 
virtual void get_pore_knudsen_radius_C4 (std::vector< double > &knudsen_radius_C4) const
 This function is used to compute the Hydrophobic knudsen_radius C4 by using PSD. More...
 
virtual void get_knudsen_radius (std::vector< double > &knudsen_radius) const
 This function is used to compute the Hydrophobic knudsen_radius by using PSD. More...
 
virtual void get_diffusivity () const
 This function is used to compute the diffusivity by using PSD. More...
 
virtual void get_critical_radius (std::vector< double > &dst) const
 This function is used to compute the diffusivity by using PSD. More...
 
virtual const double get_maximum_cross_sectional_areas () const
 
- 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...
 

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 &param) const
 Declare parameters for a parameter file. More...
 
void initialize (ParameterHandler &param)
 Member function used to read in data and initialize the necessary data to compute the coefficients. More...
 

Protected Attributes

Psd properties
std::vector< double > fHO_k
 The f_k is the contribution of the log-normal distribution k to the total PSD. More...
 
std::vector< double > rHO_k
 The r_k is the characteristic pore size of the distribution k. More...
 
std::vector< double > sHO_k
 The s_k is the spread of the distribution k. 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...
 
double pressure_c
 Constant capillary pressure only for unit_test use. More...
 
std::vector< double > critical_radius_computed
 Critical_radius_computed by the get_critical_radius function. More...
 
bool critical_radius_is_initialized
 Check if the critical radius has already been computed by set_critical_radius function. More...
 
std::vector< double > saturation_computed
 Saturation_computed by the get_critical_radius function. More...
 
bool saturation_is_initialized
 Check if the saturation has already been computed by set_saturation function. More...
 
- Protected Attributes inherited from FuelCellShop::MicroScale::BasePSD< dim >
const std::string name
 Name of the psd. More...
 
std::vector< VariableNamesderivative_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 HOPSD< dim > const * PROTOTYPE
 PROTOTYPE is the pointer is the dynamic pointer pointing to the HOPSD class itself. More...
 

Constructor,Initalization, Declarations

static const std::string concrete_name
 Concrete name used for objects of this class. More...
 
 HOPSD ()
 Constructor. More...
 
 HOPSD (std::string name)
 Constructor. More...
 
virtual ~HOPSD ()
 Destructor. More...
 
void initialize (ParameterHandler &param)
 Member function used to read in data and initialize the necessary data to compute the coefficients. More...
 
void declare_parameters (ParameterHandler &param) const
 Declare all necessary parameters in order 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...
 

Additional Inherited Members

- Static Public Member Functions inherited from FuelCellShop::MicroScale::BasePSD< dim >
static void declare_PSD_parameters (ParameterHandler &param)
 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 &param)
 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 _mapFactoryget_mapFactory ()
 Return the map library that stores all childrens of this class. More...
 

Detailed Description

template<int dim>
class FuelCellShop::MicroScale::HOPSD< dim >

Hydrophobic 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.

Input parameters

The input parameters for this class are:Mode probability global, Mode characteristic radius global, Mode width global, Volume fraction Hydrophobic,

* subsection PSD parameters
* subsection BasePSD
* set psd type = HOPSD
* set Mode probability global = 0.72, 0.28
* set Mode characteristic radius global = 34.0, 14.2
* set Mode width global = 0.35, 1.0
* set Gamma = 0.24
* set contact_angle = 1.396
* set lamda = 1.0
* set probability P_b = 1
* subsection HIPSD
* set Hydrophobic Mode probability global = 0.72, 0.28
* set Hydrophobic Mode characteristic radius global = 34.0, 14.2
* set Hydrophobic Mode width global = 0.35, 1.0
* end
* end
* end
*

Usage details

If you want to use the object of the HOPSD, use the following code, but you should not create an object of the HOPSD out of the PSD scope. If you want to use the PSD in the layer level, use the code in BasePSD.

* //Create an object of TemplateClass
*

References

[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

Author
J. Zhou

Marc Secanell

Date
2014

Constructor & Destructor Documentation

template<int dim>
FuelCellShop::MicroScale::HOPSD< dim >::HOPSD ( )

Constructor.

Warning
For internal use only.

Constructor used only to create a prototype. Do not use in general since this will not include the name of the section in the parameter file you need.

template<int dim>
FuelCellShop::MicroScale::HOPSD< dim >::HOPSD ( std::string  name)

Constructor.

template<int dim>
virtual FuelCellShop::MicroScale::HOPSD< dim >::~HOPSD ( )
virtual

Destructor.

Member Function Documentation

template<int dim>
virtual boost::shared_ptr<FuelCellShop::MicroScale::BasePSD <dim> > FuelCellShop::MicroScale::HOPSD< dim >::create_replica ( const std::string &  psd_section_name)
inlineprotectedvirtual

This member function is used to create an object of type psd.

Warning
This class MUST be redeclared in every child.

Reimplemented from FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::declare_parameters ( ParameterHandler &  param) const

Declare all necessary parameters in order to compute the coefficients.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_critical_radius ( std::vector< double > &  dst) const
virtual

This function is used to compute the diffusivity by using PSD.

Note
the p_c is the capillary pressure which is one of the solution variable in the equation liquid water therefore we need to use set_capillary function to compute the p_c at each quatrature points Units of the critical_radius is in $ r_c \quad \left[ um \right] $ and the capillary pressure imposed by the solution is $ P_c \quad \left[ Pascal \right] $
template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_diffusivity ( ) const
virtual

This function is used to compute the diffusivity by using PSD.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_global_saturated_permeability ( double &  saturated_permeability) const
virtual

This function is used to compute the Hydrophobic saturated_permeability by using PSD.

$ k_{sat} = \frac{1}{8}\left[\frac{\varepsilon_{o}}{\lambda}\right]^{2} \sum_{k} \,\exp{(-2\,s_{k}^{2})}\,r_{k}^{2}f_{k} $

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_knudsen_radius ( std::vector< double > &  knudsen_radius) const
virtual

This function is used to compute the Hydrophobic knudsen_radius by using PSD.

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_liquid_gas_interfacial_surface ( std::vector< double > &  HO_liquid_gas_interfacial_surface) const
virtual

This function is used to compute the Hydrophobic liquid_gas_interfacial_surface by using PSD.

$ \frac{a(r)_{HO}}{V_{T}} = \frac{a(r)_{c}}{a_{T}} \left( 1 - \frac{a(r)_{c}}{a_{T}}\right)\, F_{HO}\sum_{k}\frac{f_{k,HO}\exp{\left(\frac{s_{k,HO}^{2}}{2} \right)}}{8\,r_{k,HO}} \left[1 - \text{erf}\left(\frac{\text{ln}(r_{cr}) - \text{ln}(r_{k,HO})}{s_{k,HO}\sqrt{2}} + \frac{s_{k,HO}\sqrt{2}}{2} \right) \right] $

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual const double FuelCellShop::MicroScale::HOPSD< dim >::get_maximum_cross_sectional_areas ( ) const
virtual
template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_pore_HO_gas_saturated_permeability ( std::vector< double > &  saturated_HO_permeability) const
virtual

This function is used to compute the Hydrophobic gas_permeability by using PSD.

$ k_{G,HO} = \frac{F_{HO}}{16}\left[\frac{\varepsilon_{o}\,\left(1 - S_{e}\right)}{\lambda}\right]^{2}\sum_{k} \,\exp{(-2\,s_{HO,k}^{2})}\,r_{HO,k}^{2}f_{HO,k} \left[\text{erf}\left(\frac{\ln{(r_{c,HO})} - \ln{(r_{HO,k})}}{s_{HO,k}\sqrt{2}} - s_{HO,k}\sqrt{2} \right) + 1 \right] $

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_pore_HO_liquid_saturated_permeability ( std::vector< double > &  saturated_HO_permeability) const
virtual

This function is used to compute the Hydrophobic liquid_permeability by using PSD.

$ k_{L,HO} = \frac{F_{HO}}{16}\left[\frac{\varepsilon_{o}\,S_{e}}{\lambda}\right]^{2}\sum_{k} \,\exp{(-2\,s_{HO,k}^{2})}\,r_{HO,k}^{2}f_{HO,k} \left[-\text{erf}\left(\frac{\ln{(r_{c,HO})} - \ln{(r_{HO,k})}}{s_{HO,k}\sqrt{2}} - s_{HO,k}\sqrt{2} \right) + 1 \right] $

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_pore_HO_wetted_wall_surface_area ( std::vector< double > &  HO_wetted_wall_surface_area) const
virtual

This function is used to compute the Hydrophobic pore_wetted_wall by using PSD.

$ a_{wall,HO} = \sum_{k} \frac{F_{HO}\,f_{k,HO}}{r_{k,HO}}\text{exp}\left(\frac{s_{k,HO}^{2}}{2} \right) \left[ 1 - \text{erf} \left( \frac{\text{ln}(r_{c,HO}) - \text{ln}(r_{k,HO})}{s_{k,HO}\sqrt{2}} + \frac{s_{k,HO}}{\sqrt{2}} \right) \right] $

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_pore_knudsen_radius_C2 ( std::vector< double > &  knudsen_radius_C2) const
virtual

This function is used to compute the Hydrophobic knudsen_radius C2 by using PSD.

$ C_{2} = F_{HO} \sum_{k} \frac{f_{HO,k}}{2} \left[1 + \text{erf}\left(\frac{\text{ln}(r_{c,HO}) - \text{ln}(r_{HO,k})}{s_{HO,k}\sqrt{2}} \right) \right] $

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_pore_knudsen_radius_C4 ( std::vector< double > &  knudsen_radius_C4) const
virtual

This function is used to compute the Hydrophobic knudsen_radius C4 by using PSD.

$ C_{4} = \sum_{k} \frac{F_{HO}\,f_{k,HO}}{r_{k,HO}}\text{exp}\left(\frac{s_{k,HO}^{2}}{2} \right) \left[ 1 + \text{erf} \left( \frac{\text{ln}(r_{c,HO}) - \text{ln}(r_{k,HO})}{s_{k,HO}\sqrt{2}} + \frac{s_{k,HO}}{\sqrt{2}} \right) \right] $

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_relative_gas_permeability ( std::vector< double > &  gas_permeability) const
virtual

This function is used to compute the Hydrophobic gas_permeability by using PSD.

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_relative_liquid_permeability ( std::vector< double > &  liquid_permeability) const
virtual

This function is used to compute the Hydrophobic liquid_permeability by using PSD.

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_saturation ( std::vector< double > &  S) const
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.

$ S_{HO} = F_{HO}\sum_{k} \frac{f_{HO,k}}{2} \left[1 - \text{erf}\left(\frac{\text{ln}(r_{c,HO}) - \text{ln}(r_{HO,k})}{s_{HO,k}\sqrt{2}} \right) \right] $

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
virtual void FuelCellShop::MicroScale::HOPSD< dim >::get_wetted_wall_surface_area ( std::vector< double > &  wetted_wall_surface_area) const
virtual

This function is used to compute the Hydrophobic pore_wetted_wall by using PSD.

Implements FuelCellShop::MicroScale::BasePSD< dim >.

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::initialize ( ParameterHandler &  param)

Member function used to read in data and initialize the necessary data to compute the coefficients.

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::set_capillary_pressure ( const SolutionVariable C_in)
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().

Here is the call graph for this function:

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::set_critical_radius ( )
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 time to reduce the computational time.

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::set_saturation ( )
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 time to reduce the computational time.

template<int dim>
void FuelCellShop::MicroScale::HOPSD< dim >::set_temperature ( const SolutionVariable T_in)
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.

Here is the call graph for this function:

Member Data Documentation

template<int dim>
SolutionVariable FuelCellShop::MicroScale::HOPSD< dim >::Capillary_pressure_vector
protected

Capillary pressure at every quadrature point inside the cell.

template<int dim>
const std::string FuelCellShop::MicroScale::HOPSD< dim >::concrete_name
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

* subsection name_specified_in_constructor
* set psd type = HOPSD # <-here I select the type of object of type psd
* subsection HOPSD # <- this is the concrete_name for this class
* set all info relevant to this object
* end
* end
*
template<int dim>
std::vector<double> FuelCellShop::MicroScale::HOPSD< dim >::critical_radius_computed
protected

Critical_radius_computed by the get_critical_radius function.

template<int dim>
bool FuelCellShop::MicroScale::HOPSD< dim >::critical_radius_is_initialized
protected

Check if the critical radius has already been computed by set_critical_radius function.

It has to be reset each time when the solution variable capillary pressure is updated

template<int dim>
std::vector<double> FuelCellShop::MicroScale::HOPSD< dim >::fHO_k
protected

The f_k is the contribution of the log-normal distribution k to the total PSD.

template<int dim>
double FuelCellShop::MicroScale::HOPSD< dim >::pressure_c
protected

Constant capillary pressure only for unit_test use.

template<int dim>
HOPSD<dim> const* FuelCellShop::MicroScale::HOPSD< dim >::PROTOTYPE
staticprotected

PROTOTYPE is the pointer is the dynamic pointer pointing to the HOPSD class itself.

template<int dim>
std::vector<double> FuelCellShop::MicroScale::HOPSD< dim >::rHO_k
protected

The r_k is the characteristic pore size of the distribution k.

template<int dim>
std::vector<double> FuelCellShop::MicroScale::HOPSD< dim >::saturation_computed
protected

Saturation_computed by the get_critical_radius function.

template<int dim>
bool FuelCellShop::MicroScale::HOPSD< dim >::saturation_is_initialized
protected

Check if the saturation has already been computed by set_saturation function.

It has to be reset each time when the solution variable capillary pressure is updated

template<int dim>
std::vector<double> FuelCellShop::MicroScale::HOPSD< dim >::sHO_k
protected

The s_k is the spread of the distribution k.

template<int dim>
SolutionVariable FuelCellShop::MicroScale::HOPSD< dim >::T_vector
protected

Temperature at every quadrature point inside the cell.


The documentation for this class was generated from the following file: