26#ifndef dftefeCFEBDSOnTheFlyComputeDealii_h
27#define dftefeCFEBDSOnTheFlyComputeDealii_h
51 template <
typename ValueTypeBasisCoeff,
52 typename ValueTypeBasisData,
65 std::shared_ptr<const BasisDofHandler> feBDH,
73 std::shared_ptr<const BasisDofHandler>
85 std::shared_ptr<const quadrature::QuadratureRuleContainer>
86 quadratureRuleContainer,
93 std::vector<std::shared_ptr<const quadrature::QuadratureRule>>
101 std::shared_ptr<const quadrature::QuadratureRule>
102 baseQuadratureRuleAdaptive,
103 std::vector<std::shared_ptr<const utils::ScalarSpatialFunctionReal>>
105 const std::vector<double> & absoluteTolerances,
106 const std::vector<double> & relativeTolerances,
107 const std::vector<double> & integralThresholds,
108 const double smallestCellVolume,
109 const unsigned int maxRecursion,
182 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;
216 const dealii::Quadrature<dim> &
224 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: CFEBDSOnTheFlyComputeDealii.h:57
const Storage & getJxWInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1014
std::vector< size_type > d_cellStartIdsBasisQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:237
Storage getBasisOverlap(const size_type cellId, const size_type basisId1, const size_type basisId2) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1451
std::vector< size_type > d_cellStartIdsBasisJacobianInvQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:235
std::shared_ptr< const CFEBasisDofHandlerDealii< ValueTypeBasisCoeff, memorySpace, dim > > d_feBDH
Definition: CFEBDSOnTheFlyComputeDealii.h:223
const dealii::Quadrature< dim > & getDealiiQuadratureRule() const
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1633
const Storage & getBasisHessianDataInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:992
Storage getBasisDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1504
std::shared_ptr< Storage > d_JxWStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:229
const Storage & getBasisOverlapInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1415
void deleteBasisData() override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1471
const Storage & getBasisDataInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:951
const Storage & getBasisGradientDataInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:973
std::shared_ptr< const BasisDofHandler > getBasisDofHandler() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1620
void getBasisDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisData) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1074
~CFEBDSOnTheFlyComputeDealii()=default
std::shared_ptr< Storage > d_basisGradientParaCellQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:230
void getBasisGradientDataInCellRange(std::pair< size_type, size_type > cellRange, Storage &basisGradientData) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1153
Storage getBasisOverlapInCell(const size_type cellId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1433
Storage getBasisData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1287
const Storage & getBasisGradNiGradNjInAllCells() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1601
Storage getBasisHessianData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1368
dealii::Quadrature< dim > d_dealiiQuadratureRule
Definition: CFEBDSOnTheFlyComputeDealii.h:241
size_type d_maxCellBlock
Definition: CFEBDSOnTheFlyComputeDealii.h:238
Storage getBasisGradNiGradNjInCell(const size_type cellId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1581
std::vector< size_type > d_cellStartIdsBasisHessianQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:236
Storage getBasisHessianDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1545
std::shared_ptr< Storage > d_basisHessianQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:232
std::shared_ptr< Storage > d_tmpGradientBlock
Definition: CFEBDSOnTheFlyComputeDealii.h:239
typename BasisDataStorage< ValueTypeBasisData, memorySpace >::Storage Storage
Definition: CFEBDSOnTheFlyComputeDealii.h:62
BasisStorageAttributesBoolMap d_basisStorageAttributesBoolMap
Definition: CFEBDSOnTheFlyComputeDealii.h:227
linearAlgebra::LinAlgOpContext< memorySpace > & d_linAlgOpContext
Definition: CFEBDSOnTheFlyComputeDealii.h:240
std::shared_ptr< Storage > d_basisQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:228
QuadratureRuleAttributes d_quadratureRuleAttributes
Definition: CFEBDSOnTheFlyComputeDealii.h:226
Storage getBasisGradientData(const QuadraturePointAttributes &attributes, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1327
std::shared_ptr< const quadrature::QuadratureRuleContainer > getQuadratureRuleContainer() const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1564
std::shared_ptr< const quadrature::QuadratureRuleContainer > d_quadratureRuleContainer
Definition: CFEBDSOnTheFlyComputeDealii.h:225
Storage getJxWInCell(const size_type cellId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1252
Storage getBasisGradientDataInCell(const size_type cellId, const size_type basisId) const override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:1525
std::shared_ptr< Storage > d_basisJacobianInvQuadStorage
Definition: CFEBDSOnTheFlyComputeDealii.h:231
std::vector< size_type > d_dofsInCell
Definition: CFEBDSOnTheFlyComputeDealii.h:233
void evaluateBasisData(const quadrature::QuadratureRuleAttributes &quadratureRuleAttributes, const BasisStorageAttributesBoolMap basisStorageAttributesBoolMap) override
Definition: CFEBDSOnTheFlyComputeDealii.t.cpp:583
bool d_evaluateBasisData
Definition: CFEBDSOnTheFlyComputeDealii.h:220
std::vector< size_type > d_nQuadPointsIncell
Definition: CFEBDSOnTheFlyComputeDealii.h:234
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
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