26#ifndef dftefeEFEBasisDataStorageDealii_h
27#define dftefeEFEBasisDataStorageDealii_h
55 template <
typename ValueTypeBasisCoeff,
56 typename ValueTypeBasisData,
69 std::shared_ptr<const BasisDofHandler> efeBDH,
75 std::shared_ptr<const BasisDofHandler>
87 std::shared_ptr<const quadrature::QuadratureRuleContainer>
88 quadratureRuleContainer,
95 std::vector<std::shared_ptr<const quadrature::QuadratureRule>>
103 std::shared_ptr<const quadrature::QuadratureRule>
104 baseQuadratureRuleAdaptive,
105 std::vector<std::shared_ptr<const utils::ScalarSpatialFunctionReal>>
107 const std::vector<double> & absoluteTolerances,
108 const std::vector<double> & relativeTolerances,
109 const std::vector<double> & integralThresholds,
110 const double smallestCellVolume,
111 const unsigned int maxRecursion,
170 const size_type basisId2)
const override;
188 std::shared_ptr<const quadrature::QuadratureRuleContainer>
198 std::shared_ptr<const quadrature::QuadratureRuleContainer>
An abstract class to store and access data for enriched fe basis, such as the basis function values o...
Definition: EFEBasisDataStorageDealii.h:61
std::vector< size_type > d_cellStartIdsGradNiGradNj
Definition: EFEBasisDataStorageDealii.h:214
std::vector< size_type > d_cellStartIdsBasisGradientQuadStorage
Definition: EFEBasisDataStorageDealii.h:212
std::vector< size_type > d_nQuadPointsIncell
Definition: EFEBasisDataStorageDealii.h:210
Storage getBasisDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3912
std::vector< size_type > d_cellStartIdsBasisHessianQuadStorage
Definition: EFEBasisDataStorageDealii.h:213
~EFEBasisDataStorageDealii()=default
const Storage & getBasisHessianDataInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3468
const Storage & getBasisDataInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3424
Storage getBasisHessianData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3742
Storage getBasisData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3657
QuadratureRuleAttributes d_quadratureRuleAttributes
Definition: EFEBasisDataStorageDealii.h:200
std::shared_ptr< const EFEBasisDofHandlerDealii< ValueTypeBasisCoeff, ValueTypeBasisData, memorySpace, dim > > d_efeBDH
Definition: EFEBasisDataStorageDealii.h:197
void evaluateBasisData(const quadrature::QuadratureRuleAttributes &quadratureRuleAttributes, const BasisStorageAttributesBoolMap basisStorageAttributesBoolMap) override
Definition: EFEBasisDataStorageDealii.t.cpp:2363
Storage getBasisGradientData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3698
std::vector< size_type > d_cellStartIdsBasisQuadStorage
Definition: EFEBasisDataStorageDealii.h:211
BasisStorageAttributesBoolMap d_basisStorageAttributesBoolMap
Definition: EFEBasisDataStorageDealii.h:201
std::shared_ptr< Storage > d_JxWStorage
Definition: EFEBasisDataStorageDealii.h:203
std::shared_ptr< Storage > d_basisQuadStorage
Definition: EFEBasisDataStorageDealii.h:202
std::shared_ptr< Storage > d_basisGradNiGradNj
Definition: EFEBasisDataStorageDealii.h:204
Storage getBasisHessianDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3953
const Storage & getBasisOverlapInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3790
std::vector< size_type > d_dofsInCell
Definition: EFEBasisDataStorageDealii.h:208
std::shared_ptr< Storage > d_basisHessianQuadStorage
Definition: EFEBasisDataStorageDealii.h:206
std::shared_ptr< const quadrature::QuadratureRuleContainer > d_quadratureRuleContainer
Definition: EFEBasisDataStorageDealii.h:199
std::vector< size_type > d_cellStartIdsBasisOverlap
Definition: EFEBasisDataStorageDealii.h:209
std::shared_ptr< Storage > d_basisOverlap
Definition: EFEBasisDataStorageDealii.h:207
const Storage & getBasisGradNiGradNjInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:4023
bool d_evaluateBasisData
Definition: EFEBasisDataStorageDealii.h:192
Storage getBasisOverlapInCell(const size_type cellId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3812
Storage getBasisGradNiGradNjInCell(const size_type cellId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3989
std::shared_ptr< Storage > d_basisGradientQuadStorage
Definition: EFEBasisDataStorageDealii.h:205
void deleteBasisData() override
Definition: EFEBasisDataStorageDealii.t.cpp:3881
const Storage & getBasisGradientDataInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3446
Storage getBasisGradientDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3933
Storage getJxWInCell(const size_type cellId) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3623
std::shared_ptr< const BasisDofHandler > getBasisDofHandler() const override
Definition: EFEBasisDataStorageDealii.t.cpp:4045
Storage getBasisOverlap(const size_type cellId, const size_type basisId1, const size_type basisId2) const override
Definition: EFEBasisDataStorageDealii.t.cpp:3845
const Storage & getJxWInAllCells() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3490
std::shared_ptr< const quadrature::QuadratureRuleContainer > getQuadratureRuleContainer() const override
Definition: EFEBasisDataStorageDealii.t.cpp:3972
typename BasisDataStorage< ValueTypeBasisData, memorySpace >::Storage Storage
Definition: EFEBasisDataStorageDealii.h:66
An abstract class to store and access data for a given basis, such as the basis function values on a ...
Definition: EFEBasisDataStorage.h:52
Definition: EFEBasisDofHandlerDealii.h:61
Class to store the attributes of a quad point, such as the cell Id it belongs, the quadPointId within...
Definition: QuadratureAttributes.h:171
Definition: QuadratureAttributes.h:135
Definition: MemoryStorage.h:38
std::map< BasisStorageAttributes, bool > BasisStorageAttributesBoolMap
Definition: BasisDataStorage.h:50
MemorySpace
Definition: MemorySpaceType.h:37
dealii includes
Definition: AtomFieldDataSpherical.cpp:31
unsigned int size_type
Definition: TypeConfig.h:8