26#ifndef dftefeRayleighRitzEigenSolver_h
27#define dftefeRayleighRitzEigenSolver_h
41 namespace linearAlgebra
54 template <
typename ValueTypeOperator,
55 typename ValueTypeOperand,
82 const bool useScalpack =
true);
96 std::vector<RealType> & eigenValues,
98 bool computeEigenVectors =
false);
107 std::vector<RealType> & eigenValues,
109 bool computeEigenVectors =
false);
140 const bool &useBatched =
true);
144 const std::shared_ptr<const ProcessGrid> & processGrid,
Manager class for ELPA and ScaLAPACK.
Definition: ElpaScalapackManager.h:43
Definition: LinAlgOpContext.h:38
An class template to encapsulate a MultiVector. A MultiVector is a collection of vectors belonging t...
Definition: MultiVector.h:134
Abstract class to encapsulate the action of a discrete operator on vectors, matrices,...
Definition: OperatorContext.h:51
A derived class of OperatorContext to encapsulate the action of a discrete operator on vectors,...
Definition: RayleighRitzEigenSolver.h:58
size_type d_batchSizeSmall
Definition: RayleighRitzEigenSolver.h:151
const size_type d_eigenVecBatchSize
Definition: RayleighRitzEigenSolver.h:152
~RayleighRitzEigenSolver()=default
Default Destructor.
blasLapack::real_type< ValueType > RealType
Definition: RayleighRitzEigenSolver.h:68
const bool d_useScalapack
Definition: RayleighRitzEigenSolver.h:156
void computeXTransOpX(MultiVector< ValueTypeOperand, memorySpace > &X, utils::MemoryStorage< ValueType, memorySpace > &S, const OpContext &Op, const bool &useBatched=true)
Definition: RayleighRitzEigenSolver.t.cpp:488
const bool d_useELPA
Definition: RayleighRitzEigenSolver.h:155
blasLapack::scalar_type< ValueTypeOperator, ValueTypeOperand > ValueType
define ValueType as the superior (bigger set) of the ValueTypeOperator and ValueTypeOperand (e....
Definition: RayleighRitzEigenSolver.h:67
std::shared_ptr< MultiVector< ValueType, memorySpace > > d_XoutBatch
Definition: RayleighRitzEigenSolver.h:149
std::shared_ptr< MultiVector< ValueType, memorySpace > > d_XinBatchSmall
Definition: RayleighRitzEigenSolver.h:148
const ElpaScalapackManager * d_elpaScala
Definition: RayleighRitzEigenSolver.h:154
std::shared_ptr< MultiVector< ValueType, memorySpace > > d_XoutBatchSmall
Definition: RayleighRitzEigenSolver.h:149
std::shared_ptr< MultiVector< ValueType, memorySpace > > d_XinBatch
Definition: RayleighRitzEigenSolver.h:149
EigenSolverError solve(const OpContext &A, MultiVector< ValueTypeOperand, memorySpace > &X, std::vector< RealType > &eigenValues, MultiVector< ValueType, memorySpace > &eigenVectors, bool computeEigenVectors=false)
Definition: RayleighRitzEigenSolver.t.cpp:67
Scalapack wrapper adapted from dealii library and extended implementation to complex datatype.
Definition: ScalapackWrapper.h:43
Definition: MemoryStorage.h:38
A class template to store the communication pattern (i.e., which entries/nodes to receive from which ...
Definition: MPIPatternP2P.h:197
typeInternal::real_type< ValueType > real_type
Definition: BlasLapackTypedef.h:177
typeInternal::scalar_type< ValueType1, ValueType2 > scalar_type
Definition: BlasLapackTypedef.h:183
MemorySpace
Definition: MemorySpaceType.h:37
dealii includes
Definition: AtomFieldDataSpherical.cpp:31
unsigned int size_type
Definition: TypeConfig.h:8
Definition: LinearAlgebraTypes.h:147