37 #include "libmesh/getpot.h"
39 template<
typename ChemicalMixture>
40 int test( ChemicalMixture& chem_mixture )
42 const unsigned int N_index = chem_mixture.species_index(
"N");
43 const unsigned int N2_index = chem_mixture.species_index(
"N2");
45 const double gamma = 0.03;
51 const double w_s = 0.2;
53 const double rho = 1.0e-3;
54 const double rho_s = rho*w_s;
56 const double T = 620.1;
57 const double R_N = chem_mixture.R( chem_mixture.species_index(
"N") );
59 const double R = 30.1;
63 const double drho_dws = -rho*rho_s/R;
64 const double domega_dot_dws_exact = drho_dws*w_s*gamma*std::sqrt( R_N*T/(GRINS::Constants::two_pi) )
65 + rho*gamma*std::sqrt( R_N*T/(GRINS::Constants::two_pi) );
69 const double omega_dot_N = wall_N.
omega_dot( rho_s, T );
71 const double domega_dot_dT_N = wall_N.
domega_dot_dT( rho_s, T );
73 const double domega_dot_dws_N = wall_N.
domega_dot_dws( rho_s, w_s, T, R );
75 const double tol = 1.0e-15;
79 double rel_error = std::fabs( (omega_dot_N - omega_dot_exact)/omega_dot_exact );
83 std::cerr << std::setprecision(16) << std::scientific
84 <<
"Mismatch in omega_dot_N!" << std::endl
85 <<
"omega_dot_N = " << omega_dot_N << std::endl
86 <<
"omega_dot_exact = " << omega_dot_exact << std::endl
87 <<
"rel error = " << rel_error << std::endl;
95 double rel_error = std::fabs( (domega_dot_dT_N - domega_dot_dT_exact)/domega_dot_dT_exact );
99 std::cerr << std::setprecision(16) << std::scientific
100 <<
"Mismatch in domega_dot_dT_N!" << std::endl
101 <<
"domega_dot_dT_N = " << domega_dot_dT_N << std::endl
102 <<
"domega_dot_dT_exact = " << domega_dot_dT_exact << std::endl
103 <<
"rel error = " << rel_error << std::endl;
111 double rel_error = std::fabs( (domega_dot_dws_N - domega_dot_dws_exact)/domega_dot_dws_exact );
113 if( rel_error > tol )
115 std::cerr << std::setprecision(16) << std::scientific
116 <<
"Mismatch in domega_dot_dws_N!" << std::endl
117 <<
"domega_dot_dws_N = " << domega_dot_dws_N << std::endl
118 <<
"domega_dot_dws_exact = " << domega_dot_dws_exact << std::endl
119 <<
"rel error = " << rel_error << std::endl;
129 int main(
int argc,
char* argv[])
133 std::cerr <<
"Error: must specify the test type (cantera or antioch) and the input file name"
138 std::string test_type = argv[1];
140 GetPot input( argv[2] );
144 if( test_type ==
"cantera" )
146 #ifdef GRINS_HAVE_CANTERA
148 return_flag = test<GRINS::CanteraMixture>( chem_mixture );
153 else if( test_type ==
"antioch" )
155 #ifdef GRINS_HAVE_ANTIOCH
157 return_flag = test<GRINS::AntiochChemistry>( chem_mixture );
164 std::cerr <<
"Invalid test type " << test_type << std::endl;
int test(ChemicalMixture &chem_mixture)
Wrapper class for Antioch::ChemicalMixture.
int main(int argc, char *argv[])
libMesh::Real domega_dot_dT(const libMesh::Real rho_s, const libMesh::Real T) const
libMesh::Real omega_dot(const libMesh::Real rho_s, const libMesh::Real T) const
libMesh::Real domega_dot_dws(const libMesh::Real rho_s, const libMesh::Real w_s, const libMesh::Real T, const libMesh::Real R) const
Wrapper class for storing state for computing thermochemistry and transport properties using Cantera...
const libMesh::Real two_pi