Revision 5c2da885a77493bf66aaf5be0089734a795637af authored by Christoph Lehmann on 21 December 2021, 11:16:09 UTC, committed by Christoph Lehmann on 21 December 2021, 11:16:09 UTC
Draft: Do not make direct reference to Process in output functions See merge request ogs/ogs!3906
Medium.h
/**
* \file
* \author Norbert Grunwald
* \date 07.09.2017
*
* \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 <memory>
#include <string>
#include <vector>
#include "BaseLib/Error.h"
#include "Phase.h"
namespace MaterialPropertyLib
{
class Property;
}
namespace MaterialPropertyLib
{
/// This class is for material objects on the Medium scale.
///
/// A Medium consists of an arbitrarily long vector of phases and an array of
/// properties.
class Medium final
{
public:
Medium(int const material_id,
std::vector<std::unique_ptr<Phase>>&& phases,
std::unique_ptr<PropertyArray>&& properties);
/// A get-function for a particular phase. The ul argument specifies the
/// index within the phases_ vector.
Phase const& phase(std::size_t index) const;
/// A get-function for a particular phase by phase name.
Phase const& phase(std::string const& phase_name) const;
/// A query for a named phase.
bool hasPhase(std::string const& phase_name) const;
/// A get-function for a property. The argument refers to the name of the
/// property.
Property const& property(PropertyType const& p) const;
Property const& operator[](PropertyType const& p) const;
bool hasProperty(PropertyType const& p) const;
/// A simple get-function for retrieving the number of phases the medium
/// consists of.
std::size_t numberOfPhases() const;
/// Short description of the medium.
std::string description() const;
template <typename T>
T value(PropertyType const p) const
{
return property(p).template value<T>();
}
template <typename T>
T value(PropertyType const p, VariableArray const& variable_array) const
{
return property(p).template value<T>(variable_array);
}
template <typename T>
T dValue(PropertyType const p,
VariableArray const& variable_array,
Variable const variable) const
{
return property(p).template dValue<T>(variable_array, variable);
}
template <typename T>
T d2Value(PropertyType const p,
VariableArray const& variable_array,
Variable const variable1,
Variable const variable2) const
{
return property(p).template d2Value<T>(variable_array, variable1,
variable2);
}
private:
/// The vector that holds the phases.
std::vector<std::unique_ptr<Phase>> const phases_;
/// The array that holds the medium properties.
///
/// Currently, these defaults is the volume fraction average.
///
/// Most properties are fine with the volume fraction average, but
/// special-defaults are allowed as well...
PropertyArray properties_;
/// The first material id for which the medium was created. Used in the
/// description.
int const material_id_;
};
template <typename Container>
void checkRequiredProperties(Medium const& medium,
Container const& required_properties)
{
for (auto const& p : required_properties)
{
if (!medium.hasProperty(p))
{
OGS_FATAL(
"The property '{:s}' is missing in the medium definition.",
property_enum_to_string[p]);
}
}
}
/// Returns a gas or aqueous liquid phase of the given medium.
Phase const& fluidPhase(Medium const& medium);
} // namespace MaterialPropertyLib
Computing file changes ...