DFT-EFE
 
Loading...
Searching...
No Matches
ElectrostaticExcFE.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 dftefeElectrostaticExcFE_h
27#define dftefeElectrostaticExcFE_h
28
31
32namespace dftefe
33{
34 namespace ksdft
35 {
36 template <typename ValueTypeElectrostaticsCoeff,
37 typename ValueTypeElectrostaticsBasis,
38 typename ValueTypeWaveFunctionCoeff,
39 typename ValueTypeWaveFunctionBasis,
40 utils::MemorySpace memorySpace,
41 size_type dim>
43 : public Hamiltonian<
44 linearAlgebra::blasLapack::scalar_type<ValueTypeElectrostaticsBasis,
45 ValueTypeWaveFunctionBasis>,
46 memorySpace>,
47 public Energy<linearAlgebra::blasLapack::real_type<
48 linearAlgebra::blasLapack::scalar_type<
49 linearAlgebra::blasLapack::scalar_type<ValueTypeElectrostaticsBasis,
50 ValueTypeWaveFunctionBasis>,
51 linearAlgebra::blasLapack::scalar_type<
52 ValueTypeElectrostaticsCoeff,
53 ValueTypeWaveFunctionCoeff>>>>
54 {
55 public:
57 linearAlgebra::blasLapack::scalar_type<ValueTypeElectrostaticsBasis,
58 ValueTypeWaveFunctionBasis>;
60 linearAlgebra::blasLapack::scalar_type<ValueTypeElectrostaticsCoeff,
61 ValueTypeWaveFunctionCoeff>;
62 using ValueType =
66
68
69 public:
74 std::shared_ptr<const ElectrostaticFE<ValueTypeElectrostaticsBasis,
75 ValueTypeElectrostaticsCoeff,
76 ValueTypeWaveFunctionBasis,
77 memorySpace,
78 dim>> electroHamiltonian,
79 std::shared_ptr<const ExchangeCorrelationFE<ValueTypeWaveFunctionBasis,
80 ValueTypeWaveFunctionCoeff,
81 memorySpace,
82 dim>> excHamiltonian);
83
85
86 void
87 reinit(
88 std::shared_ptr<const ElectrostaticFE<ValueTypeElectrostaticsBasis,
89 ValueTypeElectrostaticsCoeff,
90 ValueTypeWaveFunctionBasis,
91 memorySpace,
92 dim>> electroHamiltonian,
93 std::shared_ptr<const ExchangeCorrelationFE<ValueTypeWaveFunctionBasis,
94 ValueTypeWaveFunctionCoeff,
95 memorySpace,
96 dim>> excHamiltonian);
97
98 void
99 getLocal(Storage &cellWiseStorage) const override;
100
102 getEnergy() const override;
103
104 private:
105 std::shared_ptr<const ElectrostaticFE<ValueTypeElectrostaticsBasis,
106 ValueTypeElectrostaticsCoeff,
107 ValueTypeWaveFunctionBasis,
108 memorySpace,
109 dim>>
111 std::shared_ptr<const ExchangeCorrelationFE<ValueTypeWaveFunctionBasis,
112 ValueTypeWaveFunctionCoeff,
113 memorySpace,
114 dim>>
116
117 }; // end of class ElectrostaticExcFE
118 } // end of namespace ksdft
119} // end of namespace dftefe
121#endif // dftefeElectrostaticExcFE_h
Definition: ElectrostaticExcFE.h:54
void getLocal(Storage &cellWiseStorage) const override
Definition: ElectrostaticExcFE.t.cpp:100
linearAlgebra::blasLapack::scalar_type< ValueTypeElectrostaticsBasis, ValueTypeWaveFunctionBasis > ValueTypeOperator
Definition: ElectrostaticExcFE.h:58
std::shared_ptr< const ExchangeCorrelationFE< ValueTypeWaveFunctionBasis, ValueTypeWaveFunctionCoeff, memorySpace, dim > > d_excHamiltonian
Definition: ElectrostaticExcFE.h:115
linearAlgebra::blasLapack::scalar_type< ValueTypeElectrostaticsCoeff, ValueTypeWaveFunctionCoeff > ValueTypeOperand
Definition: ElectrostaticExcFE.h:61
linearAlgebra::blasLapack::real_type< ValueType > RealType
Definition: ElectrostaticExcFE.h:65
std::shared_ptr< const ElectrostaticFE< ValueTypeElectrostaticsBasis, ValueTypeElectrostaticsCoeff, ValueTypeWaveFunctionBasis, memorySpace, dim > > d_electroHamiltonian
Definition: ElectrostaticExcFE.h:110
RealType getEnergy() const override
Definition: ElectrostaticExcFE.t.cpp:139
void reinit(std::shared_ptr< const ElectrostaticFE< ValueTypeElectrostaticsBasis, ValueTypeElectrostaticsCoeff, ValueTypeWaveFunctionBasis, memorySpace, dim > > electroHamiltonian, std::shared_ptr< const ExchangeCorrelationFE< ValueTypeWaveFunctionBasis, ValueTypeWaveFunctionCoeff, memorySpace, dim > > excHamiltonian)
Definition: ElectrostaticExcFE.t.cpp:73
linearAlgebra::blasLapack::scalar_type< ValueTypeOperator, ValueTypeOperator > ValueType
Definition: ElectrostaticExcFE.h:64
A derived class of linearAlgebra::OperatorContext to encapsulate the action of a discrete operator on...
Definition: ElectrostaticFE.h:65
Definition: Energy.h:35
Definition: ExchangeCorrelationFE.h:51
Definition: Hamiltonian.h:35
Definition: MemoryStorage.h:38
blas::scalar_type< ValueType1, ValueType2 > scalar_type
Definition: BlasLapackTypedef.h:70
blas::real_type< ValueType > real_type
Definition: BlasLapackTypedef.h:64
MemorySpace
Definition: MemorySpaceType.h:37
dealii includes
Definition: AtomFieldDataSpherical.cpp:31
unsigned int size_type
Definition: TypeConfig.h:8