OpenFCST: The open-source Fuel Cell Simulation Toolbox
|
Class used to store data and provide information regarding the electrolyte. More...
#include <nafion.h>
Public Member Functions | |
Constructors, destructor, and parameter initalization | |
Nafion (const bool) | |
PROTOTYE Constructor. | |
Nafion (std::string name="Nafion") | |
Constructor The constructor initialize parameters using the default values. | |
~Nafion () | |
Destructor. | |
virtual void | declare_parameters (ParameterHandler ¶m) const |
Declare parameters. | |
virtual void | set_parameters (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. | |
virtual void | initialize (ParameterHandler ¶m) |
Member function used to read in data and initialize the necessary data from the parameter file to compute the coefficients. | |
Transport properties and derivatives accessor methods | |
virtual void | sorption_isotherm (std::vector< double > &) const |
Compute the equilibrium water content, \( \lambda_{eq} \), inside the Nafion for vapor-equilibriated case, at every quadrature point in the cell. | |
virtual void | sorption_isotherm_derivative (std::map< VariableNames, std::vector< double > > &) const |
Compute the derivatives for water sorption source terms, \( \frac{\partial \lambda_{eq}}{\partial u} \), at every quadrature point in the cell. | |
virtual void | proton_conductivity (double &) const |
Compute the proton conductivity, \( \sigma_{H^+} \) [S/cm ], inside the nafion for a case of constant \( \lambda \) and \( T \). | |
virtual void | proton_conductivity (std::vector< double > &) const |
Compute the proton conductivity, \( \sigma_{H^+} \) [S/cm ], inside the nafion, at every quadrature point in the cell. | |
virtual void | proton_conductivity_derivative (std::map< VariableNames, std::vector< double > > &) const |
Compute the derivatives of proton conductivity at every quadrature point in the cell. | |
virtual void | water_diffusivity (double &) const |
Compute the water diffusivity, \( D_{\lambda} \) [cm^2/s ], inside the nafion for a case of constant \( \lambda \) and \( T \). | |
virtual void | water_diffusivity (std::vector< double > &) const |
Compute the water diffusivity, \( D_{\lambda} \) [cm^2/s ], inside the nafion at every quadrature point in the cell. | |
virtual void | water_diffusivity_derivative (std::map< VariableNames, std::vector< double > > &) const |
Compute the derivatives of water diffusivity at every quadrature point in the cell. | |
virtual void | electroosmotic_drag (std::vector< double > &) const |
Compute the electro-osmotic drag coefficient inside the nafion at every quadrature point in the cell. | |
virtual void | electroosmotic_drag_derivative (std::map< VariableNames, std::vector< double > > &) const |
Compute the derivatives of electro-osmotic drag coefficient, at every quadrature point in the cell. | |
virtual void | oxygen_diffusivity (double &) const |
Compute the oxygen diffusivity, [cm^2/s ], inside the nafion for a constant \( T \). | |
virtual void | oxygen_diffusivity (std::vector< double > &) const |
Compute the oxygen diffusivity, [cm^2/s ], inside the nafion at every quadrature point in the cell. | |
virtual void | oxygen_diffusivity_derivative (std::map< VariableNames, std::vector< double > > &) const |
Compute the derivatives of oxygen diffusivity, at every quadrature point in the cell. | |
virtual void | proton_diffusivity (double &) const |
Compute the proton diffusivity, [cm^2/s ], inside the nafion for constant case. | |
Public Member Functions inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
double | get_density () const |
Get the density [gm/cm^3 ] of the dry polymer electrolyte material. | |
double | get_H_O2 () const |
Get Henry's constant [Pa-cm^3/mol ] for oxygen dissolution in the polymer electrolyte. | |
double | get_H_H2 () const |
Get Henry's constant [Pa-cm^3/mol ] for hydrogen dissolution in the polymer electrolyte. | |
double | get_EW () const |
Get Equivalent Weight (grams of dry polymer electrolyte per moles of \( SO_3^- \)) of the polymer electrolyte material. | |
double | get_permittivity () const |
Get permittivity of the polymer electrolyte material. | |
void | set_p_t (const double &p_t) |
Specify the total pressure in Pascals. | |
void | set_T (const double &Temp) |
Specify the temperature [Kelvin ] in the polymer electrolyte for isothermal case. | |
void | set_lambda (const double &L) |
Specify the water content in the polymer electrolyte for constant lambda case. | |
void | set_membrane_water_content (const FuelCellShop::SolutionVariable &l_in) |
Set the solution variable, membrane water content \( \lambda \). | |
void | set_temperature (const FuelCellShop::SolutionVariable &T_in) |
Set the solution variable, temperature \( T \) [Kelvin ]. | |
void | set_water_molar_fraction (const FuelCellShop::SolutionVariable &x_in) |
Set the solution variable, water vapor molar fraction \( x_{H_2O} \). | |
Public Member Functions inherited from FuelCellShop::Material::BaseMaterial | |
void | set_derivative_flags (const std::vector< VariableNames > &flags) |
Set the variables for which you would like to compute the derivatives. | |
const std::string & | name_material () |
Return the name of the layer. | |
virtual void | print_material_properties () const |
This function prints out the material properties. | |
Static Public Attributes | |
static const std::string | concrete_name |
Name of the class. | |
Private Member Functions | |
void | modify_parameters (const unsigned int &index, const std::string &method) |
Method to modify parameters, without declaring and initializing the parameter file. | |
Friends | |
Friend class for Unit Testing | |
class | ::NafionTest |
Friend class for testing purposes. | |
Instance Delivery | |
static Nafion const * | PROTOTYPE |
Create prototype for the layer. | |
virtual boost::shared_ptr < FuelCellShop::Material::PolymerElectrolyteBase > | create_replica () |
This member function is used to create an object of type Nafion material. | |
Additional Inherited Members | |
Static Public Member Functions inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
static void | declare_PolymerElectrolyte_parameters (ParameterHandler ¶m) |
Function used to declare all the data necessary in the parameter files for all PolymerElectrolyteBase children. | |
static void | set_PolymerElectrolyte_parameters (const std::vector< std::string > &name_dvar, const std::vector< double > &value_dvar, ParameterHandler ¶m) |
static boost::shared_ptr < FuelCellShop::Material::PolymerElectrolyteBase > | create_PolymerElectrolyte (ParameterHandler ¶m, std::string polymer_electrolyte_name) |
Function called in create_CatalystLayer and used to select the appropriate PolymerElectrolyteBase children that will be used in the layer. | |
Protected Types inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
typedef std::map< std::string, FuelCellShop::Material::PolymerElectrolyteBase * > | _mapFactory |
This object is used to store all objects of type PolymerElectrolyteBase. | |
Protected Member Functions inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
PolymerElectrolyteBase (std::string name) | |
Constructor. | |
PolymerElectrolyteBase () | |
Constructor. | |
virtual | ~PolymerElectrolyteBase () |
Destructor. | |
Static Protected Member Functions inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
static _mapFactory * | get_mapFactory () |
Protected Attributes inherited from FuelCellShop::Material::PolymerElectrolyteBase | |
double | EW |
Equivalent weight. | |
double | rho_M |
Dry polymer electrolyte density [gm/cm^3 ]. | |
double | H_O2 |
Henry's Constant [Pa-cm^3/mol ] for dissolution of oxygen. | |
double | H_H2 |
Henry's Constant [Pa-cm^3/mol ] for dissolution of hydroge. | |
double | permittivity |
Permittivity of the material. | |
double | T |
Temperature [Kelvins ] for isothermal case. | |
double | lambda |
Membrane water content, \( \lambda \) for constant lambda case. | |
double | p_total |
Total pressure (in Pascals). | |
double | sigma_p |
Proton conductivity value [S/cm ], given in the parameter file; used with "Constant" method. | |
double | diffusion_w |
Diffusion of water in polymer electrolyte (if constant option is used), [cm2/s ]. | |
double | given_n_drag |
Given electroosmotic drag value in the parameter file. | |
double | D_O2 |
Diffusion coefficient of oxygen [cm^2/s ], given in the parameter file. | |
double | D_Protons |
Diffusion coefficient of protons [cm^2/s ], given in the parameter file. | |
std::string | method_conductivity |
Method/Semi-empirical relation to compute protonic conductivity. | |
std::string | method_sorption |
Method to compute equilibrium water content value from sorption isotherm. | |
std::string | method_diffusivity |
Method/semi-empirical relation to compute water diffusivity. | |
std::string | method_electroosmotic_drag |
Method/semi-empirical relation to compute Electro-osmotic drag. | |
FuelCellShop::SolutionVariable | lambda_var |
Solution variable, membrane water content \( \lambda \). | |
FuelCellShop::SolutionVariable | T_var |
Solution variable, temperature \( T \). | |
FuelCellShop::SolutionVariable | xwater_var |
Solution variable, water vapor molar fraction \( x_{H_2O} \). | |
Class used to store data and provide information regarding the electrolyte.
In this case the electrolyte that is setup is Nafion. In particular the data coded in this class is obtained from the literature from Nafion 1100, usually from NRE 211 properties.
Literature sources are:
(Madhur please fill this part – Add references to each section too.)
In the parameter file the following parameters can be specified within the subsections specified below:
As with most routines you need to first declare_parameters, then set_parameters (only if using optimization/parameter estimation), then initialize. After this the class is ready for use.
See for example FuelCell::OperatingConditions class for more details.
FuelCellShop::Material::Nafion::Nafion | ( | const bool | ) |
PROTOTYE Constructor.
FuelCellShop::Material::Nafion::Nafion | ( | std::string | name = "Nafion" | ) |
Constructor The constructor initialize parameters using the default values.
This is so that if I do not want to call declare_parameters and initialize, I can still use the routine with the hard coded values.
FuelCellShop::Material::Nafion::~Nafion | ( | ) |
Destructor.
|
inlineprivatevirtual |
This member function is used to create an object of type Nafion material.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Declare parameters.
In the parameter file the following parameters can be specified within the subsections specified below:
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the electro-osmotic drag coefficient inside the nafion at every quadrature point in the cell.
It takes vector as an input argument and values are passed by reference. Note that the double return method is not implemented for electro-osmotic drag coefficients because it is required only when \( \lambda \) is one of the solution variables in the application. set_membrane_water_content should be called before using this method.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the derivatives of electro-osmotic drag coefficient, at every quadrature point in the cell.
The derivatives are computed based on the flags set by the set_derivative_flags method. It takes map as an input argument by reference, in which Key
corresponds to the variable about which derivative is being computed, i.e., VariableNames and Value
corresponds to the vector storing the derivative values. set_membrane_water_content should be called before using this method. Also, this method should only be called when atleast there is one derivative flag.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Member function used to read in data and initialize the necessary data from the parameter file to compute the coefficients.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
inlineprivate |
Method to modify parameters, without declaring and initializing the parameter file.
It takes two arguments, first one (unsigned int) corresponds to a particular type of method and second one (std::string) corresponds to various implementations for that method type. index corresponds to following methods:
References FuelCellShop::Material::PolymerElectrolyteBase::method_conductivity, FuelCellShop::Material::PolymerElectrolyteBase::method_diffusivity, FuelCellShop::Material::PolymerElectrolyteBase::method_electroosmotic_drag, and FuelCellShop::Material::PolymerElectrolyteBase::method_sorption.
|
virtual |
Compute the oxygen diffusivity, [cm^2/s
], inside the nafion for a constant \( T \).
Before calling this method, set_T method should be used for setting the constant temperature value. It takes a double as an input argument and value is passed by reference.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the oxygen diffusivity, [cm^2/s
], inside the nafion at every quadrature point in the cell.
It takes vector as an input argument and values are passed by reference. set_temperature should be called before using this method.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the derivatives of oxygen diffusivity, at every quadrature point in the cell.
The derivatives are computed based on the flags set by the set_derivative_flags method. It takes map as an input argument by reference, in which Key
corresponds to the variable about which derivative is being computed, i.e., VariableNames and Value
corresponds to the vector storing the derivative values. set_temperature should be called before using this method. Also, this method should only be called when atleast there is one derivative flag.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the proton conductivity, \( \sigma_{H^+} \) [S/cm
], inside the nafion for a case of constant \( \lambda \) and \( T \).
Before calling this method, set_T method should be used for setting the constant temperature value. If the constant \( \lambda \) value is required to be different from the default value 12.0, then set_lambda method should be used. It takes a double as an input argument and value is passed by reference.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the proton conductivity, \( \sigma_{H^+} \) [S/cm
], inside the nafion, at every quadrature point in the cell.
It is computed as a function of \( \lambda \) and \( T \), hence solution setting methods should be called accordingly for them, whether constant or variable. It is recommended to set the constant ones in the initialization of the application, unless you are solving for multi-scale model. It takes vector as an input argument and values are passed by reference.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the derivatives of proton conductivity at every quadrature point in the cell.
The derivatives are computed based on the flags set by the set_derivative_flags method. It takes map as an input argument by reference, in which Key
corresponds to the variable about which derivative is being computed, i.e., VariableNames and Value
corresponds to the vector storing the derivative values. Note that this method should not be used when both \( \lambda \) and \( T \) are constant. Hence, atleast set_membrane_water_content or set_temperature should be called before using this method. Also, this method should only be called when atleast there is one derivative flag.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the proton diffusivity, [cm^2/s
], inside the nafion for constant case.
It takes a double as an input argument and value is passed by reference. It basically returns a constant value specified using the parameter file.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Member function used to change the values in the parameter file for a given list of parameters.
name_dvar
should ideally contain the string as it would appear in the input parameter file.value_dvar
contains the value that the variable should be set at.param
is the ParameterHandler that contains all the information that has been read from file.List of available std::string that can be changed, i.e. name_dvar are
given below:
S/cm
] of Nafion.cm^2/s
] of Nafion.cm^2/s
] of Nafion.Pa-cm^3/mol
].Pa-cm^3/mol
].Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the equilibrium water content, \( \lambda_{eq} \), inside the Nafion for vapor-equilibriated case, at every quadrature point in the cell.
It takes a vector as an input argument and values are passed by reference. It is required to call set_water_molar_fraction method atleast before computing sorption isotherm values.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the derivatives for water sorption source terms, \( \frac{\partial \lambda_{eq}}{\partial u} \), at every quadrature point in the cell.
The derivatives are computed based on the flags set by the set_derivative_flags method. It takes map as an input argument by reference, in which Key
corresponds to the variable about which derivative is being computed, i.e., VariableNames and Value
corresponds to the vector storing the derivative values. It is required to call set_water_molar_fraction method atleast before computing sorption isotherm values. Also, this method should only be called when atleast there is one derivative flag.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the water diffusivity, \( D_{\lambda} \) [cm^2/s
], inside the nafion for a case of constant \( \lambda \) and \( T \).
Before calling this method, set_T method should be used for setting the constant temperature value. If the constant \( \lambda \) value is required to be different from the default value 12.0, then set_lambda method should be used. It takes a double as an input argument and value is passed by reference.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the water diffusivity, \( D_{\lambda} \) [cm^2/s
], inside the nafion at every quadrature point in the cell.
It is computed as a function of \( \lambda \) and \( T \), hence solution setting methods should be called accordingly for them, whether constant or variable. It is recommended to set the constant ones in the initialization of the application. Note that this method should not be used when both \( \lambda \) and \( T \) are constant. Hence, atleast set_membrane_water_content or set_temperature should be called before using this method. It takes vector as an input argument and values are passed by reference.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
virtual |
Compute the derivatives of water diffusivity at every quadrature point in the cell.
The derivatives are computed based on the flags set by the set_derivative_flags method. It takes map as an input argument by reference, in which Key
corresponds to the variable about which derivative is being computed, i.e., VariableNames and Value
corresponds to the vector storing the derivative values. Note that this method should not be used when both \( \lambda \) and \( T \) are constant. Hence, atleast set_membrane_water_content or set_temperature should be called before using this method. Also, this method should only be called when atleast there is one derivative flag.
Reimplemented from FuelCellShop::Material::PolymerElectrolyteBase.
|
friend |
Friend class for testing purposes.
|
static |
Name of the class.
This name is used to select the layer.
|
staticprivate |
Create prototype for the layer.