17 #ifndef _FUELCELLSHOP__REACTION_HEAT_H
18 #define _FUELCELLSHOP__REACTION_HEAT_H
26 #include <base/parameter_handler.h>
27 #include <base/point.h>
28 #include <base/function.h>
29 #include <lac/vector.h>
30 #include <fe/fe_values.h>
31 #include <deal.II/base/subscriptor.h>
38 using namespace dealii;
40 namespace FuelCellShop
148 derivative_flags = flags;
161 const bool& flag_irrev_HOR =
true,
162 const bool& flag_rev_heat =
true,
163 const double& rev_heat_ORR_coef = 1.0,
164 const bool& flag_single_phase_ORR =
true)
166 factor_irrev_ORR = flag_irrev_ORR ? -1.0 : 0.0;
167 factor_rev_ORR = flag_rev_heat ? ((-1.0*rev_heat_ORR_coef)/(2.0*
Constants::F())) : 0.0;
168 factor_vap_ORR = flag_single_phase_ORR ? ((-1.0)/(2.0*
Constants::F())) : 0.0;
170 factor_irrev_HOR = flag_irrev_HOR ? 1.0 : 0.0;
171 factor_rev_HOR = flag_rev_heat ? ((rev_heat_ORR_coef-1.0)/(2.0*
Constants::F())) : 0.0;
173 factors_initialized =
true;
183 void heat_source (std::vector<double>& heat,
184 const std::vector<double>& current)
const;
192 void derivative_heat_source (std::map<
VariableNames, std::vector<double> >& heat_derived,
193 const std::map<
VariableNames, std::vector<double> >& current_derived,
194 const std::vector<double>& current)
const;
221 double deltaS = ((8.0*(1.0+
log(Temp))) - 92.84) * 4.184;
228 double dDs_dT = (4.184*8.0)/Temp;
253 #endif //_FUELCELLSHOP__REACTION_HEAT_H
double factor_vap_ORR
Factor for water vaporization heat sink in ORR.
Definition: reaction_heat.h:245
SolutionVariable phi_s
Struct stroing a pointer to the solution vector for the electronic/solid potential.
Definition: reaction_heat.h:212
double F()
Faraday constant, .
Definition: fcst_constants.h:38
VariableNames get_variablename() const
Function to get the VariableNames enumeration corresponding to this struct.
Definition: fcst_variables.h:163
bool factors_initialized
Flag to check whether factors are initialized or not.
Definition: reaction_heat.h:248
VariableNames
The enumeration containing the names of some of the available FCST solution variables and their deriv...
Definition: system_management.h:62
This structure is used to encapsulate data from constant values and variable solution data that is us...
Definition: fcst_variables.h:86
Definition: system_management.h:70
double factor_rev_ORR
Factor for reversible heating in ORR.
Definition: reaction_heat.h:239
void set_electrolyte_potential(const SolutionVariable &phi)
Set the electrolyte phase potential.
Definition: reaction_heat.h:122
Definition: system_management.h:75
std::vector< VariableNames > derivative_flags
Flags for derivatives: These flags are used to request derivatives which are computed using the deriv...
Definition: reaction_heat.h:204
void set_kinetics(FuelCellShop::Kinetics::BaseKinetics *kin)
Function to set Kinetics for enabling calculation source terms.
Definition: reaction_heat.h:110
void set_temperature(const SolutionVariable &temperature)
Set temperature.
Definition: reaction_heat.h:138
SolutionVariable T
Struct stroing a pointer to the solution vector for the temperature.
Definition: reaction_heat.h:214
FCSTLogStream log
Object used to output data to file and, if file attached recorded to a file as well.
Virtual class used to provide the interface for all kinetic/reaction children.
Definition: base_kinetics.h:107
double factor_irrev_HOR
Factor for irreversible heating in HOR.
Definition: reaction_heat.h:236
void initialize_factors(const bool &flag_irrev_ORR=true, const bool &flag_irrev_HOR=true, const bool &flag_rev_heat=true, const double &rev_heat_ORR_coef=1.0, const bool &flag_single_phase_ORR=true)
Method to initialize the flags and factors corresponding to various source term components in the app...
Definition: reaction_heat.h:160
void set_derivative_flags(const std::vector< VariableNames > &flags)
Set the variables for which we would like to compute the derivatives.
Definition: reaction_heat.h:146
double deriv_entropy_rxn(const double &Temp) const
Function to compute derivative of entropy change of reaction with respect to temperature [K]...
Definition: reaction_heat.h:226
Definition: system_management.h:71
double factor_irrev_ORR
Factor for irreversible heating in ORR.
Definition: reaction_heat.h:233
FuelCellShop::Kinetics::BaseKinetics * kinetics
Store pointer to the kinetics object.
Definition: reaction_heat.h:207
SolutionVariable phi_m
Struct storing a pointer to the solution vector for the electrolyte potential.
Definition: reaction_heat.h:210
double factor_rev_HOR
Factor for reversible heating in HOR.
Definition: reaction_heat.h:242
void set_solid_potential(const SolutionVariable &phi)
Set the solid phase potential.
Definition: reaction_heat.h:130
This class is used to compute non-linear reaction heat source terms in a catalyst layer...
Definition: reaction_heat.h:94
double entropy_rxn(const double &Temp) const
Function to compute entropy change of reaction [J/(mol-K)] as a function of temperature [K]...
Definition: reaction_heat.h:219