Revision 812d2db1ba78453ddbcb3a91b99b0e2228b4b89d authored by Lars Bilke on 01 July 2021, 13:16:32 UTC, committed by Lars Bilke on 01 July 2021, 19:23:15 UTC
https://github.com/Sbte/BuildExternalProject/commit/ce1a70996aa538aac17a6faf07db487c3a238838
1 parent 2ae4ff7
HydroMechanicsProcessData.h
/**
* \file
* \copyright
* Copyright (c) 2012-2021, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#pragma once
#include "ParameterLib/Parameter.h"
#include <memory>
#include <utility>
#include <Eigen/Dense>
#include "MaterialLib/MPL/MaterialSpatialDistributionMap.h"
namespace MaterialLib
{
namespace Solids
{
template <int DisplacementDim>
struct MechanicsBase;
}
}
namespace ProcessLib
{
namespace HydroMechanics
{
template <int DisplacementDim>
struct HydroMechanicsProcessData
{
MeshLib::PropertyVector<int> const* const material_ids = nullptr;
std::unique_ptr<MaterialPropertyLib::MaterialSpatialDistributionMap>
media_map = nullptr;
/// The constitutive relation for the mechanical part.
/// \note Linear elasticity is the only supported one in the moment.
std::map<
int,
std::unique_ptr<MaterialLib::Solids::MechanicsBase<DisplacementDim>>>
solid_materials;
/// Optional, initial stress field. A symmetric tensor, short vector
/// representation of length 4 or 6, ParameterLib::Parameter<double>.
ParameterLib::Parameter<double> const* const initial_stress;
/// Specific body forces applied to solid and fluid.
/// It is usually used to apply gravitational forces.
/// A vector of displacement dimension's length.
Eigen::Matrix<double, DisplacementDim, 1> const specific_body_force;
/// If set mass lumping will be applied to the pressure equation.
bool const mass_lumping;
/// ID of hydraulic process.
int const hydraulic_process_id;
/// ID of the processes that contains mechanical process.
int const mechanics_related_process_id;
MeshLib::PropertyVector<double>* pressure_interpolated = nullptr;
std::array<MeshLib::PropertyVector<double>*, 3> principal_stress_vector = {
nullptr, nullptr, nullptr};
MeshLib::PropertyVector<double>* principal_stress_values = nullptr;
/// Total permeability as a symmetric tensor of length 4 or 6
/// with elements in the order k_xx, k_yy, k_zz, k_xy, k_yz, k_xz
MeshLib::PropertyVector<double>* permeability = nullptr;
EIGEN_MAKE_ALIGNED_OPERATOR_NEW;
};
} // namespace HydroMechanics
} // namespace ProcessLib
Computing file changes ...