DFT-EFE
 
Loading...
Searching...
No Matches
OrthoEFEOverlapOperatorContext.h
Go to the documentation of this file.
1/******************************************************************************
2 * Copyright (c) 2021. *
3 * The Regents of the University of Michigan and DFT-EFE developers. *
4 * *
5 * This file is part of the DFT-EFE code. *
6 * *
7 * DFT-EFE is free software: you can redistribute it and/or modify *
8 * it under the terms of the Lesser GNU General Public License as *
9 * published by the Free Software Foundation, either version 3 of *
10 * the License, or (at your option) any later version. *
11 * *
12 * DFT-EFE is distributed in the hope that it will be useful, but *
13 * WITHOUT ANY WARRANTY; without even the implied warranty *
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
15 * See the Lesser GNU General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU Lesser General Public *
18 * License at the top level of DFT-EFE distribution. If not, see *
19 * <https://www.gnu.org/licenses/>. *
20 ******************************************************************************/
21
22/*
23 * @author Avirup Sircar
24 */
25
26#ifndef dftefeOEFEOverlapOperatorContext_h
27#define dftefeOEFEOverlapOperatorContext_h
28
41#include <memory>
42
43namespace dftefe
44{
45 namespace basis
46 {
60 template <typename ValueTypeOperator,
61 typename ValueTypeOperand,
62 utils::MemorySpace memorySpace,
63 size_type dim>
65 : public linearAlgebra::
66 OperatorContext<ValueTypeOperator, ValueTypeOperand, memorySpace>
67 {
68 public:
75 using ValueType =
77 ValueTypeOperand>;
78
79 using Storage =
81
82 public:
96 const FEBasisManager<ValueTypeOperand,
97 ValueTypeOperator,
98 memorySpace,
99 dim> &feBasisManager,
101 &classicalBlockBasisDataStorage,
103 &enrichmentBlockEnrichmentBasisDataStorage,
105 & enrichmentBlockClassicalBasisDataStorage,
106 const size_type maxCellBlock,
107 const size_type maxFieldBlock,
109 linAlgOpContext,
110 const bool calculateWings = true);
111
125 const FEBasisManager<ValueTypeOperand,
126 ValueTypeOperator,
127 memorySpace,
128 dim> &feBasisManager,
130 &classicalBlockBasisDataStorage,
132 & enrichmentBlockBasisDataStorage,
133 const size_type maxCellBlock,
134 const size_type maxFieldBlock,
135 const bool calculateWings = true);
136
150 const FEBasisManager<ValueTypeOperand,
151 ValueTypeOperator,
152 memorySpace,
153 dim> &feBasisManager,
155 &classicalBlockGLLBasisDataStorage,
157 &enrichmentBlockBasisDataStorage,
159 linAlgOpContext);
160
174 const FEBasisManager<ValueTypeOperand,
175 ValueTypeOperator,
176 memorySpace,
177 dim> &feBasisManager,
179 &classicalBlockGLLBasisDataStorage,
181 &enrichmentBlockEnrichmentBasisDataStorage,
183 &enrichmentBlockClassicalBasisDataStorage,
185 linAlgOpContext);
186
188
192 void
195 bool updateGhostX = false,
196 bool updateGhostY = false) const override;
197
198 // get overlap of two basis functions in a cell
199 Storage
200 getBasisOverlap(const size_type cellId,
201 const size_type basisId1,
202 const size_type basisId2) const;
203
204 // get overlap of all the basis functions in a cell
205 Storage
206 getBasisOverlapInCell(const size_type cellId) const;
207
208 // get overlap of all the basis functions in all cells
209 const Storage &
211
212
213 private:
214 const FEBasisManager<ValueTypeOperand,
215 ValueTypeOperator,
216 memorySpace,
218 std::shared_ptr<Storage> d_basisOverlap;
219 std::vector<size_type> d_cellStartIdsBasisOverlap;
220 std::vector<size_type> d_dofsInCell;
223
225 std::shared_ptr<linearAlgebra::Vector<ValueTypeOperator, memorySpace>>
227 std::shared_ptr<utils::MemoryStorage<ValueTypeOperator, memorySpace>>
229 const EFEBasisDofHandler<ValueTypeOperand,
230 ValueTypeOperator,
231 memorySpace,
234
235 }; // end of class OrthoEFEOverlapOperatorContext
236 } // end of namespace basis
237} // end of namespace dftefe
239#endif // dftefeOEFEOverlapOperatorContext_h
Definition: EFEBasisDofHandler.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
An abstract class to encapsulate the partitioning of a finite element basis across multiple processor...
Definition: FEBasisManager.h:44
A derived class of linearAlgebra::OperatorContext to encapsulate the action of a discrete operator on...
Definition: OrthoEFEOverlapOperatorContext.h:67
std::shared_ptr< linearAlgebra::Vector< ValueTypeOperator, memorySpace > > d_diagonal
Definition: OrthoEFEOverlapOperatorContext.h:226
const FEBasisManager< ValueTypeOperand, ValueTypeOperator, memorySpace, dim > * d_feBasisManager
Definition: OrthoEFEOverlapOperatorContext.h:217
linearAlgebra::blasLapack::scalar_type< ValueTypeOperator, ValueTypeOperand > ValueType
define ValueType as the superior (bigger set) of the ValueTypeOperator and ValueTypeOperand (e....
Definition: OrthoEFEOverlapOperatorContext.h:77
Storage getBasisOverlap(const size_type cellId, const size_type basisId1, const size_type basisId2) const
Definition: OrthoEFEOverlapOperatorContext.t.cpp:2007
std::vector< size_type > d_dofsInCell
Definition: OrthoEFEOverlapOperatorContext.h:220
std::shared_ptr< utils::MemoryStorage< ValueTypeOperator, memorySpace > > d_basisOverlapEnrichmentBlock
Definition: OrthoEFEOverlapOperatorContext.h:228
bool d_isMassLumping
Definition: OrthoEFEOverlapOperatorContext.h:224
void apply(linearAlgebra::MultiVector< ValueTypeOperand, memorySpace > &X, linearAlgebra::MultiVector< ValueType, memorySpace > &Y, bool updateGhostX=false, bool updateGhostY=false) const override
Apply AX = B where A is the discretized matrix, X is the operand and B is the result.
Definition: OrthoEFEOverlapOperatorContext.t.cpp:1797
std::shared_ptr< Storage > d_basisOverlap
Definition: OrthoEFEOverlapOperatorContext.h:218
size_type d_nglobalEnrichmentIds
Definition: OrthoEFEOverlapOperatorContext.h:233
const size_type d_maxCellBlock
Definition: OrthoEFEOverlapOperatorContext.h:221
const EFEBasisDofHandler< ValueTypeOperand, ValueTypeOperator, memorySpace, dim > * d_efebasisDofHandler
Definition: OrthoEFEOverlapOperatorContext.h:232
std::vector< size_type > d_cellStartIdsBasisOverlap
Definition: OrthoEFEOverlapOperatorContext.h:219
const Storage & getBasisOverlapInAllCells() const
Definition: OrthoEFEOverlapOperatorContext.t.cpp:1970
Storage getBasisOverlapInCell(const size_type cellId) const
Definition: OrthoEFEOverlapOperatorContext.t.cpp:1983
const size_type d_maxFieldBlock
Definition: OrthoEFEOverlapOperatorContext.h:222
Definition: LinAlgOpContext.h:38
An class template to encapsulate a MultiVector. A MultiVector is a collection of vectors belonging t...
Definition: MultiVector.h:134
blas::scalar_type< ValueType1, ValueType2 > scalar_type
Definition: BlasLapackTypedef.h:70
MemorySpace
Definition: MemorySpaceType.h:37
dealii includes
Definition: AtomFieldDataSpherical.cpp:31
unsigned int size_type
Definition: TypeConfig.h:8