3
3
#include <libdpd/dpd.h>
4
#include <libciomr/libciomr.h>
7
void build_ZIjAb(char *, char *, int, double, char *, char *, int, double);
9
/* LHX1Y1(): Computes the <0|L*(HBAR*X1*Y1)c |0> contributions to the
10
** linear response function. Note that most of the work is actually
11
** already done in other codes because the contractions may all be
12
** formulated in as products of X1*Y1 with L*HBAR, the latter of which
13
** are referred to in this code as "lambda residuals".
15
** Type-I residuals are taken directly from cclambda: L2*D, L2*Wmnij,
16
** L2*Wabef, L2*Wamef, L2*Wmnie, and L2*three-body-terms.
18
** Type-II residuals are computed once in lambda_residuals(): L1*Fme
24
void build_XY(char *, char *, int, double, char *, char *, int, double);
9
26
double LHX1Y1(char *pert_x, char *cart_x, int irrep_x, double omega_x,
10
27
char *pert_y, char *cart_y, int irrep_y, double omega_y)
13
dpdfile2 F, X1, Y1, Zmi, Zae, Zfb, Znj, ZIA, L1, t1;
30
dpdfile2 F, X1, Y1, Zmi, Zae_1, Zae_2, Zfb, Znj, ZIA, L1, t1, z;
14
31
dpdbuf4 Z1, Z2, I, tau, W1, W2, ZIjAb, L2, T2, W, Z;
18
/* The Lambda 1 contractions */
19
dpd_file2_init(&ZIA, CC_TMP0, 0, 0, 1, "ZIA");
20
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_x, cart_x, omega_x);
21
dpd_file2_init(&X1, CC_OEI, irrep_x, 0, 1, lbl);
22
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_y, cart_y, omega_y);
23
dpd_file2_init(&Y1, CC_OEI, irrep_y, 0, 1, lbl);
25
/* Contraction of FME, XIE, YMA */
26
dpd_file2_init(&F, CC_OEI, 0, 0, 1, "FME");
27
sprintf(lbl, "Z_%s_%1s_MI" , pert_x, cart_x);
28
dpd_file2_init(&Zmi, CC_TMP0, irrep_x, 0, 0, lbl);
29
dpd_contract222(&F, &X1, &Zmi, 0, 0, 1, 0);
31
dpd_contract222(&Zmi, &Y1, &ZIA, 1, 1, -1, 0);
33
/* Contraction of FME, XMA, YIE */
34
dpd_file2_init(&F, CC_OEI, 0, 0, 1, "FME");
35
dpd_file2_init(&Zmi, CC_TMP0, irrep_x, 0, 0, lbl);
36
dpd_contract222(&F, &Y1, &Zmi, 0, 0, 1, 0);
38
dpd_contract222(&Zmi, &X1, &ZIA, 1, 1, -1, 1);
39
dpd_file2_close(&Zmi);
41
/* Contraction of WAMEF, XIE, YMF */
42
sprintf(lbl, "Z_%s_%1s_AE" , pert_y, cart_y);
43
dpd_file2_init(&Zae, CC_TMP0, irrep_y, 1, 1, lbl);
44
dpd_buf4_init(&W1, CC_HBAR, 0, 11, 5, 11, 5, 0, "WAmEf 2(Am,Ef) - (Am,fE)");
45
dpd_dot24(&Y1, &W1, &Zae, 0, 0, 1, 0);
47
dpd_contract222(&X1, &Zae, &ZIA, 0, 0, 1, 1);
49
/* Contraction of WAMEF, XMF, YIE */
50
dpd_buf4_init(&W1, CC_HBAR, 0, 11, 5, 11, 5, 0, "WAmEf 2(Am,Ef) - (Am,fE)");
51
dpd_dot24(&X1, &W1, &Zae, 0, 0, 1, 0);
53
dpd_contract222(&Y1, &Zae, &ZIA, 0, 0, 1, 1);
54
dpd_file2_close(&Zae);
56
/* Contraction of WAMEF, XMA, YNE */
57
sprintf(lbl, "Z_%s_%1s_MI" , pert_y, cart_y);
58
dpd_file2_init(&Zmi, CC_TMP0, irrep_y, 0, 0, lbl);
59
dpd_buf4_init(&W1, CC_HBAR, 0, 0, 11, 0, 11, 0, "WMnIe - 2WnMIe");
60
dpd_dot13(&Y1, &W1, &Zmi, 0, 0, 1, 0);
62
dpd_contract222(&Zmi, &X1, &ZIA, 1, 1, 1, 1);
64
/* Contraction of WAMEF, XMA, YNE */
65
dpd_buf4_init(&W1, CC_HBAR, 0, 0, 11, 0, 11, 0, "WMnIe - 2WnMIe");
66
dpd_dot13(&X1, &W1, &Zmi, 0, 0, 1, 0);
68
dpd_contract222(&Zmi, &Y1, &ZIA, 1, 1, 1, 1);
69
dpd_file2_close(&Zmi);
74
/* Final contraction of ZIA intermediate with LIA */
75
dpd_file2_init(&L1, CC_OEI, 0, 0, 1, "LIA");
76
polar = 2.0 * dpd_file2_dot(&ZIA, &L1);
78
dpd_file2_close(&ZIA);
80
/* fprintf(outfile, "L(1)HX1Y1 = %20.12f\n", polar); */
82
/* The Lambda 2 contractions */
83
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_x, cart_x, omega_x);
84
dpd_file2_init(&X1, CC_OEI, irrep_x, 0, 1, lbl);
85
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_y, cart_y, omega_y);
86
dpd_file2_init(&Y1, CC_OEI, irrep_y, 0, 1, lbl);
89
/* Contraction of Wmnij with Zmnab */
90
dpd_buf4_init(&ZIjAb, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) Final");
91
dpd_buf4_scm(&ZIjAb, 0);
92
build_ZIjAb(pert_x, cart_x, irrep_x, omega_x, pert_y, cart_y, irrep_y, omega_y);
93
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
94
dpd_buf4_init(&W1, CC_HBAR, 0, 0, 0, 0, 0, 0, "WMnIj");
95
dpd_contract444(&W1, &Z1, &ZIjAb, 1, 1, 1, 0);
98
dpd_buf4_close(&ZIjAb);
100
/* Contraction of Wabef with Zijef */
101
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
103
dpd_buf4_init(&Z2, CC_TMP1, 0, 5, 0, 5, 0, 0, "Z(Ab,Ij)");
104
dpd_buf4_init(&I, CC_BINTS, 0, 5, 5, 5, 5, 0, "B <ab|cd>");
105
dpd_contract444(&I, &Z1, &Z2, 0, 0, 1, 0);
107
dpd_buf4_sort_axpy(&Z2, CC_TMP0, rspq, 0, 5, "Z(Ij,Ab) Final", 1);
110
dpd_buf4_init(&ZIjAb, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) Final");
111
dpd_buf4_init(&Z2, CC_TMP0, 0, 0, 11, 0, 11, 0, "Z(ij,am)");
112
dpd_buf4_init(&I, CC_FINTS, 0, 11, 5, 11, 5, 0, "F <ai|bc>");
113
dpd_contract444(&Z1, &I, &Z2, 0, 0, -2, 0);
115
dpd_file2_init(&t1, CC_OEI, 0, 0, 1, "tIA");
116
dpd_contract424(&Z2, &t1, &ZIjAb, 3, 0, 0, 1, 1);
117
dpd_file2_close(&t1);
119
dpd_buf4_init(&Z2, CC_TMP0, 0, 0, 0, 0, 0, 0, "Z(Ij,Mn)");
120
dpd_buf4_init(&I, CC_DINTS, 0, 0, 5, 0, 5, 0, "D <ij|ab>");
121
dpd_contract444(&Z1, &I, &Z2, 0, 0, 1, 0);
123
dpd_buf4_init(&tau, CC_TAMPS, 0, 0, 5, 0, 5, 0, "tauIjAb");
124
dpd_contract444(&Z2, &tau, &ZIjAb, 0, 1, 1, 1);
125
dpd_buf4_close(&tau);
128
dpd_buf4_close(&ZIjAb);
130
/* Contraction of Wmbej with Xie, Yma and Xma, Yie */
131
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
132
dpd_buf4_sort(&Z1, CC_TMP0, psqr, 10, 10, "Z(Ib,jA) anti");
135
dpd_buf4_init(&Z2, CC_TMP0, 0, 10, 10, 10, 10, 0, "Z(IA,jb) I");
136
dpd_buf4_init(&Z1, CC_TMP0, 0, 10, 10, 10, 10, 0, "Z(Ib,jA) anti");
137
dpd_buf4_init(&W1, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
138
dpd_contract444(&Z1, &W1, &Z2, 0, 1, -1, 0);
141
dpd_buf4_sort(&Z2, CC_TMP0, prqs, 0, 5, "Z(Ij,Ab) I");
144
dpd_buf4_init(&Z2, CC_TMP0, 0, 10, 10, 10, 10, 0, "Z(jA,Ib) II");
145
dpd_buf4_init(&Z1, CC_TMP0, 0, 10, 10, 10, 10, 0, "Z(Ib,jA) anti");
146
dpd_buf4_init(&W1, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
147
dpd_contract444(&Z1, &W1, &Z2, 0, 1, 1, 0);
150
dpd_buf4_sort(&Z2, CC_TMP0, rpqs, 0, 5, "Z(Ij,Ab) II");
153
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) I");
154
dpd_buf4_init(&Z2, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) II");
155
dpd_buf4_axpy(&Z2, &Z1, 1);
157
dpd_buf4_sort_axpy(&Z1, CC_TMP0, qpsr, 0, 5, "Z(Ij,Ab) Final", 1);
158
dpd_buf4_init(&ZIjAb, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) Final");
159
dpd_buf4_axpy(&Z1, &ZIjAb, 1);
161
dpd_buf4_close(&ZIjAb);
164
dpd_buf4_init(&ZIjAb, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) Final");
166
/* Contraction of Wmaneij with X and Y */
167
dpd_file2_init(&Zfb, CC_TMP0, 0, 1, 1, "Z_fb");
168
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
169
dpd_buf4_init(&I, CC_DINTS, 0, 0, 5, 0, 5, 0, "D 2<ij|ab> - <ij|ba>");
170
dpd_contract442(&I, &Z1, &Zfb, 3, 3, -1, 0);
174
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) temp");
175
dpd_buf4_init(&T2, CC_TAMPS, 0, 0, 5, 0, 5, 0, "tIjAb");
176
dpd_contract424(&T2, &Zfb, &Z1, 3, 0, 0, 1, 0);
178
dpd_file2_close(&Zfb);
179
dpd_buf4_axpy(&Z1, &ZIjAb, 1);
180
dpd_buf4_sort(&Z1, CC_TMP0, qpsr, 0, 5, "Z(jI,bA) temp");
182
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(jI,bA) temp");
183
dpd_buf4_axpy(&Z1, &ZIjAb, 1);
186
/* Contraction of Wmabeif with X and Y */
187
dpd_file2_init(&Znj, CC_TMP0, 0, 0, 0, "Z_nj");
188
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
189
dpd_buf4_init(&I, CC_DINTS, 0, 0, 5, 0, 5, 0, "D 2<ij|ab> - <ij|ba>");
190
dpd_contract442(&I, &Z1, &Znj, 1, 1, 1, 0);
194
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) temp");
195
dpd_buf4_init(&T2, CC_TAMPS, 0, 0, 5, 0, 5, 0, "tIjAb");
196
dpd_contract244(&Znj, &T2, &Z1, 0, 0, 0, -1, 0);
198
dpd_file2_close(&Znj);
199
dpd_buf4_axpy(&Z1, &ZIjAb, 1);
200
dpd_buf4_sort(&Z1, CC_TMP0, qpsr, 0, 5, "Z(jI,bA) temp");
202
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(jI,bA) temp");
203
dpd_buf4_axpy(&Z1, &ZIjAb, 1);
206
/* Close the X and Y matices */
207
dpd_file2_close(&Y1);
208
dpd_file2_close(&X1);
210
/* Final contraction with LIJAB */
211
dpd_buf4_init(&L2, CC_LAMPS, 0, 0, 5, 0, 5, 0, "2 LIjAb - LIjBa");
212
polar += dpd_buf4_dot(&L2, &ZIjAb);
214
dpd_buf4_close(&ZIjAb);
32
double polar, polar_I, polar_II;
34
int Gbm, Gfe, bm, b, m, Gb, Gm, Ge, Gf, B, M, fe, f, e, ef, nrows, ncols;
37
build_XY(pert_x, cart_x, irrep_x, omega_x, pert_y, cart_y, irrep_y, omega_y);
39
/* Type-I L2 residual */
40
dpd_buf4_init(&L2, CC_LAMPS, 0, 0, 5, 0, 5, 0, "LHX1Y1 I (2 Lijab - Lijba)");
41
dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "X*Y(ij,ab)");
42
polar_I = 2.0 * dpd_buf4_dot(&L2, &Z1);
46
/* Type-II L2 residual */
47
dpd_buf4_init(&L2, CC_LAMPS, 0, 10, 10, 10, 10, 0, "LHX1Y1 Residual II");
48
dpd_buf4_init(&Z1, CC_TMP0, 0, 10, 10, 10, 10, 0, "(X*Y+Y*X)(ie,ma)");
49
polar_II = -2.0 * dpd_buf4_dot(&L2, &Z1);
53
return polar_I+polar_II;
56
/* build_XY(): Compute products of X1 and Y1 for the
57
** <0|L*(HBAR*X1*Y1)|0> part of the response function.
59
** For the Type-I residuals:
60
** X*Y(ij,ab) = X(i,a) * Y(j,b)
62
** For the Type-II residuals:
63
** (X*Y+Y*X)(ie,ma) = [X(i,e) * Y(m,a) + X(m,a) * Y(i,e)]
68
void build_XY(char *pert_x, char *cart_x, int irrep_x, double omega_x,
69
char *pert_y, char *cart_y, int irrep_y, double omega_y)
71
int h, row, col, i, j, m, e, f, a, I, J, M, E, F, A, ij, ef;
72
int Isym, Jsym, Msym, Esym, Fsym, Asym;
78
nirreps = moinfo.nirreps;
80
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_y, cart_y, omega_y);
81
dpd_file2_init(&Y1, CC_OEI, irrep_y, 0, 1, lbl);
82
dpd_file2_mat_init(&Y1);
83
dpd_file2_mat_rd(&Y1);
85
sprintf(lbl, "X_%s_%1s_IA (%5.3f)", pert_x, cart_x, omega_x);
86
dpd_file2_init(&X1, CC_OEI, irrep_x, 0, 1, lbl);
87
dpd_file2_mat_init(&X1);
88
dpd_file2_mat_rd(&X1);
90
dpd_buf4_init(&Z, CC_TMP0, 0, 0, 5, 0, 5, 0, "X*Y(ij,ab)");
91
dpd_buf4_scm(&Z, 0.0);
92
for(h=0; h< nirreps; h++) {
93
dpd_buf4_mat_irrep_init(&Z, h);
94
for(row=0; row < Z.params->rowtot[h]; row++) {
95
i = Z.params->roworb[h][row][0];
96
j = Z.params->roworb[h][row][1];
97
I = X1.params->rowidx[i];
98
J = Y1.params->rowidx[j];
99
Isym = X1.params->psym[i];
100
Jsym = Y1.params->psym[j];
101
for(col=0; col < Z.params->coltot[h]; col++) {
102
e = Z.params->colorb[h][col][0];
103
f = Z.params->colorb[h][col][1];
104
E = X1.params->colidx[e];
105
F = Y1.params->colidx[f];
106
Esym = X1.params->qsym[e];
107
Fsym = Y1.params->qsym[f];
108
if((Isym^Esym)==irrep_x && (Jsym^Fsym)==irrep_y)
109
Z.matrix[h][row][col] = (X1.matrix[Isym][I][E] * Y1.matrix[Jsym][J][F]);
112
dpd_buf4_mat_irrep_wrt(&Z, h);
113
dpd_buf4_mat_irrep_close(&Z, h);
117
dpd_buf4_init(&Z, CC_TMP0, 0, 10, 10, 10, 10, 0, "(X*Y+Y*X)(ie,ma)");
118
dpd_buf4_scm(&Z, 0.0);
119
for(h=0; h< nirreps; h++) {
120
dpd_buf4_mat_irrep_init(&Z, h);
121
for(row=0; row < Z.params->rowtot[h]; row++) {
122
i = Z.params->roworb[h][row][0];
123
e = Z.params->roworb[h][row][1];
124
I = X1.params->rowidx[i];
125
E = X1.params->colidx[e];
126
Isym = X1.params->psym[i];
127
Esym = X1.params->qsym[e];
128
for(col=0; col < Z.params->coltot[h]; col++) {
129
m = Z.params->colorb[h][col][0];
130
a = Z.params->colorb[h][col][1];
131
M = Y1.params->rowidx[m];
132
A = Y1.params->colidx[a];
133
Msym = Y1.params->psym[m];
134
Asym = Y1.params->qsym[a];
136
if(((Isym^Esym)==irrep_x) && ((Msym^Asym)==irrep_y))
137
Z.matrix[h][row][col] =
138
(X1.matrix[Isym][I][E] * Y1.matrix[Msym][M][A]) +
139
(Y1.matrix[Isym][I][E] * X1.matrix[Msym][M][A]);
142
dpd_buf4_mat_irrep_wrt(&Z, h);
143
dpd_buf4_mat_irrep_close(&Z, h);
147
dpd_file2_mat_close(&X1);
148
dpd_file2_close(&X1);
149
dpd_file2_mat_close(&Y1);
150
dpd_file2_close(&Y1);