OpenFCST: The open-source Fuel Cell Simulation Toolbox
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Classes | Functions | Variables
FcstUtilities Namespace Reference

Classes

class  FCSTdatabase
 This class is for interfacing with SQL databases, for the purpose of accessing and storing simulation results. More...
 
class  DatabaseOC
 This class is for storing a list of up to 10 parameters and is used as a way of informing the FCSTdatabase class about the model you wish to store/access. More...
 
class  FCSTLogStream
 The object FcstUtilities::log should be used throughout OpenFCST for console logging. More...
 

Functions

 DeclException1 (ExcWrongString, std::string,<< "Can't convert the string "<< arg1<< " to the desired Number type")
 Exception shown when a particular string can't be converted to Number type. More...
 
template<typename NumType >
NumType string_to_number (const std::string &)
 Function to convert a std::string into Number template. More...
 
template<typename NumType >
std::vector< NumType > string_to_number (const std::vector< std::string > &)
 Function to convert a std::vector< std::string > into std::vector < Number template >. More...
 
template<>
unsigned char string_to_number< unsigned char > (const std::string &str)
 Function to convert a std::string into an unsigned char such as types::material_id and types::boundary_id. More...
 
template<typename KeyType , typename ValueType >
std::map< KeyType, ValueType > string_to_map (const std::vector< std::string > &)
 Function to convert a std::vector< std::string > into std::map< KeyType, ValueType >. More...
 
template<typename KeyType , typename ValueType >
std::map< KeyType, ValueType > string_to_map (const std::string &name)
 This function is the same as the previous one. More...
 
template<>
std::map< unsigned int,
std::string > 
string_to_map (const std::string &name)
 This function is a particular reimplementation of the previous one. More...
 
bool is_number (const std::string &s)
 This function determines whether a string is a "valid" representation of a number. More...
 
template<typename KeyType , typename ValueType >
std::map< KeyType, std::vector
< ValueType > > 
split_mapvalue_list (const std::map< KeyType, std::string > &, const char delimiter= ';')
 This function takes a std::map<KeyType, std::string>, and std::string contains text separated by a delimiter. More...
 
void print_parameter_file_XML (ParameterHandler &param, std::string path="default.xml")
 This function prepares an XML file with ALL your data inside. More...
 
std::string find_fcst_root ()
 This function returns the address of the fcst root directory. More...
 
void run_python (std::string script_name, std::string arg)
 This function runs external python scripts. More...
 
template<typename ValType >
void modify_parameter_file (const std::string name_design_var, const ValType value_design_var, ParameterHandler &param)
 This routine is used to parse the input parameter. More...
 
template<typename NumType >
std::string number_to_string (const NumType &num)
 Function for casting from double to string. More...
 
void read_parameter_files (ParameterHandler &param, const std::string &filename)
 This function reads parameter files written in both prm and xml formats. More...
 
bool file_exists (const std::string &file_name)
 Check if a file exists. More...
 

Variables

FCSTLogStream log
 Object used to output data to file and, if file attached recorded to a file as well. More...
 

Function Documentation

FcstUtilities::DeclException1 ( ExcWrongString  ,
std::string  ,
<< "Can't convert the string "<< arg1<< " to the desired Number type"   
)

Exception shown when a particular string can't be converted to Number type.

bool FcstUtilities::file_exists ( const std::string &  file_name)

Check if a file exists.

Adapted from http://stackoverflow.com/questions/12774207/fastest-way-to-check-if-a-file-exist-using-standard-c-c11-c

Parameters
file_nameThe file name or relative file path.
std::string FcstUtilities::find_fcst_root ( )

This function returns the address of the fcst root directory.

It presumes that you are executing from within the data folder - an exception will be thrown otherwise.

bool FcstUtilities::is_number ( const std::string &  s)

This function determines whether a string is a "valid" representation of a number.

Examples: Valid: "2.2", "-33", "-1.332" Invalid: "1+23.3", "2.2.2", "Bob"

See UtilsTest::testIsNumber in unit_test/source/utils_test.cc for more information.

template<typename ValType >
void FcstUtilities::modify_parameter_file ( const std::string  name_design_var,
const ValType  value_design_var,
ParameterHandler &  param 
)

This routine is used to parse the input parameter.

Parameters
name_design_varfor subsections and parameter name. This values are used to set the parameters specified as design variables.

The string should be of the form:

* set DV_0 = subsection_1>>subsection_2>>subsection_3>>parameter name:material_ID
*

This routine will go to the appropriate subsection in the ParameterHandler passed as input and will add the value in

Parameters
value_design_varto the ParameterHandler file
Author
M. Secanell and P. Wardlaw, 2014
template<typename NumType >
std::string FcstUtilities::number_to_string ( const NumType &  num)

Function for casting from double to string.

Uses boost lexical cast.

void FcstUtilities::print_parameter_file_XML ( ParameterHandler &  param,
std::string  path = "default.xml" 
)

This function prepares an XML file with ALL your data inside.

void FcstUtilities::read_parameter_files ( ParameterHandler &  param,
const std::string &  filename 
)

This function reads parameter files written in both prm and xml formats.

void FcstUtilities::run_python ( std::string  script_name,
std::string  arg 
)

This function runs external python scripts.

User must provide the script name and argument. It is presumed that the script resides in the python folder.

template<typename KeyType , typename ValueType >
std::map< KeyType, std::vector<ValueType> > FcstUtilities::split_mapvalue_list ( const std::map< KeyType, std::string > &  ,
const char  delimiter = ';' 
)

This function takes a std::map<KeyType, std::string>, and std::string contains text separated by a delimiter.

It splits the std::string into std::vector<ValueType>, removing all the leading and trailing spaces. It returns std::map< KeyType, std::vector<ValueType> >. The default value of the delimiter is semi-colon ";".

Note
It is necessary to have the delimiter "atleast once" in the Value string.
template<typename KeyType , typename ValueType >
std::map< KeyType, ValueType > FcstUtilities::string_to_map ( const std::vector< std::string > &  )

Function to convert a std::vector< std::string > into std::map< KeyType, ValueType >.

This function is used to convert a string like "2 : 3.86" into a std::map where Key is 2 and Value is 3.86. This function is useful to convert a Patterns::Map (of ParameterHandler class of deal.ii) into a useful data map.

Warning
String should contain ":" to distinguish between key and corresponding value. Also a key should not be repeated in the parameter strings. Also Input strings should be free from blank spaces at the beginning and end.
Note
Currently, it is templated only to have KeyType as unsigned int and ValueType as double. But, the capabilities can be extended.
template<>
std::map< unsigned int, std::string > FcstUtilities::string_to_map ( const std::string &  name)

This function is a particular reimplementation of the previous one.

template<typename KeyType , typename ValueType >
std::map< KeyType, ValueType > FcstUtilities::string_to_map ( const std::string &  name)

This function is the same as the previous one.

The only difference is that this function takes std::string instead of std::vector<std::string>.

template<typename NumType >
NumType FcstUtilities::string_to_number ( const std::string &  )

Function to convert a std::string into Number template.

Currently, it is templated only for double and unsigned int types. But it can be easily extended for other numeric data types.

Input string should be free from blank spaces at the beginning and end.

Note
There is a similar function in deal.ii Utilities namespace, but it has certain limitations as it doesn't do effective error checking for wrong input arguments. For that purpose, a new function is written here using boost::lexical_cast.
template<typename NumType >
std::vector<NumType> FcstUtilities::string_to_number ( const std::vector< std::string > &  )

Function to convert a std::vector< std::string > into std::vector < Number template >.

Currently, it is templated only for double and unsigned int types. But it can be easily extended for other numeric data types.

Input strings should be free from blank spaces at the beginning and end.

Note
Before extending its capabilities to deal with other numeric data types, capability of string_to_number should be extended.
template<>
unsigned char FcstUtilities::string_to_number< unsigned char > ( const std::string &  str)

Function to convert a std::string into an unsigned char such as types::material_id and types::boundary_id.

Variable Documentation

FCSTLogStream FcstUtilities::log

Object used to output data to file and, if file attached recorded to a file as well.

Referenced by FuelCellShop::Material::CatalystBase::alpha_anodic(), FuelCellShop::Material::CatalystBase::alpha_cathodic(), FuelCell::InitialAndBoundaryData::check(), FuelCellShop::Material::CatalystBase::check_reaction_implementation(), FuelCellShop::Kinetics::BaseKinetics::compute_coverages(), FuelCell::ApplicationCore::OptimizationBlockMatrixApplication< dim >::compute_L1_L2_error_and_convergence_rate(), FuelCellShop::Material::CatalystBase::create_Catalyst(), FuelCellShop::Layer::CatalystLayer< dim >::create_CatalystLayer(), FuelCellShop::Material::CatalystSupportBase::create_CatalystSupport(), FuelCellShop::Layer::GasDiffusionLayer< dim >::create_GasDiffusionLayer(), FuelCellShop::Geometry::GridBase< dim >::create_GridGenerator(), FuelCellShop::Kinetics::BaseKinetics::create_Kinetics(), FuelCellShop::Layer::MembraneLayer< dim >::create_MembraneLayer(), FuelCellShop::Layer::MicroPorousLayer< dim >::create_MicroPorousLayer(), FuelCellShop::MicroScale::MicroScaleBase::create_MicroStructure(), FuelCellShop::Material::PolymerElectrolyteBase::create_PolymerElectrolyte(), FuelCellShop::Material::PureSolid::create_PureSolid(), FuelCellShop::Material::CatalystSupportBase::create_replica(), FuelCellShop::Material::PureSolid::create_replica(), FuelCellShop::Kinetics::BaseKinetics::create_replica(), FuelCellShop::Material::CatalystBase::create_replica(), FuelCellShop::Geometry::GridBase< dim >::create_replica(), FuelCellShop::Layer::MembraneLayer< dim >::create_replica(), FuelCellShop::Material::PolymerElectrolyteBase::create_replica(), FuelCellShop::Layer::MicroPorousLayer< dim >::create_replica(), FuelCellShop::Layer::GasDiffusionLayer< dim >::create_replica(), FuelCellShop::Layer::CatalystLayer< dim >::create_replica(), FuelCellShop::Kinetics::BaseKinetics::current_density(), FuelCellShop::Layer::CatalystLayer< dim >::current_density(), FuelCellShop::Material::BaseMaterial::declare_parameters(), FuelCellShop::Material::CatalystSupportBase::declare_parameters(), FuelCellShop::Material::CatalystBase::declare_parameters(), FuelCellShop::Kinetics::BaseKinetics::declare_parameters(), FuelCellShop::Material::PolymerElectrolyteBase::declare_parameters(), FuelCellShop::Material::CatalystBase::derivative_alpha_anodic(), FuelCellShop::Material::CatalystBase::derivative_alpha_cathodic(), FuelCellShop::Kinetics::BaseKinetics::derivative_current(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_current_density(), FuelCellShop::Layer::MicroPorousLayer< dim >::derivative_dpcapillary_dsat(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_dpcapillary_dsat(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_dpcapillary_dsat(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_effective_electron_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_electron_conductivity(), FuelCellShop::Layer::MicroPorousLayer< dim >::derivative_effective_gas_diffusivity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_effective_gas_diffusivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_gas_diffusivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_proton_conductivity(), FuelCellShop::Layer::MicroPorousLayer< dim >::derivative_effective_thermal_conductivity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_effective_thermal_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_thermal_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_thermoosmotic_diffusivity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_effective_water_diffusivity(), FuelCellShop::Material::CatalystBase::derivative_exchange_current_density(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_gas_permeablity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_gas_permeablity(), FuelCellShop::Layer::MicroPorousLayer< dim >::derivative_interfacial_surface_area(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_interfacial_surface_area(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_interfacial_surface_area(), FuelCellShop::Layer::MicroPorousLayer< dim >::derivative_liquid_permeablity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::derivative_liquid_permeablity(), FuelCellShop::Layer::CatalystLayer< dim >::derivative_liquid_permeablity(), FuelCellShop::Layer::MicroPorousLayer< dim >::dpcapillary_dsat(), FuelCellShop::Layer::GasDiffusionLayer< dim >::dpcapillary_dsat(), FuelCellShop::Layer::CatalystLayer< dim >::dpcapillary_dsat(), FuelCellShop::Material::CatalystBase::dvoltage_cell_th_dT(), FuelCellShop::Layer::MicroPorousLayer< dim >::effective_electron_conductivity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::effective_electron_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::effective_electron_conductivity(), FuelCellShop::Layer::MicroPorousLayer< dim >::effective_gas_diffusivity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::effective_gas_diffusivity(), FuelCellShop::Layer::CatalystLayer< dim >::effective_gas_diffusivity(), FuelCellShop::Layer::CatalystLayer< dim >::effective_proton_conductivity(), FuelCellShop::Layer::MicroPorousLayer< dim >::effective_thermal_conductivity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::effective_thermal_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::effective_thermal_conductivity(), FuelCellShop::Layer::CatalystLayer< dim >::effective_thermoosmotic_diffusivity(), FuelCellShop::Layer::MicroPorousLayer< dim >::effective_transport_property_solid(), FuelCellShop::Layer::CatalystLayer< dim >::effective_water_diffusivity(), FuelCellShop::Material::PolymerElectrolyteBase::electroosmotic_drag(), FuelCellShop::Material::PolymerElectrolyteBase::electroosmotic_drag_derivative(), FuelCellShop::Equation::ReactionHeat::entropy_rxn(), FuelCellShop::Material::CatalystBase::exchange_current_density(), FuelCellShop::Layer::GasDiffusionLayer< dim >::gas_permeablity(), FuelCellShop::Layer::CatalystLayer< dim >::gas_permeablity(), FuelCellShop::Geometry::GridBase< dim >::generate_grid(), FuelCellShop::Geometry::GridBase< dim >::generate_grid_with_curved_boundaries(), FuelCellShop::Layer::CatalystLayer< dim >::get_active_area_Pt(), FuelCellShop::Layer::BaseLayer< dim >::get_base_type(), FuelCellShop::Material::PolymerElectrolyteBase::get_d2Hlambda_dT2(), FuelCellShop::Material::Graphite::get_Delectrical_conductivity_Dtemperature(), FuelCellShop::Material::FiberBase::get_density(), FuelCellShop::Material::CatalystSupportBase::get_density(), FuelCellShop::Material::CarbonFiber::get_derivative_electrical_conductivity(), FuelCellShop::Material::FiberBase::get_derivative_electrical_conductivity(), FuelCellShop::Material::CarbonFiber::get_derivative_thermal_conductivity(), FuelCellShop::Material::FiberBase::get_derivative_thermal_conductivity(), FuelCellShop::Material::PolymerElectrolyteBase::get_dHlambda_dT(), FuelCellShop::Material::Graphite::get_Dthermal_conductivity_Dtemperature(), FuelCellShop::Material::FiberBase::get_electrical_conductivity(), FuelCellShop::Material::CatalystSupportBase::get_electrical_conductivity(), FuelCellShop::Material::MaterialPlateBase::get_electron_conductivity(), FuelCellShop::Material::MaterialPlateBase::get_electron_conductivity_derivative(), FuelCellShop::Material::MaterialPlateBase::get_expansion_coefficient(), FuelCellShop::Material::MaterialPlateBase::get_expansion_coefficient_derivative(), FuelCellShop::Material::PolymerElectrolyteBase::get_Hlambda(), FuelCellShop::Layer::CatalystLayer< dim >::get_loadings(), FuelCellShop::Material::MaterialPlateBase::get_poissons_modulus_derivative(), FuelCellShop::Material::MaterialPlateBase::get_poissons_ratio(), FuelCellShop::Material::FiberBase::get_thermal_conductivity(), FuelCellShop::Material::MaterialPlateBase::get_thermal_conductivity(), FuelCellShop::Material::CatalystSupportBase::get_thermal_conductivity(), FuelCellShop::Material::MaterialPlateBase::get_thermal_conductivity_derivative(), FuelCellShop::Layer::CatalystLayer< dim >::get_volume_fractions(), FuelCellShop::Material::MaterialPlateBase::get_youngs_modulus(), FuelCellShop::Material::MaterialPlateBase::get_youngs_modulus_derivative(), LinearSolvers::GMRESSolver::GMRESSolver(), FuelCellShop::Material::PolymerElectrolyteBase::hydrogen_diffusivity(), LinearSolvers::ILUPreconditioner::ILUPreconditioner(), FuelCellShop::Material::BaseMaterial::initialize(), FuelCellShop::Material::CatalystSupportBase::initialize(), FuelCellShop::Material::CatalystBase::initialize(), FuelCellShop::Kinetics::BaseKinetics::initialize(), FuelCellShop::Material::PolymerElectrolyteBase::initialize(), FuelCellShop::Layer::MicroPorousLayer< dim >::interfacial_surface_area(), FuelCellShop::Layer::GasDiffusionLayer< dim >::interfacial_surface_area(), FuelCellShop::Layer::CatalystLayer< dim >::interfacial_surface_area(), FuelCellShop::Layer::MicroPorousLayer< dim >::liquid_permeablity(), FuelCellShop::Layer::GasDiffusionLayer< dim >::liquid_permeablity(), FuelCellShop::Layer::CatalystLayer< dim >::liquid_permeablity(), FuelCellShop::Kinetics::BaseKinetics::O_coverage(), FuelCellShop::Kinetics::BaseKinetics::OH_coverage(), FuelCellShop::Material::PolymerElectrolyteBase::oxygen_diffusivity(), FuelCellShop::Material::PolymerElectrolyteBase::oxygen_diffusivity_derivative(), FuelCellShop::Layer::MicroPorousLayer< dim >::pcapillary(), FuelCellShop::Layer::PorousLayer< dim >::pcapillary(), FuelCellShop::Layer::GasDiffusionLayer< dim >::pcapillary(), FuelCellShop::Layer::CatalystLayer< dim >::pcapillary(), FuelCell::ApplicationCore::OptimizationBlockMatrixApplication< dim >::print_dresponses_dl(), FuelCell::ApplicationCore::OptimizationBlockMatrixApplication< dim >::print_dresponses_du(), FuelCell::ParametricStudy< dim >::print_iteration_info(), FuelCellShop::Material::BaseMaterial::print_material_properties(), FuelCellShop::MicroScale::PolyAgglomerate::print_properties(), FuelCellShop::Material::PolymerElectrolyteBase::proton_conductivity(), FuelCellShop::Material::PolymerElectrolyteBase::proton_conductivity_derivative(), FuelCellShop::Material::PolymerElectrolyteBase::proton_diffusivity(), FuelCellShop::Material::CatalystBase::reaction_order(), FuelCellShop::Material::CatalystBase::reference_concentration(), FuelCellShop::Layer::CatalystLayer< dim >::set_cell_id(), FuelCellShop::Layer::MicroPorousLayer< dim >::set_method_effective_transport_property_solid(), FuelCellShop::Layer::DesignMPL< dim >::set_parameters(), FuelCellShop::Kinetics::DualPathKinetics::set_reaction_kinetics(), FuelCellShop::Material::CatalystBase::set_reaction_kinetics(), FuelCellShop::Kinetics::DoubleTrapKinetics::set_reaction_kinetics(), FuelCellShop::Layer::BaseLayer< dim >::set_solution(), FuelCellShop::Material::PolymerElectrolyteBase::sorption_enthalpy(), FuelCellShop::Material::PolymerElectrolyteBase::sorption_enthalpy_derivative(), FuelCellShop::Material::PolymerElectrolyteBase::sorption_isotherm(), FuelCellShop::Material::PolymerElectrolyteBase::sorption_isotherm_derivative(), LinearSolvers::SparseDirectUMFPACKSolver::SparseDirectUMFPACKSolver(), FuelCellShop::Layer::BaseLayer< dim >::test_layer(), FuelCellShop::Material::PolymerElectrolyteBase::thermoosmotic_coeff(), FuelCellShop::Material::PolymerElectrolyteBase::thermoosmotic_coeff_derivative(), FuelCellShop::Material::CatalystBase::voltage_cell_th(), FuelCellShop::Material::PolymerElectrolyteBase::water_diffusivity(), and FuelCellShop::Material::PolymerElectrolyteBase::water_diffusivity_derivative().