26#ifndef dftefeEFEBDSOnTheFlyComputeDealii_h
27#define dftefeEFEBDSOnTheFlyComputeDealii_h
52 template <
typename ValueTypeBasisCoeff,
53 typename ValueTypeBasisData,
66 std::shared_ptr<const BasisDofHandler> feBDH,
74 std::shared_ptr<const BasisDofHandler>
86 std::shared_ptr<const quadrature::QuadratureRuleContainer>
87 quadratureRuleContainer,
94 std::vector<std::shared_ptr<const quadrature::QuadratureRule>>
102 std::shared_ptr<const quadrature::QuadratureRule>
103 baseQuadratureRuleAdaptive,
104 std::vector<std::shared_ptr<const utils::ScalarSpatialFunctionReal>>
106 const std::vector<double> & absoluteTolerances,
107 const std::vector<double> & relativeTolerances,
108 const std::vector<double> & integralThresholds,
109 const double smallestCellVolume,
110 const unsigned int maxRecursion,
183 const size_type basisId2)
const override;
202 std::shared_ptr<const quadrature::QuadratureRuleContainer>
209 Storage &basisData)
const override;
212 std::pair<size_type, size_type> cellRange,
213 Storage & basisGradientData)
const override;
222 std::shared_ptr<const quadrature::QuadratureRuleContainer>
An abstract class to store and access data for a given basis, such as the basis function values on a ...
Definition: EFEBDSOnTheFlyComputeDealii.h:58
const Storage & getBasisHessianDataInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1714
typename BasisDataStorage< ValueTypeBasisData, memorySpace >::Storage Storage
Definition: EFEBDSOnTheFlyComputeDealii.h:63
Storage getBasisOverlap(const size_type cellId, const size_type basisId1, const size_type basisId2) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2217
Storage getJxWInCell(const size_type cellId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2021
std::shared_ptr< const quadrature::QuadratureRuleContainer > d_quadratureRuleContainer
Definition: EFEBDSOnTheFlyComputeDealii.h:223
std::shared_ptr< Storage > d_basisGradientEnrichQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:239
Storage getBasisGradientDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2291
const Storage & getBasisOverlapInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2181
std::shared_ptr< Storage > d_basisEnrichQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:240
Storage getBasisGradientData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2093
std::vector< size_type > d_nQuadPointsIncell
Definition: EFEBDSOnTheFlyComputeDealii.h:232
std::shared_ptr< const quadrature::QuadratureRuleContainer > getQuadratureRuleContainer() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2330
void getBasisGradientDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisGradientData) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1884
BasisStorageAttributesBoolMap d_basisStorageAttributesBoolMap
Definition: EFEBDSOnTheFlyComputeDealii.h:225
void getBasisDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisData) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1792
Storage getBasisOverlapInCell(const size_type cellId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2199
std::shared_ptr< Storage > d_JxWStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:227
std::shared_ptr< Storage > d_basisGradientParaCellClassQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:228
const Storage & getBasisGradientDataInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1695
~EFEBDSOnTheFlyComputeDealii()=default
void evaluateBasisData(const quadrature::QuadratureRuleAttributes &quadratureRuleAttributes, const BasisStorageAttributesBoolMap basisStorageAttributesBoolMap) override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1088
Storage getBasisHessianDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2311
std::vector< size_type > d_cellStartIdsBasisJacobianInvQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:233
std::shared_ptr< Storage > d_basisParaCellClassQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:226
const Storage & getJxWInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1736
std::vector< size_type > d_cellStartIdsBasisHessianQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:234
bool d_evaluateBasisData
Definition: EFEBDSOnTheFlyComputeDealii.h:216
std::shared_ptr< Storage > d_tmpGradientBlock
Definition: EFEBDSOnTheFlyComputeDealii.h:236
void deleteBasisData() override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2237
linearAlgebra::LinAlgOpContext< memorySpace > & d_linAlgOpContext
Definition: EFEBDSOnTheFlyComputeDealii.h:237
Storage getBasisData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2056
Storage getBasisHessianData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2134
std::vector< size_type > d_dofsInCell
Definition: EFEBDSOnTheFlyComputeDealii.h:231
const Storage & getBasisDataInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:1679
Storage getBasisGradNiGradNjInCell(const size_type cellId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2347
std::shared_ptr< const BasisDofHandler > getBasisDofHandler() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2386
std::shared_ptr< const EFEBasisDofHandlerDealii< ValueTypeBasisCoeff, ValueTypeBasisData, memorySpace, dim > > d_efeBDH
Definition: EFEBDSOnTheFlyComputeDealii.h:221
std::shared_ptr< Storage > d_basisHessianQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:230
QuadratureRuleAttributes d_quadratureRuleAttributes
Definition: EFEBDSOnTheFlyComputeDealii.h:224
Storage getBasisDataInCell(const size_type cellId, const size_type basisId) const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2270
size_type d_maxCellBlock
Definition: EFEBDSOnTheFlyComputeDealii.h:235
std::shared_ptr< Storage > d_basisJacobianInvQuadStorage
Definition: EFEBDSOnTheFlyComputeDealii.h:229
const Storage & getBasisGradNiGradNjInAllCells() const override
Definition: EFEBDSOnTheFlyComputeDealii.t.cpp:2367
size_type d_classialDofsInCell
Definition: EFEBDSOnTheFlyComputeDealii.h:238
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
Definition: LinAlgOpContext.h:38
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
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