Forked from
ogs / ogs
12712 commits behind the upstream repository.
-
Florian Zill authoredFlorian Zill authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
MaterialSpatialDistributionMap.h 1.04 KiB
/**
* \file
* \date Nov 28, 2017
*
* \copyright
* Copyright (c) 2012-2020, 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 <map>
#include <memory>
#include <vector>
namespace MeshLib
{
template <typename PROP_VAL_TYPE>
class PropertyVector;
} // namespace MeshLib
namespace MaterialPropertyLib
{
class Medium;
class MaterialSpatialDistributionMap
{
public:
MaterialSpatialDistributionMap(
std::map<int, std::shared_ptr<Medium>> const& media,
MeshLib::PropertyVector<int> const* const material_ids)
: _media(media), _material_ids(material_ids)
{
}
Medium* getMedium(std::size_t element_id);
void checkElementHasMedium(std::size_t const element_id);
private:
std::map<int, std::shared_ptr<Medium>> const& _media;
MeshLib::PropertyVector<int> const* const _material_ids;
};
} // namespace MaterialPropertyLib