Newer
Older
* Copyright (c) 2012-2016, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#include "ProcessVariable.h"
#include "GeoLib/GEOObjects.h"
#include "MeshLib/Mesh.h"
ProcessVariable::ProcessVariable(BaseLib::ConfigTree const& config,
:
//! \ogs_file_param{prj__process_variables__process_variable__name}
_name(config.getConfigParameter<std::string>("name")),
_mesh(mesh),
//! \ogs_file_param{prj__process_variables__process_variable__components}
_n_components(config.getConfigParameter<int>("components"))
DBUG("Constructing process variable %s", this->_name.c_str());
// Initial condition
//! \ogs_file_param{prj__process_variables__process_variable__initial_condition}
if (auto ic_config = config.getConfigSubtreeOptional("initial_condition"))
//! \ogs_file_param{initial_condition__type}
auto const type = ic_config->peekConfigParameter<std::string>("type");
if (type == "Uniform")
{
_initial_condition =
createUniformInitialCondition(*ic_config, _n_components);
}
else if (type == "MeshProperty")
{
_initial_condition =
createMeshPropertyInitialCondition(*ic_config, _mesh, _n_components);
}
else
{
ERR("Unknown type of the initial condition.");
}
}
else
{
INFO("No initial condition found.");
}
// Boundary conditions
//! \ogs_file_param{prj__process_variables__process_variable__boundary_conditions}
if (auto bcs_config = config.getConfigSubtreeOptional("boundary_conditions"))
for (auto bc_config :
//! \ogs_file_param{prj__process_variables__process_variable__boundary_conditions__boundary_condition}
bcs_config->getConfigSubtreeList("boundary_condition"))
//! \ogs_file_param{boundary_condition__geometrical_set}
bc_config.getConfigParameter<std::string>("geometrical_set");
//! \ogs_file_param{boundary_condition__geometry}
bc_config.getConfigParameter<std::string>("geometry");
geometries.getGeoObject(geometrical_set_name, geometry_name);
if (! geometry)
OGS_FATAL(
"No geometry with name `%s' has been found in the "
"geometrical set `%s'.",
geometry_name.c_str(), geometrical_set_name.c_str());
GeoLib::convertGeoTypeToString(geometry->getGeoType()).c_str());
auto component_id =
//! \ogs_file_param{boundary_condition__component}
bc_config.getConfigParameterOptional<int>("component");
if (!component_id)
{
if (_n_components == 1)
// default value for single component vars.
component_id = 0;
else
OGS_FATAL(
"The <component> tag could not be found for the "
"multi-component boundary condition of the process "
"variable `%s'.",
_name.c_str());
}
_bc_configs.emplace_back(std::move(bc_config), *geometry,
*component_id);
}
} else {
INFO("No boundary conditions found.");
}
// Source Terms
config.ignoreConfigParameter("source_terms");
ProcessVariable::ProcessVariable(ProcessVariable&& other)
: _name(std::move(other._name)),
_mesh(other._mesh),
_initial_condition(std::move(other._initial_condition)),
std::string const& ProcessVariable::getName() const
{
MeshLib::Mesh const& ProcessVariable::getMesh() const
{
MeshLib::PropertyVector<double>& ProcessVariable::getOrCreateMeshProperty()
{
if (_mesh.getProperties().hasPropertyVector(_name))
{
_mesh.getProperties().template getPropertyVector<double>(_name);
assert(result);
assert(result->size() == _mesh.getNumberOfNodes() * _n_components);
auto result = _mesh.getProperties().template createNewPropertyVector<double>(
_name, MeshLib::MeshItemType::Node, _n_components);
result->resize(_mesh.getNumberOfNodes() * _n_components);
std::vector<std::unique_ptr<BoundaryCondition>>
const NumLib::LocalToGlobalIndexMap& dof_table,
const int variable_id,
unsigned const integration_order)
{
std::vector<std::unique_ptr<BoundaryCondition>> bcs;
for (auto& config : _bc_configs)
bcs.emplace_back(createBoundaryCondition(
config, dof_table, _mesh, variable_id, integration_order));
return bcs;
}