Forked from
ogs / ogs
8004 commits behind the upstream repository.
-
Dmitri Naumov authoredDmitri Naumov authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
DeactivatedSubdomain.h 3.67 KiB
/**
* \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
*
* File: DeactivatedSubdomain.h
*
* Created on November 29, 2018, 10:50 AM
*/
#pragma once
#include <Eigen/Dense>
#include <memory>
#include <string>
#include <vector>
#include "MathLib/InterpolationAlgorithms/PiecewiseLinearInterpolation.h"
#include "MathLib/Point3d.h"
namespace MeshLib
{
class Mesh;
class Node;
} // namespace MeshLib
namespace ParameterLib
{
template <typename T>
struct Parameter;
}
namespace ProcessLib
{
struct DeactivatedSubdomainMesh
{
DeactivatedSubdomainMesh(
std::unique_ptr<MeshLib::Mesh> deactivated_subdomain_mesh_,
std::vector<MeshLib::Node*>&& inner_nodes_,
std::vector<MeshLib::Node*>&& outer_nodes_);
std::unique_ptr<MeshLib::Mesh> const mesh;
std::vector<MeshLib::Node*> const inner_nodes;
std::vector<MeshLib::Node*> const outer_nodes;
};
/// Time depend subdomain deactivation.
///
/// Subdomain deactivation is space and time dependent.
/// The spatial extent of deactivated elements is defined through a set of
/// material ids.
/// Additionally a line segment separates through its normal plane and position
/// on the line segment an active and inactive part.
///
/// The subdomain can be deactivated at once using a time interval.
/// For fine grained control a time curve can be specified.
/// It maps current time to position on the line segment.
/// Elements, which center points lie left of this position are deactivated.
///
/// \internal
/// The deactivated elements are excluded from the assembly, pre and post call,
/// secondary variables computation and the like. To keep the size of the global
/// linear equation system artificial Dirichlet boundary conditions are applied
/// on the interior of the deactivated subdomain. The nodes on the border
/// between the active and inactive elements are not affected.
struct DeactivatedSubdomain
{
DeactivatedSubdomain(
MathLib::PiecewiseLinearInterpolation time_interval_,
std::pair<Eigen::Vector3d, Eigen::Vector3d>
line_segment,
std::vector<int>&& materialIDs_,
std::vector<std::unique_ptr<DeactivatedSubdomainMesh>>&&
deactivated_subdomain_meshes_,
ParameterLib::Parameter<double> const* boundary_value_parameter);
/// \returns true if the given time is included in the subdomains time
/// support interval.
bool isInTimeSupportInterval(double const t) const;
/// \returns true if the point is in the deactivated part of the subdomain.
/// The domain is split into two parts by a plane defined as a normal plane
/// of the line segment and the position on the line segment, where the
/// latter is defined by the time curve.
bool isDeactivated(MathLib::Point3d const& point, double const time) const;
MathLib::PiecewiseLinearInterpolation const time_interval;
/// Line segment along which excavation progresses. Represented by start and
/// end points.
std::pair<Eigen::Vector3d, Eigen::Vector3d> line_segment;
/// The material IDs of the deactivated the subdomains
std::vector<int> const materialIDs;
std::vector<std::unique_ptr<DeactivatedSubdomainMesh>> const
deactivated_subdomain_meshes;
/// A pararameter for the optional Dirichlet boundary condition applied on
/// the surface of the deactivated subdomain/excavation.
ParameterLib::Parameter<double> const* const boundary_value_parameter;
static const std::string zero_parameter_name;
};
} // namespace ProcessLib