~ubuntu-branches/ubuntu/vivid/psicode/vivid

« back to all changes in this revision

Viewing changes to src/bin/ccdensity/x_onepdm_uhf.c

  • Committer: Bazaar Package Importer
  • Author(s): Michael Banck
  • Date: 2008-06-07 16:49:57 UTC
  • mfrom: (2.1.2 hardy)
  • Revision ID: james.westby@ubuntu.com-20080607164957-8pifvb133yjlkagn
Tags: 3.3.0-3
* debian/rules (DEB_MAKE_CHECK_TARGET): Do not abort test suite on
  failures.
* debian/rules (DEB_CONFIGURE_EXTRA_FLAGS): Set ${bindir} to /usr/lib/psi.
* debian/rules (install/psi3): Move psi3 file to /usr/bin.
* debian/patches/07_464867_move_executables.dpatch: New patch, add
  /usr/lib/psi to the $PATH, so that the moved executables are found.
  (closes: #464867)
* debian/patches/00list: Adjusted.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#include <stdio.h>
 
2
#include <libdpd/dpd.h>
 
3
#define EXTERN
 
4
#include "globals.h"
 
5
 
 
6
/* onepdm_uhf(): Computes the non-R0 parts of the unrelaxed EOM 1pdm
 
7
* intermediates are defined in x_oe_intermediates.c
 
8
 
9
*   D[i][j] = -LR_oo[j][i] - t1[i][f] * L2R1_ov[j][f]
 
10
*
 
11
*   D[a][b] = +LR_vv[a][b] + t1[n][b] * L2R1_ov[n][a]
 
12
*
 
13
*   D[a][i] = +L2R1_ov[i][a]
 
14
*
 
15
*   D[i][a] = + L1R2_ov[i][a] 
 
16
*            - t1[m][a] * LR_oo[m][i] 
 
17
*            - t1[i][e] * LR_vv[e][a]
 
18
*            - r1[m][a] * LT2_oo[m][i]
 
19
*            - r1[i][e] * LT2_vv[e][a]
 
20
*            + L2R1_ov[M][E] * (t2[i][m][a][e] - t1[i][e] * t1[m][a])
 
21
*
 
22
* RAK 2003
 
23
*/
 
24
 
 
25
void x_onepdm_uhf(struct RHO_Params rho_params)
 
26
{
 
27
  dpdfile2 DAI, Dai, DIA, Dia, DIJ, DAB, Dij, Dab, TIA, Tia;
 
28
  dpdfile2 LIA, Lia, RIA, Ria, I, XIJ, Xij;
 
29
  dpdbuf4 T2, L2, R2, I2;
 
30
  int L_irr, R_irr, G_irr;
 
31
  double dot_IA, dot_ia, dot_AI, dot_ai;
 
32
  L_irr = rho_params.L_irr;
 
33
  R_irr = rho_params.R_irr;
 
34
  G_irr = rho_params.G_irr;
 
35
 
 
36
  dpd_file2_init(&TIA, CC_OEI, 0, 0, 1, "tIA");
 
37
  dpd_file2_init(&Tia, CC_OEI, 0, 2, 3, "tia");
 
38
  dpd_file2_init(&RIA, CC_GR, R_irr, 0, 1, "RIA");
 
39
  dpd_file2_init(&Ria, CC_GR, R_irr, 2, 3, "Ria");
 
40
  dpd_file2_init(&LIA, CC_GL, L_irr, 0, 1, "LIA");
 
41
  dpd_file2_init(&Lia, CC_GL, L_irr, 2, 3, "Lia");
 
42
 
 
43
  /* D[i][j] = -LR_oo[j][i] - t1[i][f] * L2R1_ov[j][f] */
 
44
  dpd_file2_init(&DIJ, CC_OEI, G_irr, 0, 0, rho_params.DIJ_lbl);
 
45
  dpd_file2_init(&I, EOM_TMP, G_irr, 0, 0, "LR_OO");
 
46
  dpd_file2_axpy(&I, &DIJ, -1.0, 1);
 
47
  dpd_file2_close(&I);
 
48
 
 
49
  if (!params.connect_xi) {
 
50
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
51
    dpd_contract222(&TIA, &I, &DIJ, 0, 0, -1.0, 1.0);
 
52
    dpd_file2_close(&I);
 
53
  }
 
54
  dpd_file2_close(&DIJ);
 
55
 
 
56
  dpd_file2_init(&Dij, CC_OEI, G_irr, 2, 2, rho_params.Dij_lbl);
 
57
  dpd_file2_init(&I, EOM_TMP, G_irr, 2, 2, "LR_oo");
 
58
  dpd_file2_axpy(&I, &Dij, -1.0, 1);
 
59
  dpd_file2_close(&I);
 
60
 
 
61
  if (!params.connect_xi) {
 
62
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
63
    dpd_contract222(&Tia, &I, &Dij, 0, 0, -1.0, 1.0);
 
64
    dpd_file2_close(&I);
 
65
  }
 
66
  dpd_file2_close(&Dij);
 
67
 
 
68
  /* D[a][b] = +LR_vv[a][b] + L2R1_ov[n][a] * t1[n][b] */
 
69
  dpd_file2_init(&DAB, CC_OEI, G_irr, 1, 1, rho_params.DAB_lbl);
 
70
  dpd_file2_init(&I, EOM_TMP, G_irr, 1, 1, "LR_VV");
 
71
  dpd_file2_axpy(&I, &DAB, 1.0, 0);
 
72
  dpd_file2_close(&I);
 
73
 
 
74
  if (!params.connect_xi) {
 
75
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
76
    dpd_contract222(&I, &TIA, &DAB, 1, 1, 1.0, 1.0);
 
77
    dpd_file2_close(&I);
 
78
  }
 
79
  dpd_file2_close(&DAB);
 
80
 
 
81
  dpd_file2_init(&Dab, CC_OEI, G_irr, 3, 3, rho_params.Dab_lbl);
 
82
  dpd_file2_init(&I, EOM_TMP, G_irr, 3, 3, "LR_vv");
 
83
  dpd_file2_axpy(&I, &Dab, 1.0, 0);
 
84
  dpd_file2_close(&I);
 
85
 
 
86
  if (!params.connect_xi) {
 
87
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
88
    dpd_contract222(&I, &Tia, &Dab, 1, 1, 1.0, 1.0);
 
89
    dpd_file2_close(&I);
 
90
  }
 
91
  dpd_file2_close(&Dab);
 
92
 
 
93
  /* D[a][i] = +L2R1_ov[i][a] */
 
94
 
 
95
  if (!params.connect_xi) {
 
96
    dpd_file2_init(&DAI, CC_OEI, G_irr, 0, 1, rho_params.DAI_lbl);
 
97
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
98
    dpd_file2_axpy(&I, &DAI, 1.0, 0);
 
99
    dpd_file2_close(&I);
 
100
    dpd_file2_close(&DAI);
 
101
 
 
102
    dpd_file2_init(&Dai, CC_OEI, G_irr, 2, 3, rho_params.Dai_lbl);
 
103
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
104
    dpd_file2_axpy(&I, &Dai, 1.0, 0);
 
105
    dpd_file2_close(&I);
 
106
    dpd_file2_close(&Dai);
 
107
  }
 
108
 
 
109
  /*
 
110
     D[I][A] = (1-R0)*tIA + L1R2_OV[I][A] 
 
111
               - LR_OO[M][I] * t1[M][A]
 
112
               - t1[I][E] * LR_vv[E][A]
 
113
               - LT2_OO[M][I] * r1[M][A]
 
114
               - r1[I][E] * LT2_vv[E][A]
 
115
               + L2R1_ov[M][E] * (t2[i][m][a][e] - t1[i][e] * t1[m][a])
 
116
  */
 
117
 
 
118
  /* (1-R0) * tIA */
 
119
  dpd_file2_init(&DIA, CC_OEI, G_irr, 0, 1, rho_params.DIA_lbl);
 
120
 
 
121
  if ( (G_irr == 0) /* && (!params.connect_xi)*/ ) {
 
122
    dpd_file2_init(&I, CC_OEI, 0, 0, 1, "tIA");
 
123
    dpd_file2_axpy(&I, &DIA, 1.0, 0);
 
124
    dpd_file2_close(&I);
 
125
  }
 
126
 
 
127
  dpd_file2_init(&Dia, CC_OEI, G_irr, 2, 3, rho_params.Dia_lbl);
 
128
  if ( (G_irr == 0) /* && (!params.connect_xi)*/ ) {
 
129
    dpd_file2_init(&I, CC_OEI, 0, 2, 3, "tia");
 
130
    dpd_file2_axpy(&I, &Dia, 1.0, 0);
 
131
    dpd_file2_close(&I);
 
132
  }
 
133
 
 
134
  /* D[i][a] = L1R2_ov[i][a] */
 
135
  dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L1R2_OV");
 
136
  dpd_file2_axpy(&I, &DIA, 1.0, 0);
 
137
  dpd_file2_close(&I);
 
138
 
 
139
  dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L1R2_ov");
 
140
  dpd_file2_axpy(&I, &Dia, 1.0, 0);
 
141
  dpd_file2_close(&I);
 
142
 
 
143
  /* - LR_OO[M][I] * t1[M][A] */
 
144
 
 
145
  dpd_file2_init(&I, EOM_TMP, G_irr, 0, 0, "LR_OO");
 
146
  dpd_contract222(&I, &TIA, &DIA, 1, 1, -1.0, 1.0);
 
147
  dpd_file2_close(&I);
 
148
 
 
149
  dpd_file2_init(&I, EOM_TMP, G_irr, 2, 2, "LR_oo");
 
150
  dpd_contract222(&I, &Tia, &Dia, 1, 1, -1.0, 1.0);
 
151
  dpd_file2_close(&I);
 
152
 
 
153
  /* - t1[I][E] * LR_vv[E][A] */
 
154
 
 
155
  dpd_file2_init(&I, EOM_TMP, G_irr, 1, 1, "LR_VV");
 
156
  dpd_contract222(&TIA, &I, &DIA, 0, 1, -1.0, 1.0);
 
157
  dpd_file2_close(&I);
 
158
 
 
159
  dpd_file2_init(&I, EOM_TMP, G_irr, 3, 3, "LR_vv");
 
160
  dpd_contract222(&Tia, &I, &Dia, 0, 1, -1.0, 1.0);
 
161
  dpd_file2_close(&I);
 
162
 
 
163
  /* - LT2_OO[M][I] * r1[M][A] */
 
164
 
 
165
  dpd_file2_init(&I, EOM_TMP, L_irr, 0, 0, "LT2_OO");
 
166
  dpd_contract222(&I, &RIA, &DIA, 1, 1, -1.0, 1.0);
 
167
  dpd_file2_close(&I);
 
168
 
 
169
  dpd_file2_init(&I, EOM_TMP, L_irr, 2, 2, "LT2_oo");
 
170
  dpd_contract222(&I, &Ria, &Dia, 1, 1, -1.0, 1.0);
 
171
  dpd_file2_close(&I);
 
172
 
 
173
  /* - r1[I][E] * LT2_vv[E][A] */
 
174
 
 
175
  dpd_file2_init(&I, EOM_TMP, L_irr, 1, 1, "LT2_VV");
 
176
  dpd_contract222(&RIA, &I, &DIA, 0, 1, -1.0, 1.0);
 
177
  dpd_file2_close(&I);
 
178
 
 
179
  dpd_file2_init(&I, EOM_TMP, L_irr, 3, 3, "LT2_vv");
 
180
  dpd_contract222(&Ria, &I, &Dia, 0, 1, -1.0, 1.0);
 
181
  dpd_file2_close(&I);
 
182
 
 
183
  /* term 6, + L2R1_ov[M][E] * t2[i][m][a][e] */
 
184
 
 
185
  if (!params.connect_xi) {
 
186
    dpd_buf4_init(&T2, CC_TAMPS, 0, 0, 5, 2, 7, 0, "tIJAB"); 
 
187
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
188
    dpd_dot24(&I, &T2, &DIA, 0, 0, 1.0, 1.0);
 
189
    dpd_file2_close(&I);
 
190
    dpd_buf4_close(&T2);
 
191
 
 
192
    dpd_buf4_init(&T2, CC_TAMPS, 0, 22, 28, 22, 28, 0, "tIjAb"); 
 
193
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
194
    dpd_dot24(&I, &T2, &DIA, 0, 0, 1.0, 1.0);
 
195
    dpd_file2_close(&I);
 
196
    dpd_buf4_close(&T2);
 
197
 
 
198
    dpd_buf4_init(&T2, CC_TAMPS, 0, 10, 15, 12, 17, 0, "tijab"); 
 
199
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
200
    dpd_dot24(&I, &T2, &Dia, 0, 0, 1.0, 1.0);
 
201
    dpd_file2_close(&I);
 
202
    dpd_buf4_close(&T2);
 
203
 
 
204
    dpd_buf4_init(&T2, CC_TAMPS, 0, 23, 29, 23, 29, 0, "tiJaB"); 
 
205
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
206
    dpd_dot24(&I, &T2, &Dia, 0, 0, 1.0, 1.0);
 
207
    dpd_file2_close(&I);
 
208
    dpd_buf4_close(&T2);
 
209
  }
 
210
    
 
211
  /* term 7, - (t1[i][e] * L2R1_ov[M][E]) * t1[m][a] */
 
212
 
 
213
  if (!params.connect_xi) {
 
214
    dpd_file2_init(&I, EOM_TMP, G_irr, 0, 1, "L2R1_OV");
 
215
    dpd_file2_init(&XIJ, EOM_TMP, G_irr, 0, 0, "XIJ");
 
216
    dpd_contract222(&TIA, &I, &XIJ, 0, 0, 1.0, 0.0);
 
217
    dpd_file2_close(&I);
 
218
 
 
219
    dpd_file2_init(&XIJ, EOM_TMP, G_irr, 0, 0, "XIJ");
 
220
    dpd_contract222(&XIJ, &TIA, &DIA, 0, 1, -1.0, 1.0);
 
221
    dpd_file2_close(&XIJ);
 
222
 
 
223
    dpd_file2_init(&I, EOM_TMP, G_irr, 2, 3, "L2R1_ov");
 
224
    dpd_file2_init(&Xij, EOM_TMP, G_irr, 2, 2, "Xij");
 
225
    dpd_contract222(&Tia, &I, &Xij, 0, 0, 1.0, 0.0);
 
226
    dpd_file2_close(&I);
 
227
 
 
228
    dpd_file2_init(&Xij, EOM_TMP, G_irr, 2, 2, "Xij");
 
229
    dpd_contract222(&Xij, &Tia, &Dia, 0, 1, -1.0, 1.0);
 
230
    dpd_file2_close(&Xij);
 
231
  }
 
232
 
 
233
  dpd_file2_close(&DIA);
 
234
  dpd_file2_close(&Dia);
 
235
 
 
236
  dpd_file2_close(&TIA);
 
237
  dpd_file2_close(&Tia);
 
238
  dpd_file2_close(&RIA);
 
239
  dpd_file2_close(&Ria);
 
240
  dpd_file2_close(&LIA);
 
241
  dpd_file2_close(&Lia);
 
242
 
 
243
  /* compute overlaps */
 
244
  dpd_file2_init(&DIA, CC_OEI, G_irr, 0, 1, rho_params.DIA_lbl);
 
245
  dot_IA = dpd_file2_dot_self(&DIA);
 
246
  dpd_file2_close(&DIA);
 
247
  dpd_file2_init(&Dia, CC_OEI, G_irr, 2, 3, rho_params.Dia_lbl);
 
248
  dot_ia = dpd_file2_dot_self(&Dia);
 
249
  dpd_file2_close(&Dia);
 
250
  dpd_file2_init(&DAI, CC_OEI, G_irr, 0, 1, rho_params.DAI_lbl);
 
251
  dot_AI = dpd_file2_dot_self(&DAI);
 
252
  dpd_file2_close(&DAI);
 
253
  dpd_file2_init(&Dai, CC_OEI, G_irr, 2, 3, rho_params.Dai_lbl);
 
254
  dot_ai = dpd_file2_dot_self(&Dai);
 
255
  dpd_file2_close(&Dai);
 
256
        fprintf(outfile,"\tOverlaps of onepdm after excited-state parts added.\n");
 
257
        fprintf(outfile,"\t<DIA|DIA> = %15.10lf     <Dia|Dia> = %15.10lf\n", dot_IA, dot_ia);
 
258
        fprintf(outfile,"\t<DAI|DAI> = %15.10lf     <Dai|Dai> = %15.10lf\n", dot_AI, dot_ai);
 
259
        fprintf(outfile,"\t<Dpq|Dqp> = %15.10lf\n", dot_IA+dot_ia+dot_AI+dot_ai);
 
260
  return;
 
261
}