TBTK
Need a break? Support the development by playing Polarity Puzzles
HartreeFockPotentialOperator.h
1 /* Copyright 2018 Kristofer Björnson
2  *
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  * http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
17 
24 #ifndef COM_DAFER45_TBTK_HARTREE_FOCK_POTENTIAL_OPERATOR
25 #define COM_DAFER45_TBTK_HARTREE_FOCK_POTENTIAL_OPERATOR
26 
27 #include "TBTK/AbstractOperator.h"
28 
29 namespace TBTK{
30 
31 class HartreeFockPotentialOperator : public AbstractOperator{
32 public:
38  HartreeFockPotentialOperator(
39  const AbstractState &firstState,
40  const AbstractState &secondState
41  );
42 
47  HartreeFockPotentialOperator(
48  const HartreeFockPotentialOperator &hartreeFockPotentialOperator
49  );
50 
52  ~HartreeFockPotentialOperator();
53 
60  HartreeFockPotentialOperator& operator=(
61  const HartreeFockPotentialOperator &rhs
62  );
63 
67  const AbstractState& getFirstState() const;
68 
72  const AbstractState& getSecondState() const;
73 private:
75  AbstractState *firstState;
76 
78  AbstractState *secondState;
79 };
80 
81 inline HartreeFockPotentialOperator::HartreeFockPotentialOperator(
82  const AbstractState &firstState,
83  const AbstractState &secondState
84 ) :
85  AbstractOperator(OperatorID::HartreeFockPotential),
86  firstState(firstState.clone()),
87  secondState(secondState.clone())
88 {
89 }
90 
91 inline HartreeFockPotentialOperator::HartreeFockPotentialOperator(
92  const HartreeFockPotentialOperator &hartreeFockPotentialOperator
93 ) :
94  AbstractOperator(hartreeFockPotentialOperator)
95 {
96  firstState = hartreeFockPotentialOperator.firstState->clone();
97  secondState = hartreeFockPotentialOperator.secondState->clone();
98 }
99 
100 inline HartreeFockPotentialOperator::~HartreeFockPotentialOperator(){
101  delete firstState;
102  delete secondState;
103 }
104 
105 inline HartreeFockPotentialOperator& HartreeFockPotentialOperator::operator=(
106  const HartreeFockPotentialOperator &rhs
107 ){
108  if(this != &rhs){
109  firstState = rhs.firstState->clone();
110  secondState = rhs.secondState->clone();
111  }
112 
113  return *this;
114 }
115 
116 inline const AbstractState&
117 HartreeFockPotentialOperator::getFirstState() const{
118  return *firstState;
119 }
120 
121 inline const AbstractState&
122 HartreeFockPotentialOperator::getSecondState() const{
123  return *secondState;
124 }
125 
126 }; //End of namespace TBTK
127 
128 #endif
129