forked from CrawfordGroup/ugacc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathccresp.cc
126 lines (91 loc) · 2.94 KB
/
ccresp.cc
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
116
117
118
119
120
121
122
123
124
125
126
#include "ccpert.h"
#include "ccresp.h"
using namespace std;
namespace psi { namespace ugacc {
CCResp::CCResp(shared_ptr<CCPert> X, shared_ptr<CCPert> Y)
{
H_ = X->H_;
CC_ = X->CC_;
HBAR_ = X->HBAR_;
Lambda_ = X->CCLambda_;
no_ = CC_->no_;
nv_ = CC_->nv_;
X_ = X;
Y_ = Y;
}
CCResp::~CCResp()
{
}
double CCResp::linresp(shared_ptr<CCPert> X, shared_ptr<CCPert> Y)
{
int no = no_ ;
int nv = nv_ ;
double **l1 = Lambda_->l1_;
double ****l2 = Lambda_->l2_;
double **X1_x = X->X1_ ;
double **Y1_x = X->Y1_ ;
double ****X2_x = X->X2_ ;
double ****Y2_x = X->Y2_ ;
double **X1_y = Y->X1_ ;
double **Y1_y = Y->Y1_ ;
double ****X2_y = Y->X2_ ;
double ****Y2_y = Y->Y2_ ;
double **pert_x = X->pert_;
double **pert_y = Y->pert_;
double **Aov_x = X->Aov_;
double **Aoo_x = X->Aoo_;
double **Avv_x = X->Avv_;
double **Avo_x = X->Avo_;
double ****Aovoo_x = X->Aovoo_;
double ****Avvvo_x = X->Avvvo_;
double ****Avvoo_x = X->Avvoo_;
double **Aov_y = Y->Aov_;
double **Aoo_y = Y->Aoo_;
double **Avv_y = Y->Avv_;
double **Avo_y = Y->Avo_;
double ****Aovoo_y = Y->Aovoo_;
double ****Avvvo_y = Y->Avvvo_;
double ****Avvoo_y = Y->Avvoo_;
double first=0;
double second=0;
double polar1=0, polar2=0, polar=0;
for (int i=0; i< no; i++)
for (int a=0; a< nv; a++){
polar1 += Avo_x[a][i] * Y1_y[i][a] ;
first += Avo_x[a][i] * Y1_y[i][a] ;
for (int j=0; j< no; j++)
for (int b=0; b< nv; b++){
polar1 += (0.50) * (Avvoo_x[a][b][i][j] + Avvoo_x[b][a][j][i])* Y2_y[i][j][a][b] ;
second += (0.50) * (Avvoo_x[a][b][i][j] + Avvoo_x[b][a][j][i])* Y2_y[i][j][a][b] ;
}
}
for (int i=0; i< no; i++)
for (int a=0; a< nv; a++){
for (int j=0; j< no; j++)
for (int b=0; b< nv; b++){
polar2 += l1[i][a] * pert_x[j][b+no] * (2.0 * X2_y[i][j][a][b] - X2_y[i][j][b][a]);
}
for (int c=0; c< nv; c++)
polar2 += l1[i][a] * Avv_x[a][c] * X1_y[i][c];
for (int k=0; k< no; k++)
polar2 -= l1[i][a] * Aoo_x[k][i] * X1_y[k][a];
for (int j=0; j< no; j++)
for (int b=0; b< nv; b++){
for (int c=0; c< nv; c++)
polar2 += l2[i][j][b][c] * X1_y[i][a] * Avvvo_x[b][c][a][j] ;
for (int k=0; k< no; k++){
polar2 -= 0.5 * l2[i][j][a][b] * X1_y[k][a] * Aovoo_x[k][b][i][j] ;
polar2 -= 0.5 * l2[i][j][a][b] * X1_y[k][b] * Aovoo_x[k][a][j][i] ;
polar2 -= 0.5 * l2[i][j][a][b] * (X2_y[k][j][a][b]) * Aoo_x[k][i] ;
polar2 -= 0.5 * l2[i][j][a][b] * (X2_y[k][i][b][a]) * Aoo_x[k][j] ;
}
for (int c=0; c< nv; c++){
polar2 += 0.5 * l2[i][j][a][b] * (X2_y[i][j][a][c]) * Avv_x[b][c] ;
polar2 += 0.5 * l2[i][j][a][b] * (X2_y[j][i][b][c]) * Avv_x[a][c] ;
}
}
polar2 += 2.0 * pert_x[i][a+no] * X1_y[i][a];
}
return -1.0 * (polar1 + polar2) ;
}
}} // psi::ugaccc