DFT-FE 1.1.0-pre
Density Functional Theory With Finite-Elements
Loading...
Searching...
No Matches
dftfe::ExcSSDFunctionalBaseClass< memorySpace > Class Template Referenceabstract

This class provides the structure for all Exc functionals that can be written as a combination of functional of Single Slater determinant that results in a non-multiplicative potential plus a remainder functional dependent on density and Tau. More...

#include <ExcSSDFunctionalBaseClass.h>

Inheritance diagram for dftfe::ExcSSDFunctionalBaseClass< memorySpace >:
dftfe::ExcDFTPlusU< ValueType, memorySpace > dftfe::excDensityGGAClass< memorySpace > dftfe::excDensityLDAClass< memorySpace > dftfe::excDensityLLMGGAClass< memorySpace >

Public Member Functions

 ExcSSDFunctionalBaseClass (const ExcFamilyType excFamType, const densityFamilyType densityFamType, const std::vector< DensityDescriptorDataAttributes > &densityDescriptorAttributesList)
 
virtual ~ExcSSDFunctionalBaseClass ()
 
const std::vector< DensityDescriptorDataAttributes > & getDensityDescriptorAttributesList () const
 
densityFamilyType getDensityBasedFamilyType () const
 
virtual void applyWaveFunctionDependentFuncDerWrtPsi (const dftfe::linearAlgebra::MultiVector< dataTypes::number, memorySpace > &src, dftfe::linearAlgebra::MultiVector< dataTypes::number, memorySpace > &dst, const unsigned int inputVecSize, const unsigned int kPointIndex, const unsigned int spinIndex)=0
 
virtual void applyWaveFunctionDependentFuncDerWrtPsi (const dftfe::linearAlgebra::MultiVector< dataTypes::numberFP32, memorySpace > &src, dftfe::linearAlgebra::MultiVector< dataTypes::numberFP32, memorySpace > &dst, const unsigned int inputVecSize, const unsigned int kPointIndex, const unsigned int spinIndex)=0
 
virtual void updateWaveFunctionDependentFuncDerWrtPsi (const std::shared_ptr< AuxDensityMatrix< memorySpace > > &auxDensityMatrixPtr, const std::vector< double > &kPointWeights)=0
 
virtual void computeWaveFunctionDependentExcEnergy (const std::shared_ptr< AuxDensityMatrix< memorySpace > > &auxDensityMatrix, const std::vector< double > &kPointWeights)=0
 
virtual double getWaveFunctionDependentExcEnergy ()=0
 
virtual double getExpectationOfWaveFunctionDependentExcFuncDerWrtPsi ()=0
 
virtual void computeRhoTauDependentXCData (AuxDensityMatrix< memorySpace > &auxDensityMatrix, const std::vector< double > &quadPoints, std::unordered_map< xcRemainderOutputDataAttributes, std::vector< double > > &xDataOut, std::unordered_map< xcRemainderOutputDataAttributes, std::vector< double > > &cDataout) const =0
 
ExcFamilyType getExcFamilyType () const
 
virtual void checkInputOutputDataAttributesConsistency (const std::vector< xcRemainderOutputDataAttributes > &outputDataAttributes) const =0
 
virtual void reinitKPointDependentVariables (unsigned int kPointIndex)=0
 

Protected Attributes

const std::vector< DensityDescriptorDataAttributesd_densityDescriptorAttributesList
 
ExcFamilyType d_ExcFamilyType
 
densityFamilyType d_densityFamilyType
 

Detailed Description

template<dftfe::utils::MemorySpace memorySpace>
class dftfe::ExcSSDFunctionalBaseClass< memorySpace >

This class provides the structure for all Exc functionals that can be written as a combination of functional of Single Slater determinant that results in a non-multiplicative potential plus a remainder functional dependent on density and Tau.

Exc = S{\phi} + R [\rho, \tau]

Author
Vishal Subramanian, Sambit Das

Constructor & Destructor Documentation

◆ ExcSSDFunctionalBaseClass()

template<dftfe::utils::MemorySpace memorySpace>
dftfe::ExcSSDFunctionalBaseClass< memorySpace >::ExcSSDFunctionalBaseClass ( const ExcFamilyType excFamType,
const densityFamilyType densityFamType,
const std::vector< DensityDescriptorDataAttributes > & densityDescriptorAttributesList )

◆ ~ExcSSDFunctionalBaseClass()

template<dftfe::utils::MemorySpace memorySpace>
dftfe::ExcSSDFunctionalBaseClass< memorySpace >::~ExcSSDFunctionalBaseClass ( )
virtual

Member Function Documentation

◆ applyWaveFunctionDependentFuncDerWrtPsi() [1/2]

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::applyWaveFunctionDependentFuncDerWrtPsi ( const dftfe::linearAlgebra::MultiVector< dataTypes::number, memorySpace > & src,
dftfe::linearAlgebra::MultiVector< dataTypes::number, memorySpace > & dst,
const unsigned int inputVecSize,
const unsigned int kPointIndex,
const unsigned int spinIndex )
pure virtual

◆ applyWaveFunctionDependentFuncDerWrtPsi() [2/2]

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::applyWaveFunctionDependentFuncDerWrtPsi ( const dftfe::linearAlgebra::MultiVector< dataTypes::numberFP32, memorySpace > & src,
dftfe::linearAlgebra::MultiVector< dataTypes::numberFP32, memorySpace > & dst,
const unsigned int inputVecSize,
const unsigned int kPointIndex,
const unsigned int spinIndex )
pure virtual

◆ checkInputOutputDataAttributesConsistency()

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::checkInputOutputDataAttributesConsistency ( const std::vector< xcRemainderOutputDataAttributes > & outputDataAttributes) const
pure virtual

◆ computeRhoTauDependentXCData()

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::computeRhoTauDependentXCData ( AuxDensityMatrix< memorySpace > & auxDensityMatrix,
const std::vector< double > & quadPoints,
std::unordered_map< xcRemainderOutputDataAttributes, std::vector< double > > & xDataOut,
std::unordered_map< xcRemainderOutputDataAttributes, std::vector< double > > & cDataout ) const
pure virtual

x and c denotes exchange and correlation respectively. This function computes the rho and tau dependent part of the Exc functional energy density and its partial derivatives

Implemented in dftfe::excDensityGGAClass< memorySpace >, dftfe::excDensityLDAClass< memorySpace >, dftfe::excDensityLLMGGAClass< memorySpace >, and dftfe::ExcDFTPlusU< ValueType, memorySpace >.

◆ computeWaveFunctionDependentExcEnergy()

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::computeWaveFunctionDependentExcEnergy ( const std::shared_ptr< AuxDensityMatrix< memorySpace > > & auxDensityMatrix,
const std::vector< double > & kPointWeights )
pure virtual

◆ getDensityBasedFamilyType()

template<dftfe::utils::MemorySpace memorySpace>
densityFamilyType dftfe::ExcSSDFunctionalBaseClass< memorySpace >::getDensityBasedFamilyType ( ) const

◆ getDensityDescriptorAttributesList()

template<dftfe::utils::MemorySpace memorySpace>
const std::vector< DensityDescriptorDataAttributes > & dftfe::ExcSSDFunctionalBaseClass< memorySpace >::getDensityDescriptorAttributesList ( ) const

◆ getExcFamilyType()

template<dftfe::utils::MemorySpace memorySpace>
ExcFamilyType dftfe::ExcSSDFunctionalBaseClass< memorySpace >::getExcFamilyType ( ) const

◆ getExpectationOfWaveFunctionDependentExcFuncDerWrtPsi()

template<dftfe::utils::MemorySpace memorySpace>
virtual double dftfe::ExcSSDFunctionalBaseClass< memorySpace >::getExpectationOfWaveFunctionDependentExcFuncDerWrtPsi ( )
pure virtual

◆ getWaveFunctionDependentExcEnergy()

◆ reinitKPointDependentVariables()

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::reinitKPointDependentVariables ( unsigned int kPointIndex)
pure virtual

◆ updateWaveFunctionDependentFuncDerWrtPsi()

template<dftfe::utils::MemorySpace memorySpace>
virtual void dftfe::ExcSSDFunctionalBaseClass< memorySpace >::updateWaveFunctionDependentFuncDerWrtPsi ( const std::shared_ptr< AuxDensityMatrix< memorySpace > > & auxDensityMatrixPtr,
const std::vector< double > & kPointWeights )
pure virtual

Member Data Documentation

◆ d_densityDescriptorAttributesList

template<dftfe::utils::MemorySpace memorySpace>
const std::vector<DensityDescriptorDataAttributes> dftfe::ExcSSDFunctionalBaseClass< memorySpace >::d_densityDescriptorAttributesList
protected

◆ d_densityFamilyType

template<dftfe::utils::MemorySpace memorySpace>
densityFamilyType dftfe::ExcSSDFunctionalBaseClass< memorySpace >::d_densityFamilyType
protected

◆ d_ExcFamilyType

template<dftfe::utils::MemorySpace memorySpace>
ExcFamilyType dftfe::ExcSSDFunctionalBaseClass< memorySpace >::d_ExcFamilyType
protected

The documentation for this class was generated from the following files: