26#ifndef dftefeCFEBasisDataStorageDealii_h
27#define dftefeCFEBasisDataStorageDealii_h
51 template <
typename ValueTypeBasisCoeff,
52 typename ValueTypeBasisData,
65 std::shared_ptr<const BasisDofHandler> feBDH,
71 std::shared_ptr<const BasisDofHandler>
83 std::shared_ptr<const quadrature::QuadratureRuleContainer>
84 quadratureRuleContainer,
91 std::vector<std::shared_ptr<const quadrature::QuadratureRule>>
99 std::shared_ptr<const quadrature::QuadratureRule>
100 baseQuadratureRuleAdaptive,
101 std::vector<std::shared_ptr<const utils::ScalarSpatialFunctionReal>>
103 const std::vector<double> & absoluteTolerances,
104 const std::vector<double> & relativeTolerances,
105 const std::vector<double> & integralThresholds,
106 const double smallestCellVolume,
107 const unsigned int maxRecursion,
180 const size_type basisId2)
const override;
200 std::shared_ptr<const quadrature::QuadratureRuleContainer>
207 Storage &basisData)
const override;
210 std::pair<size_type, size_type> cellRange,
211 Storage & basisGradientData)
const override;
214 const dealii::Quadrature<dim> &
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: CFEBasisDataStorageDealii.h:57
const Storage & getBasisGradNiGradNjInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:2626
const Storage & getBasisHessianDataInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:1984
const dealii::Quadrature< dim > & getDealiiQuadratureRule() const
Definition: CFEBasisDataStorageDealii.t.cpp:2661
const Storage & getBasisDataInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:1940
const Storage & getBasisOverlapInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:2393
std::shared_ptr< const quadrature::QuadratureRuleContainer > d_quadratureRuleContainer
Definition: CFEBasisDataStorageDealii.h:223
~CFEBasisDataStorageDealii()=default
BasisStorageAttributesBoolMap d_basisStorageAttributesBoolMap
Definition: CFEBasisDataStorageDealii.h:225
std::vector< size_type > d_cellStartIdsBasisQuadStorage
Definition: CFEBasisDataStorageDealii.h:235
std::shared_ptr< const CFEBasisDofHandlerDealii< ValueTypeBasisCoeff, memorySpace, dim > > d_feBDH
Definition: CFEBasisDataStorageDealii.h:221
Storage getBasisData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2255
QuadratureRuleAttributes d_quadratureRuleAttributes
Definition: CFEBasisDataStorageDealii.h:224
dealii::Quadrature< dim > d_dealiiQuadratureRule
Definition: CFEBasisDataStorageDealii.h:239
Storage getJxWInCell(const size_type cellId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2221
std::shared_ptr< Storage > d_basisQuadStorage
Definition: CFEBasisDataStorageDealii.h:226
std::shared_ptr< Storage > d_basisGradNiGradNj
Definition: CFEBasisDataStorageDealii.h:228
void getBasisDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisData) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2066
Storage getBasisHessianData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2343
Storage getBasisGradientDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2536
std::vector< size_type > d_cellStartIdsBasisOverlap
Definition: CFEBasisDataStorageDealii.h:233
bool d_evaluateBasisData
Definition: CFEBasisDataStorageDealii.h:218
Storage getBasisHessianDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2556
void evaluateBasisData(const quadrature::QuadratureRuleAttributes &quadratureRuleAttributes, const BasisStorageAttributesBoolMap basisStorageAttributesBoolMap) override
Definition: CFEBasisDataStorageDealii.t.cpp:1253
std::shared_ptr< Storage > d_JxWStorage
Definition: CFEBasisDataStorageDealii.h:227
bool d_isUniformQuad
Definition: CFEBasisDataStorageDealii.h:240
void getBasisGradientDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisGradientData) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2144
void deleteBasisData() override
Definition: CFEBasisDataStorageDealii.t.cpp:2484
std::vector< size_type > d_nQuadPointsIncell
Definition: CFEBasisDataStorageDealii.h:234
std::shared_ptr< const BasisDofHandler > getBasisDofHandler() const override
Definition: CFEBasisDataStorageDealii.t.cpp:2648
std::shared_ptr< Storage > d_basisOverlap
Definition: CFEBasisDataStorageDealii.h:231
typename BasisDataStorage< ValueTypeBasisData, memorySpace >::Storage Storage
Definition: CFEBasisDataStorageDealii.h:62
std::shared_ptr< Storage > d_basisHessianQuadStorage
Definition: CFEBasisDataStorageDealii.h:230
const Storage & getBasisGradientDataInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:1962
Storage getBasisGradientData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2297
Storage getBasisOverlapInCell(const size_type cellId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2415
Storage getBasisDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2515
std::shared_ptr< Storage > d_basisGradientQuadStorage
Definition: CFEBasisDataStorageDealii.h:229
Storage getBasisOverlap(const size_type cellId, const size_type basisId1, const size_type basisId2) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2448
std::vector< size_type > d_dofsInCell
Definition: CFEBasisDataStorageDealii.h:232
const Storage & getJxWInAllCells() const override
Definition: CFEBasisDataStorageDealii.t.cpp:2006
std::vector< size_type > d_cellStartIdsBasisHessianQuadStorage
Definition: CFEBasisDataStorageDealii.h:237
std::shared_ptr< const quadrature::QuadratureRuleContainer > getQuadratureRuleContainer() const override
Definition: CFEBasisDataStorageDealii.t.cpp:2575
Storage getBasisGradNiGradNjInCell(const size_type cellId) const override
Definition: CFEBasisDataStorageDealii.t.cpp:2592
std::vector< size_type > d_cellStartIdsGradNiGradNj
Definition: CFEBasisDataStorageDealii.h:238
std::vector< size_type > d_cellStartIdsBasisGradientQuadStorage
Definition: CFEBasisDataStorageDealii.h:236
Definition: CFEBasisDofHandlerDealii.h:57
An abstract class to store and access data for a given basis, such as the basis function values on a ...
Definition: FEBasisDataStorage.h:54
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