forked from CrawfordGroup/ugacc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathccwfn.h
115 lines (94 loc) · 3.24 KB
/
ccwfn.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#ifndef CCWFN_H
#define CCWFN_H
#include "hamiltonian.h"
#include "psi4/libmints/mintshelper.h"
#include "psi4/libmints/molecule.h"
using namespace std;
namespace psi { namespace ugacc {
class CCWfn: public Wavefunction {
public:
CCWfn(shared_ptr<Wavefunction> reference, shared_ptr<Hamiltonian> H, Options &options);
virtual ~CCWfn();
protected:
std::string wfn_; // wfn type (CCSD, CCSD_T, etc.)
double convergence_; // conv. on RMS residual change between iterations
int maxiter_; // maximum number of iterations
bool do_diis_; // use DIIS algorithms?
bool ooc_; // Use out-of-core algorithms?
std::string dertype_; // Gradient level -- needed only for (T) gradients
int no_; // Number of active occupied MOs
int nv_; // Number of active virtual MOs
shared_ptr<Hamiltonian> H_; // integrals and Fock matrix
// Energy denominators
double **D1_;
double ****D2_;
// Ground-state T amplitudes
double **t1_; // Current T1
double **t1old_; // Previous iteration T1
double ****t2_; // Current T2
double ****t2old_; // Previous iteration T2
// DIIS-related vectors
std::vector<double> t1diis_;
std::vector<double> t2diis_;
std::vector<double> t1err_;
std::vector<double> t2err_;
// Effective doubles
double ****tau_; // tau(ijab) = t2(ijab) + t1(ia) * t1(jb)
double ****ttau_; // ttau(ijab) = t2(ijab) + (1/2) t1(ia) * t1(jb)
// Biorthogonal projection doubles
double **t1s_;
double ****t2s_;
// CCSD intermediates for amplitude equations (related to, but not the
// same as corresponding HBAR quantities)
double **Fvv_;
double **Foo_;
double **Fov_;
double ****Woooo_;
double ****Wovvo_;
double ****Wovov_;
// Extra contributions for (T) gradients
double ******t3_; // only for in-core code
double ******l3_; // only for in-core code
double **s1_;
double ****s2_;
double **Doo_;
double **Dvv_;
double **Dov_;
double ****Gooov_;
double ****Gvvvo_;
double ****Goovv_;
double energy();
void build_tau();
void amp_save();
void build_F();
void build_W();
void build_t1();
void build_t2();
void build_diis_error();
void save_diis_vectors();
double t1norm();
double increment_amps();
void build_tstar();
void print_amps();
double tcorr();
double tcorr_ooc();
double tcorr_ooc_TJL();
void tgrad();
void tgrad_ooc();
void t3_ijk(double ***t3, int i, int j, int k, double ****t2, double **fock, double ****ints);
void W3_ijk(double ***W3, int i, int j, int k, double ****t2, double ****ints);
void t3_abc(double ***t3, int a, int b, int c, double ****t2, double **fock, double ****ints);
void M3_ijk(double ***M3, int i, int j, int k, double ****t2, double **fock, double ****ints);
void M3_abc(double ***M3, int a, int b, int c, double ****t2, double **fock, double ****ints);
void N3_ijk(double ***N3, int i, int j, int k, double ****t2, double **t1, double **fock, double ****ints);
void N3_abc(double ***N3, int a, int b, int c, double ****t2, double **t1, double **fock, double ****ints);
public:
double compute_energy();
friend class HBAR;
friend class CCLambda;
friend class CCDensity;
friend class CCPert;
friend class CCResp;
}; // CCWfn
}} // psi::ugacc
#endif // CCWFN_H