~ubuntu-branches/ubuntu/karmic/psicode/karmic

« back to all changes in this revision

Viewing changes to src/bin/cchbar/Wmbej.cc

  • Committer: Bazaar Package Importer
  • Author(s): Michael Banck, Michael Banck, Daniel Leidert
  • Date: 2009-02-23 00:12:02 UTC
  • mfrom: (1.1.2 upstream)
  • Revision ID: james.westby@ubuntu.com-20090223001202-rutldoy3dimfpesc
Tags: 3.4.0-1
* New upstream release.

[ Michael Banck ]
* debian/patches/01_DESTDIR.dpatch: Refreshed.
* debian/patches/02_FHS.dpatch: Removed, applied upstream.
* debian/patches/03_debian_docdir: Likewise.
* debian/patches/04_man.dpatch: Likewise.
* debian/patches/06_466828_fix_gcc_43_ftbfs.dpatch: Likewise.
* debian/patches/07_464867_move_executables: Fixed and refreshed.
* debian/patches/00list: Adjusted.
* debian/control: Improved description.
* debian/patches-held: Removed.
* debian/rules (install/psi3): Do not ship the ruby bindings for now.

[ Daniel Leidert ]
* debian/rules: Fix txtdir via DEB_MAKE_INSTALL_TARGET.
* debian/patches/01_DESTDIR.dpatch: Refreshed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*! \file
 
2
    \ingroup CCHBAR
 
3
    \brief Enter brief description of file here 
 
4
*/
 
5
#include <cstdio>
 
6
#include <libdpd/dpd.h>
 
7
#include <libqt/qt.h>
 
8
#include "MOInfo.h"
 
9
#include "Params.h"
 
10
#define EXTERN
 
11
#include "globals.h"
 
12
 
 
13
namespace psi { namespace cchbar {
 
14
 
 
15
/* Wmbej_build(): Computes all contributions to the Wmbej HBAR matrix
 
16
** elements.  These are defined in terms of spin orbitals as:
 
17
**
 
18
** Wmbej = <mb||ej> + t_j^f <mb||ef> - t_n^b <mn||ej> 
 
19
**         - { t_jn^fb + t_j^f t_n^b } <mn||ef>
 
20
**
 
21
** [cf. Gauss and Stanton, JCP 103, 3561-3577 (1995)]
 
22
**
 
23
** There are Wmbej six spin cases, which are stored and named
 
24
** as follows:
 
25
**
 
26
** Spin Case    Storage    Name
 
27
** ----------   ---------  -------
 
28
** WMBEJ        (ME,JB)    "WMBEJ"
 
29
** Wmbej        (me,jb)    "Wmbej"
 
30
** WMbEj        (ME,jb)    "WMbEj"
 
31
** WmBeJ        (me,JB)    "WmBeJ"
 
32
** WMbeJ        (Me,bJ)    "WMbeJ"
 
33
** WmBEj        (mE,Bj)    "WmBEj"
 
34
** -------------------------------
 
35
**
 
36
** TDC, June 2002
 
37
*/
 
38
 
 
39
void Wmbej_build(void) {
 
40
  dpdbuf4 WMBEJ, Wmbej, WMbEj, WmBeJ, WmBEj, WMbeJ;
 
41
  dpdbuf4 tIAJB, tjAIb, tiajb, tIAjb, tiaJB, tIbjA;
 
42
  dpdbuf4 D, C, F, E, X, Y, t2, W, Z;
 
43
  dpdfile2 tIA, tia;
 
44
  int Gmb, mb, Gj, Ge, Gf, nrows, ncols, nlinks;
 
45
 
 
46
  if(params.ref == 0) { /** RHF **/
 
47
 
 
48
    /* <mb||ej> -> Wmbej */
 
49
 
 
50
    dpd_buf4_init(&C, CC_CINTS, 0, 10, 10, 10, 10, 0, "C <ia|jb>");
 
51
    dpd_buf4_scmcopy(&C, CC_TMP0, "WMbeJ", -1);
 
52
    dpd_buf4_close(&C);
 
53
 
 
54
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ib,aj)");
 
55
    dpd_buf4_copy(&D, CC_TMP0, "WMbEj");
 
56
    dpd_buf4_close(&D);
 
57
 
 
58
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
59
 
 
60
    /* F -> Wmbej */
 
61
 
 
62
    dpd_buf4_init(&F, CC_FINTS, 0, 10, 5, 10, 5, 0, "F <ia|bc>");
 
63
 
 
64
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
65
    dpd_contract424(&F, &tIA, &WMbEj, 3, 1, 0, 1, 1); /* should run OOC, if needed */
 
66
    dpd_buf4_close(&WMbEj);
 
67
 
 
68
    dpd_buf4_close(&F);
 
69
 
 
70
    /*
 
71
    dpd_buf4_init(&F, CC_FINTS, 0, 11, 5, 11, 5, 0, "F <ai|bc>");
 
72
 
 
73
    dpd_buf4_init(&Z, CC_TMP0, 0, 11, 11, 11, 11, 0, "Z(bM,eJ)");
 
74
    dpd_contract424(&F, &tIA, &Z, 3, 1, 0, -1, 0);
 
75
    dpd_buf4_sort(&Z, CC_TMP0, qpsr, 10, 10, "Z(Mb,Je)");
 
76
    dpd_buf4_close(&Z);
 
77
    dpd_buf4_init(&Z, CC_TMP0, 0, 10, 10, 10, 10, 0, "Z(Mb,Je)");
 
78
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
79
    dpd_buf4_axpy(&Z, &WMbeJ, 1.0);
 
80
    dpd_buf4_close(&WMbeJ);
 
81
    dpd_buf4_close(&Z);
 
82
 
 
83
    dpd_buf4_close(&F);
 
84
    */
 
85
    /* W(Mb,Je) <-- t(J,F) <Mb|Fe> */
 
86
    /* OOC code added to replace above on 3/26/05, TDC */
 
87
    dpd_buf4_init(&F, CC_FINTS, 0, 10, 5, 10, 5, 0, "F <ia|bc>");
 
88
    dpd_buf4_init(&W, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
89
    dpd_file2_mat_init(&tIA);
 
90
    dpd_file2_mat_rd(&tIA);
 
91
 
 
92
    for(Gmb=0; Gmb < moinfo.nirreps; Gmb++) {
 
93
      dpd_buf4_mat_irrep_row_init(&W, Gmb);
 
94
      dpd_buf4_mat_irrep_row_init(&F, Gmb);
 
95
 
 
96
      for(mb=0; mb < F.params->rowtot[Gmb]; mb++) {
 
97
        dpd_buf4_mat_irrep_row_rd(&W, Gmb, mb);
 
98
        dpd_buf4_mat_irrep_row_rd(&F, Gmb, mb);
 
99
 
 
100
        for(Gj=0; Gj < moinfo.nirreps; Gj++) {
 
101
          Gf = Gj;  /* T1 is totally symmetric */
 
102
          Ge = Gmb ^ Gf; /* <mb|fe> is totally symmetric */
 
103
 
 
104
          nrows = moinfo.occpi[Gj];
 
105
          ncols = moinfo.virtpi[Ge];
 
106
          nlinks = moinfo.virtpi[Gf];
 
107
          if(nrows && ncols && nlinks)
 
108
            C_DGEMM('n','n',nrows,ncols,nlinks,-1.0,tIA.matrix[Gj][0],nlinks,
 
109
                    &F.matrix[Gmb][0][F.col_offset[Gmb][Gf]],ncols,1.0,
 
110
                    &W.matrix[Gmb][0][W.col_offset[Gmb][Gj]],ncols);
 
111
        }
 
112
 
 
113
        dpd_buf4_mat_irrep_row_wrt(&W, Gmb, mb);
 
114
      }
 
115
 
 
116
      dpd_buf4_mat_irrep_row_close(&F, Gmb);
 
117
      dpd_buf4_mat_irrep_row_close(&W, Gmb);
 
118
    }
 
119
 
 
120
    dpd_file2_mat_close(&tIA);
 
121
    dpd_buf4_close(&W);
 
122
    dpd_buf4_close(&F);
 
123
 
 
124
 
 
125
    dpd_file2_close(&tIA);
 
126
 
 
127
    /* E -> Wmbej */
 
128
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
129
 
 
130
    dpd_buf4_init(&E, CC_EINTS, 0, 11, 0, 11, 0, 0, "E <ai|jk>");
 
131
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
132
    dpd_contract424(&E, &tIA, &WMbEj, 3, 0, 1, -1, 1);
 
133
    dpd_buf4_close(&WMbEj);
 
134
    dpd_buf4_close(&E);
 
135
 
 
136
    dpd_buf4_init(&E, CC_EINTS, 0, 0, 10, 0, 10, 0, "E <ij|ka>");
 
137
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
138
    dpd_contract424(&E, &tIA, &WMbeJ, 1, 0, 1, 1, 1);
 
139
    dpd_buf4_close(&WMbeJ);
 
140
    dpd_buf4_close(&E);
 
141
 
 
142
    dpd_file2_close(&tIA);  
 
143
 
 
144
 
 
145
    /* Sort to (ME,JB) */
 
146
 
 
147
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
148
    dpd_buf4_sort(&WMbEj, CC_HBAR, prsq, 10, 10, "WMbEj");
 
149
    dpd_buf4_close(&WMbEj);
 
150
 
 
151
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
152
    dpd_buf4_sort(&WMbeJ, CC_HBAR, psrq, 10, 10, "WMbeJ");
 
153
    dpd_buf4_close(&WMbeJ);
 
154
 
 
155
 
 
156
    /* T1^2 -> Wmbej */
 
157
 
 
158
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
159
 
 
160
    /*** ABAB ***/
 
161
 
 
162
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
 
163
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAjb");
 
164
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D 2<ij|ab> - <ij|ba> (ia,jb)");
 
165
    dpd_contract444(&D, &t2, &W, 0, 0, 1, 1);
 
166
    dpd_buf4_close(&D);
 
167
    dpd_buf4_close(&t2);
 
168
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tjAIb");
 
169
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
170
    dpd_contract444(&D, &t2, &W, 0, 0, -1, 1);
 
171
    dpd_buf4_close(&D);
 
172
    dpd_buf4_close(&t2);
 
173
    dpd_buf4_close(&W);
 
174
 
 
175
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
176
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ia,bj)");
 
177
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
178
    dpd_buf4_close(&D);
 
179
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
 
180
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, -1, 1);
 
181
    dpd_buf4_close(&W);
 
182
    dpd_buf4_close(&Y);
 
183
 
 
184
    /*** ABBA ***/
 
185
  
 
186
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
187
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIbjA");
 
188
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ib,ja)");
 
189
    dpd_contract444(&D, &t2, &W, 0, 0, 1, 1);
 
190
    dpd_buf4_close(&D);
 
191
    dpd_buf4_close(&t2);
 
192
    dpd_buf4_close(&W);
 
193
 
 
194
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
195
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ib,aj)");
 
196
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
197
    dpd_buf4_close(&D);
 
198
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
199
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, 1, 1);
 
200
    dpd_buf4_close(&W);
 
201
    dpd_buf4_close(&Y);
 
202
 
 
203
    dpd_file2_close(&tIA);
 
204
 
 
205
  }
 
206
  else if(params.ref == 1) { /** ROHF **/
 
207
 
 
208
    /* W(mb,je) <-- <mb||ej> */
 
209
 
 
210
    dpd_buf4_init(&C, CC_CINTS, 0, 10, 11, 10, 11, 0, "C <ia||jb> (ia,bj)");
 
211
    dpd_buf4_scmcopy(&C, CC_TMP0, "WMBEJ", -1);
 
212
    dpd_buf4_scmcopy(&C, CC_TMP0, "Wmbej", -1);
 
213
    dpd_buf4_close(&C);
 
214
 
 
215
    dpd_buf4_init(&C, CC_CINTS, 0, 10, 10, 10, 10, 0, "C <ia|jb>");
 
216
    dpd_buf4_scmcopy(&C, CC_TMP0, "WmBEj", -1);
 
217
    dpd_buf4_scmcopy(&C, CC_TMP0, "WMbeJ", -1);
 
218
    dpd_buf4_close(&C);
 
219
 
 
220
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ib,aj)");
 
221
    dpd_buf4_copy(&D, CC_TMP0, "WMbEj");
 
222
    dpd_buf4_copy(&D, CC_TMP0, "WmBeJ");
 
223
    dpd_buf4_close(&D);
 
224
 
 
225
    /* F -> Wmbej */
 
226
 
 
227
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
228
    dpd_file2_init(&tia, CC_OEI, 0, 0, 1, "tia");
 
229
 
 
230
    dpd_buf4_init(&F, CC_FINTS, 0, 10, 5, 10, 5, 1, "F <ia|bc>");
 
231
    dpd_buf4_init(&WMBEJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMBEJ");
 
232
    dpd_contract424(&F, &tIA, &WMBEJ, 3, 1, 0, 1, 1);
 
233
    dpd_buf4_close(&WMBEJ);
 
234
    dpd_buf4_init(&Wmbej, CC_TMP0, 0, 10, 11, 10, 11, 0, "Wmbej");
 
235
    dpd_contract424(&F, &tia, &Wmbej, 3, 1, 0, 1, 1);
 
236
    dpd_buf4_close(&Wmbej);
 
237
    dpd_buf4_close(&F);
 
238
 
 
239
    dpd_buf4_init(&F, CC_FINTS, 0, 10, 5, 10, 5, 0, "F <ia|bc>");
 
240
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
241
    dpd_contract424(&F, &tia, &WMbEj, 3, 1, 0, 1, 1);
 
242
    dpd_buf4_close(&WMbEj);
 
243
    dpd_buf4_init(&WmBeJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WmBeJ");
 
244
    dpd_contract424(&F, &tIA, &WmBeJ, 3, 1, 0, 1, 1);
 
245
    dpd_buf4_close(&WmBeJ);
 
246
 
 
247
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
248
    dpd_contract244(&tIA, &F, &WMbeJ, 1, 2, 1, -1, 1);
 
249
    dpd_buf4_close(&WMbeJ);
 
250
    dpd_buf4_init(&WmBEj, CC_TMP0, 0, 10, 10, 10, 10, 0, "WmBEj");
 
251
    dpd_contract244(&tia, &F, &WmBEj, 1, 2, 1, -1, 1);
 
252
    dpd_buf4_close(&WmBEj);
 
253
    dpd_buf4_close(&F);
 
254
 
 
255
    dpd_file2_close(&tIA);
 
256
    dpd_file2_close(&tia);
 
257
 
 
258
    /* E -> Wmbej */
 
259
 
 
260
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
261
    dpd_file2_init(&tia, CC_OEI, 0, 0, 1, "tia");
 
262
 
 
263
    dpd_buf4_init(&E, CC_EINTS, 0, 0, 11, 2, 11, 0, "E <ij||ka> (i>j,ak)");
 
264
    dpd_buf4_init(&WMBEJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMBEJ");
 
265
    dpd_contract424(&E, &tIA, &WMBEJ, 1, 0, 1, 1, 1);
 
266
    dpd_buf4_close(&WMBEJ);
 
267
    dpd_buf4_init(&Wmbej, CC_TMP0, 0, 10, 11, 10, 11, 0, "Wmbej");
 
268
    dpd_contract424(&E, &tia, &Wmbej, 1, 0, 1, 1, 1);
 
269
    dpd_buf4_close(&Wmbej);
 
270
    dpd_buf4_close(&E);
 
271
 
 
272
    dpd_buf4_init(&E, CC_EINTS, 0, 11, 0, 11, 0, 0, "E <ai|jk>");
 
273
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
274
    dpd_contract424(&E, &tia, &WMbEj, 3, 0, 1, -1, 1);
 
275
    dpd_buf4_close(&WMbEj);
 
276
    dpd_buf4_init(&WmBeJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WmBeJ");
 
277
    dpd_contract424(&E, &tIA, &WmBeJ, 3, 0, 1, -1, 1);
 
278
    dpd_buf4_close(&WmBeJ);
 
279
    dpd_buf4_close(&E);
 
280
 
 
281
    dpd_buf4_init(&E, CC_EINTS, 0, 0, 10, 0, 10, 0, "E <ij|ka>");
 
282
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
283
    dpd_contract424(&E, &tia, &WMbeJ, 1, 0, 1, 1, 1);
 
284
    dpd_buf4_close(&WMbeJ);
 
285
    dpd_buf4_init(&WmBEj, CC_TMP0, 0, 10, 10, 10, 10, 0, "WmBEj");
 
286
    dpd_contract424(&E, &tIA, &WmBEj, 1, 0, 1, 1, 1);
 
287
    dpd_buf4_close(&WmBEj);
 
288
    dpd_buf4_close(&E);
 
289
 
 
290
    dpd_file2_close(&tIA);  
 
291
    dpd_file2_close(&tia);
 
292
 
 
293
    /* Convert to (ME,JB) for remaining terms */
 
294
 
 
295
    dpd_buf4_init(&WMBEJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMBEJ");
 
296
    dpd_buf4_sort(&WMBEJ, CC_HBAR, prsq, 10, 10, "WMBEJ");
 
297
    dpd_buf4_close(&WMBEJ);
 
298
 
 
299
    dpd_buf4_init(&Wmbej, CC_TMP0, 0, 10, 11, 10, 11, 0, "Wmbej");
 
300
    dpd_buf4_sort(&Wmbej, CC_HBAR, prsq, 10, 10, "Wmbej");
 
301
    dpd_buf4_close(&Wmbej);
 
302
 
 
303
    dpd_buf4_init(&WMbEj, CC_TMP0, 0, 10, 11, 10, 11, 0, "WMbEj");
 
304
    dpd_buf4_sort(&WMbEj, CC_HBAR, prsq, 10, 10, "WMbEj");
 
305
    dpd_buf4_close(&WMbEj);
 
306
 
 
307
    dpd_buf4_init(&WmBeJ, CC_TMP0, 0, 10, 11, 10, 11, 0, "WmBeJ");
 
308
    dpd_buf4_sort(&WmBeJ, CC_HBAR, prsq, 10, 10, "WmBeJ");
 
309
    dpd_buf4_close(&WmBeJ);
 
310
 
 
311
    dpd_buf4_init(&WMbeJ, CC_TMP0, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
312
    dpd_buf4_sort(&WMbeJ, CC_HBAR, psrq, 10, 10, "WMbeJ");
 
313
    dpd_buf4_close(&WMbeJ);
 
314
 
 
315
    dpd_buf4_init(&WmBEj, CC_TMP0, 0, 10, 10, 10, 10, 0, "WmBEj");
 
316
    dpd_buf4_sort(&WmBEj, CC_HBAR, psrq, 10, 10, "WmBEj");
 
317
    dpd_buf4_close(&WmBEj);
 
318
 
 
319
    /* X -> Wmbej */
 
320
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
321
    dpd_file2_init(&tia, CC_OEI, 0, 0, 1, "tia");
 
322
 
 
323
    /*** AAAA ***/
 
324
 
 
325
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMBEJ");
 
326
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
327
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAJB");
 
328
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
329
    dpd_buf4_close(&t2);
 
330
    dpd_buf4_close(&D);
 
331
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
332
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAjb");
 
333
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
334
    dpd_buf4_close(&t2);
 
335
    dpd_buf4_close(&D);
 
336
    dpd_buf4_close(&W);
 
337
 
 
338
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
339
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij||ab> (ia,bj)");
 
340
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
341
    dpd_buf4_close(&D);
 
342
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMBEJ");
 
343
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, -1, 1);
 
344
    dpd_buf4_close(&W);
 
345
    dpd_buf4_close(&Y);
 
346
 
 
347
    /*** BBBB ***/
 
348
 
 
349
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "Wmbej");
 
350
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
351
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiajb");
 
352
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
353
    dpd_buf4_close(&t2);
 
354
    dpd_buf4_close(&D);
 
355
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
356
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiaJB");
 
357
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
358
    dpd_buf4_close(&t2);
 
359
    dpd_buf4_close(&D);
 
360
    dpd_buf4_close(&W);
 
361
 
 
362
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
363
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij||ab> (ia,bj)");
 
364
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
365
    dpd_buf4_close(&D);
 
366
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "Wmbej");
 
367
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, -1, 1);
 
368
    dpd_buf4_close(&W);
 
369
    dpd_buf4_close(&Y);
 
370
 
 
371
    /*** ABAB ***/
 
372
  
 
373
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
 
374
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
375
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiajb");
 
376
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1); 
 
377
    dpd_buf4_close(&t2);
 
378
    dpd_buf4_close(&D);
 
379
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
380
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiaJB");
 
381
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1); 
 
382
    dpd_buf4_close(&t2);
 
383
    dpd_buf4_close(&D);
 
384
    dpd_buf4_close(&W);
 
385
 
 
386
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
387
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ia,bj)");
 
388
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
389
    dpd_buf4_close(&D);
 
390
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
 
391
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, -1, 1);
 
392
    dpd_buf4_close(&W);
 
393
    dpd_buf4_close(&Y);
 
394
 
 
395
    /*** BABA ***/
 
396
 
 
397
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBeJ");
 
398
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
399
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAJB");
 
400
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
401
    dpd_buf4_close(&t2);
 
402
    dpd_buf4_close(&D);
 
403
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
404
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAjb");
 
405
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
406
    dpd_buf4_close(&t2);
 
407
    dpd_buf4_close(&D);
 
408
    dpd_buf4_close(&W);
 
409
 
 
410
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
411
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ia,bj)");
 
412
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
413
    dpd_buf4_close(&D);
 
414
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBeJ");
 
415
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, -1, 1);
 
416
    dpd_buf4_close(&W);
 
417
    dpd_buf4_close(&Y);
 
418
 
 
419
    /*** ABBA ***/
 
420
  
 
421
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
422
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIbjA");
 
423
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ib,ja)");
 
424
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
425
    dpd_buf4_close(&D);
 
426
    dpd_buf4_close(&t2);
 
427
    dpd_buf4_close(&W);
 
428
 
 
429
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
430
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ib,aj)");
 
431
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
432
    dpd_buf4_close(&D);
 
433
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
434
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, 1, 1);
 
435
    dpd_buf4_close(&W);
 
436
    dpd_buf4_close(&Y);
 
437
 
 
438
    /*** BAAB ***/
 
439
 
 
440
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBEj");
 
441
    dpd_buf4_init(&t2, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tjAIb");
 
442
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ib,ja)");
 
443
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
444
    dpd_buf4_close(&D);
 
445
    dpd_buf4_close(&t2);
 
446
    dpd_buf4_close(&W);
 
447
 
 
448
    dpd_buf4_init(&Y, CC_TMP0, 0, 10, 0, 10, 0, 0, "Y (ME,JN)");
 
449
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 11, 10, 11, 0, "D <ij|ab> (ib,aj)");
 
450
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
451
    dpd_buf4_close(&D);
 
452
    dpd_buf4_init(&W, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBEj");
 
453
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, 1, 1);
 
454
    dpd_buf4_close(&W);
 
455
    dpd_buf4_close(&Y);
 
456
 
 
457
    dpd_file2_close(&tIA);
 
458
    dpd_file2_close(&tia);
 
459
 
 
460
 
 
461
    /* D(me,nf) * T2(jb,nf) --> W(me,jb) */
 
462
    dpd_buf4_init(&Wmbej, CC_HBAR, 0, 10, 10, 10, 10, 0, "Wmbej");
 
463
 
 
464
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
465
    dpd_buf4_init(&tiajb, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiajb");
 
466
    dpd_contract444(&D, &tiajb, &Wmbej, 0, 0, 0.5, 1);
 
467
    dpd_buf4_close(&D);
 
468
    dpd_buf4_close(&tiajb);
 
469
 
 
470
    /* D(me,NF) * T2(jb,NF) --> W(me,jb) */
 
471
    dpd_buf4_init(&tiaJB, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiaJB");
 
472
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
473
    dpd_contract444(&D, &tiaJB, &Wmbej, 0, 0, 0.5, 1);
 
474
    dpd_buf4_close(&D);
 
475
    dpd_buf4_close(&tiaJB);
 
476
 
 
477
    dpd_buf4_close(&Wmbej);
 
478
 
 
479
 
 
480
    /* D(ME,NF) * T2(JB,NF) --> W(ME,JB) */
 
481
    dpd_buf4_init(&WMBEJ, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMBEJ");
 
482
 
 
483
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
484
    dpd_buf4_init(&tIAJB, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAJB");
 
485
    dpd_contract444(&D, &tIAJB, &WMBEJ, 0, 0, 0.5, 1);
 
486
    dpd_buf4_close(&D);
 
487
    dpd_buf4_close(&tIAJB);
 
488
 
 
489
    /* D(ME,nf) * T2(JB,nf) --> W(ME,JB) */
 
490
    dpd_buf4_init(&tIAjb, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAjb");
 
491
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
492
    dpd_contract444(&D, &tIAjb, &WMBEJ, 0, 0, 0.5, 1);
 
493
    dpd_buf4_close(&D);
 
494
    dpd_buf4_close(&tIAjb);
 
495
 
 
496
    dpd_buf4_close(&WMBEJ);
 
497
 
 
498
 
 
499
    /* D(me,nf) * T2(JB,nf) --> W(me,JB) */
 
500
    dpd_buf4_init(&WmBeJ, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBeJ");
 
501
 
 
502
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
503
    dpd_buf4_init(&tIAjb, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAjb");
 
504
    dpd_contract444(&D, &tIAjb, &WmBeJ, 0, 0, 0.5, 1);
 
505
    dpd_buf4_close(&D);
 
506
    dpd_buf4_close(&tIAjb);
 
507
 
 
508
    /* D(me,NF) * T2(JB,NF) --> W(me,JB) */
 
509
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
510
    dpd_buf4_init(&tIAJB, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIAJB");
 
511
    dpd_contract444(&D, &tIAJB, &WmBeJ, 0, 0, 0.5, 1);
 
512
    dpd_buf4_close(&D);
 
513
    dpd_buf4_close(&tIAJB);
 
514
 
 
515
    dpd_buf4_close(&WmBeJ);
 
516
 
 
517
 
 
518
    /* D(ME,NF) * T2(jb,NF) --> W(ME,jb) */
 
519
    dpd_buf4_init(&WMbEj, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbEj");
 
520
 
 
521
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij||ab> (ia,jb)");
 
522
    dpd_buf4_init(&tiaJB, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiaJB");
 
523
    dpd_contract444(&D, &tiaJB, &WMbEj, 0, 0, 0.5, 1);
 
524
    dpd_buf4_close(&D);
 
525
    dpd_buf4_close(&tiaJB);
 
526
 
 
527
    /* D(ME,nf) * T2(jb,nf) --> W(ME,jb) */
 
528
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ia,jb)");
 
529
    dpd_buf4_init(&tiajb, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tiajb");
 
530
    dpd_contract444(&D, &tiajb, &WMbEj, 0, 0, 0.5, 1);
 
531
    dpd_buf4_close(&D);
 
532
    dpd_buf4_close(&tiajb);
 
533
 
 
534
    dpd_buf4_close(&WMbEj);
 
535
 
 
536
 
 
537
    /* D(mE,Nf) * T2(jB,Nf) --> W(mE,jB) */
 
538
    dpd_buf4_init(&WmBEj, CC_HBAR, 0, 10, 10, 10, 10, 0, "WmBEj");
 
539
 
 
540
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ib,ja)");
 
541
    dpd_buf4_init(&tjAIb, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tjAIb");
 
542
    dpd_contract444(&D, &tjAIb, &WmBEj, 0, 0, 0.5, 1);
 
543
    dpd_buf4_close(&D);
 
544
    dpd_buf4_close(&tjAIb);
 
545
 
 
546
    dpd_buf4_close(&WmBEj);
 
547
 
 
548
 
 
549
    /* D(Me,nF) * T2(Jb,nF) --> W(Me,Jb) */
 
550
    dpd_buf4_init(&WMbeJ, CC_HBAR, 0, 10, 10, 10, 10, 0, "WMbeJ");
 
551
 
 
552
    dpd_buf4_init(&D, CC_DINTS, 0, 10, 10, 10, 10, 0, "D <ij|ab> (ib,ja)");
 
553
    dpd_buf4_init(&tIbjA, CC_TAMPS, 0, 10, 10, 10, 10, 0, "tIbjA");
 
554
    dpd_contract444(&D, &tIbjA, &WMbeJ, 0, 0, 0.5, 1);
 
555
    dpd_buf4_close(&D);
 
556
    dpd_buf4_close(&tIbjA);
 
557
 
 
558
    dpd_buf4_close(&WMbeJ);
 
559
 
 
560
  } /** RHF or ROHF **/
 
561
  else if(params.ref == 2) { /** UHF **/
 
562
 
 
563
    /* W(mb,je) <-- <mb||ej> */
 
564
 
 
565
    dpd_buf4_init(&C, CC_CINTS, 0, 20, 21, 20, 21, 0, "C <IA||JB> (IA,BJ)");
 
566
    dpd_buf4_scmcopy(&C, CC_TMP0, "WMBEJ", -1);
 
567
    dpd_buf4_close(&C);
 
568
 
 
569
    dpd_buf4_init(&C, CC_CINTS, 0, 30, 31, 30, 31, 0, "C <ia||jb> (ia,bj)");
 
570
    dpd_buf4_scmcopy(&C, CC_TMP0, "Wmbej", -1);
 
571
    dpd_buf4_close(&C);
 
572
 
 
573
    dpd_buf4_init(&D, CC_DINTS, 0, 24, 26, 24, 26, 0, "D <Ij|Ab> (Ib,Aj)");
 
574
    dpd_buf4_scmcopy(&D, CC_TMP0, "WMbEj", 1);
 
575
    dpd_buf4_close(&D);
 
576
 
 
577
    dpd_buf4_init(&D, CC_DINTS, 0, 27, 25, 27, 25, 0, "D <iJ|aB> (iB,aJ)");
 
578
    dpd_buf4_scmcopy(&D, CC_TMP0, "WmBeJ", 1);
 
579
    dpd_buf4_close(&D);
 
580
 
 
581
    dpd_buf4_init(&C, CC_CINTS, 0, 27, 27, 27, 27, 0, "C <iA|jB>");
 
582
    dpd_buf4_scmcopy(&C, CC_TMP0, "WmBEj", -1);
 
583
    dpd_buf4_close(&C);
 
584
 
 
585
    dpd_buf4_init(&C, CC_CINTS, 0, 24, 24, 24, 24, 0, "C <Ia|Jb>");
 
586
    dpd_buf4_scmcopy(&C, CC_TMP0, "WMbeJ", -1);
 
587
    dpd_buf4_close(&C);
 
588
 
 
589
    /* F -> Wmbej */
 
590
 
 
591
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
592
    dpd_file2_init(&tia, CC_OEI, 0, 2, 3, "tia");
 
593
 
 
594
    dpd_buf4_init(&W, CC_TMP0, 0, 20, 21, 20, 21, 0, "WMBEJ");
 
595
    dpd_buf4_init(&F, CC_FINTS, 0, 20, 5, 20, 5, 1, "F <IA|BC>");
 
596
    dpd_contract424(&F, &tIA, &W, 3, 1, 0, 1, 1);
 
597
    dpd_buf4_close(&F);
 
598
    dpd_buf4_close(&W);
 
599
 
 
600
    dpd_buf4_init(&W, CC_TMP0, 0, 30, 31, 30, 31, 0, "Wmbej");
 
601
    dpd_buf4_init(&F, CC_FINTS, 0, 30, 15, 30, 15, 1, "F <ia|bc>");
 
602
    dpd_contract424(&F, &tia, &W, 3, 1, 0, 1, 1);
 
603
    dpd_buf4_close(&F);
 
604
    dpd_buf4_close(&W);
 
605
 
 
606
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 26, 24, 26, 0, "WMbEj");
 
607
    dpd_buf4_init(&F, CC_FINTS, 0, 24, 28, 24, 28, 0, "F <Ia|Bc>");
 
608
    dpd_contract424(&F, &tia, &W, 3, 1, 0, 1, 1);
 
609
    dpd_buf4_close(&F);
 
610
    dpd_buf4_close(&W);
 
611
 
 
612
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 25, 27, 25, 0, "WmBeJ");
 
613
    dpd_buf4_init(&F, CC_FINTS, 0, 27, 29, 27, 29, 0, "F <iA|bC>");
 
614
    dpd_contract424(&F, &tIA, &W, 3, 1, 0, 1, 1);
 
615
    dpd_buf4_close(&F);
 
616
    dpd_buf4_close(&W);
 
617
 
 
618
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
619
    dpd_buf4_init(&F, CC_FINTS, 0, 24, 28, 24, 28, 0, "F <Ia|Bc>");
 
620
    dpd_contract244(&tIA, &F, &W, 1, 2, 1, -1, 1);
 
621
    dpd_buf4_close(&F);
 
622
    dpd_buf4_close(&W);
 
623
 
 
624
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 27, 27, 27, 0, "WmBEj");
 
625
    dpd_buf4_init(&F, CC_FINTS, 0, 27, 29, 27, 29, 0, "F <iA|bC>");
 
626
    dpd_contract244(&tia, &F, &W, 1, 2, 1, -1, 1);
 
627
    dpd_buf4_close(&F);
 
628
    dpd_buf4_close(&W);
 
629
 
 
630
    dpd_file2_close(&tIA);
 
631
    dpd_file2_close(&tia);
 
632
 
 
633
    /* E -> Wmbej */
 
634
 
 
635
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
636
    dpd_file2_init(&tia, CC_OEI, 0, 2, 3, "tia");
 
637
 
 
638
    dpd_buf4_init(&W, CC_TMP0, 0, 20, 21, 20, 21, 0, "WMBEJ");
 
639
    dpd_buf4_init(&E, CC_EINTS, 0, 0, 21, 2, 21, 0, "E <IJ||KA> (I>J,AK)");
 
640
    dpd_contract424(&E, &tIA, &W, 1, 0, 1, 1, 1);
 
641
    dpd_buf4_close(&E);
 
642
    dpd_buf4_close(&W);
 
643
 
 
644
    dpd_buf4_init(&W, CC_TMP0, 0, 30, 31, 30, 31, 0, "Wmbej");
 
645
    dpd_buf4_init(&E, CC_EINTS, 0, 10, 31, 12, 31, 0, "E <ij||ka> (i>j,ak)");
 
646
    dpd_contract424(&E, &tia, &W, 1, 0, 1, 1, 1);
 
647
    dpd_buf4_close(&E);
 
648
    dpd_buf4_close(&W);
 
649
 
 
650
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 26, 24, 26, 0, "WMbEj");
 
651
    dpd_buf4_init(&E, CC_EINTS, 0, 22, 26, 22, 26, 0, "E <Ij|Ak>");
 
652
    dpd_contract424(&E, &tia, &W, 1, 0, 1, -1, 1);
 
653
    dpd_buf4_close(&E);
 
654
    dpd_buf4_close(&W);
 
655
 
 
656
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 25, 27, 25, 0, "WmBeJ");
 
657
    dpd_buf4_init(&E, CC_EINTS, 0, 23, 25, 23, 25, 0, "E <iJ|aK>");
 
658
    dpd_contract424(&E, &tIA, &W, 1, 0, 1, -1, 1);
 
659
    dpd_buf4_close(&E);
 
660
    dpd_buf4_close(&W);
 
661
 
 
662
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
663
    dpd_buf4_init(&E, CC_EINTS, 0, 22, 24, 22, 24, 0, "E <Ij|Ka>");
 
664
    dpd_contract424(&E, &tia, &W, 1, 0, 1, 1, 1);
 
665
    dpd_buf4_close(&E);
 
666
    dpd_buf4_close(&W);
 
667
 
 
668
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 27, 27, 27, 0, "WmBEj");
 
669
    dpd_buf4_init(&E, CC_EINTS, 0, 23, 27, 23, 27, 0, "E <iJ|kA>");
 
670
    dpd_contract424(&E, &tIA, &W, 1, 0, 1, 1, 1);
 
671
    dpd_buf4_close(&E);
 
672
    dpd_buf4_close(&W);
 
673
 
 
674
    dpd_file2_close(&tIA);  
 
675
    dpd_file2_close(&tia);
 
676
 
 
677
    /* Convert to (ME,JB) for remaining terms */
 
678
 
 
679
    dpd_buf4_init(&W, CC_TMP0, 0, 20, 21, 20, 21, 0, "WMBEJ");
 
680
    dpd_buf4_sort(&W, CC_HBAR, prsq, 20, 20, "WMBEJ");
 
681
    dpd_buf4_close(&W);
 
682
 
 
683
    dpd_buf4_init(&W, CC_TMP0, 0, 30, 31, 30, 31, 0, "Wmbej");
 
684
    dpd_buf4_sort(&W, CC_HBAR, prsq, 30, 30, "Wmbej");
 
685
    dpd_buf4_close(&W);
 
686
 
 
687
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 26, 24, 26, 0, "WMbEj");
 
688
    dpd_buf4_sort(&W, CC_HBAR, prsq, 20, 30, "WMbEj");
 
689
    dpd_buf4_close(&W);
 
690
 
 
691
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 25, 27, 25, 0, "WmBeJ");
 
692
    dpd_buf4_sort(&W, CC_HBAR, prsq, 30, 20, "WmBeJ");
 
693
    dpd_buf4_close(&W);
 
694
 
 
695
    dpd_buf4_init(&W, CC_TMP0, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
696
    dpd_buf4_sort(&W, CC_HBAR, psrq, 24, 24, "WMbeJ");
 
697
    dpd_buf4_close(&W);
 
698
 
 
699
    dpd_buf4_init(&W, CC_TMP0, 0, 27, 27, 27, 27, 0, "WmBEj");
 
700
    dpd_buf4_sort(&W, CC_HBAR, psrq, 27, 27, "WmBEj");
 
701
    dpd_buf4_close(&W);
 
702
 
 
703
    /* X -> Wmbej */
 
704
 
 
705
    dpd_file2_init(&tIA, CC_OEI, 0, 0, 1, "tIA");
 
706
    dpd_file2_init(&tia, CC_OEI, 0, 2, 3, "tia");
 
707
 
 
708
    /*** AAAA ***/
 
709
 
 
710
    dpd_buf4_init(&W, CC_HBAR, 0, 20, 20, 20, 20, 0, "WMBEJ");
 
711
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 20, 20, 20, 0, "D <IJ||AB> (IA,JB)");
 
712
    dpd_buf4_init(&t2, CC_TAMPS, 0, 20, 20, 20, 20, 0, "tIAJB");
 
713
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
714
    dpd_buf4_close(&t2);
 
715
    dpd_buf4_close(&D);
 
716
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 30, 20, 30, 0, "D <Ij|Ab> (IA,jb)");
 
717
    dpd_buf4_init(&t2, CC_TAMPS, 0, 20, 30, 20, 30, 0, "tIAjb");
 
718
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
719
    dpd_buf4_close(&t2);
 
720
    dpd_buf4_close(&D);
 
721
    dpd_buf4_close(&W);
 
722
 
 
723
    dpd_buf4_init(&Y, CC_TMP0, 0, 20, 0, 20, 0, 0, "Y (ME,JN)");
 
724
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 21, 20, 21, 0, "D <IJ||AB> (IA,BJ)");
 
725
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
726
    dpd_buf4_close(&D);
 
727
    dpd_buf4_init(&W, CC_HBAR, 0, 20, 20, 20, 20, 0, "WMBEJ");
 
728
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, -1, 1);
 
729
    dpd_buf4_close(&W);
 
730
    dpd_buf4_close(&Y);
 
731
 
 
732
    /*** BBBB ***/
 
733
 
 
734
    dpd_buf4_init(&W, CC_HBAR, 0, 30, 30, 30, 30, 0, "Wmbej");
 
735
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 30, 30, 30, 0, "D <ij||ab> (ia,jb)");
 
736
    dpd_buf4_init(&t2, CC_TAMPS, 0, 30, 30, 30, 30, 0, "tiajb");
 
737
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
738
    dpd_buf4_close(&t2);
 
739
    dpd_buf4_close(&D);
 
740
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 20, 30, 20, 0, "D <Ij|Ab> (ia,JB)");
 
741
    dpd_buf4_init(&t2, CC_TAMPS, 0, 30, 20, 30, 20, 0, "tiaJB");
 
742
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
743
    dpd_buf4_close(&t2);
 
744
    dpd_buf4_close(&D);
 
745
    dpd_buf4_close(&W);
 
746
 
 
747
    dpd_buf4_init(&Y, CC_TMP0, 0, 30, 10, 30, 10, 0, "Y (me,jn)");
 
748
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 31, 30, 31, 0, "D <ij||ab> (ia,bj)");
 
749
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
750
    dpd_buf4_close(&D);
 
751
    dpd_buf4_init(&W, CC_HBAR, 0, 30, 30, 30, 30, 0, "Wmbej");
 
752
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, -1, 1);
 
753
    dpd_buf4_close(&W);
 
754
    dpd_buf4_close(&Y);
 
755
 
 
756
    /*** ABAB ***/
 
757
 
 
758
    dpd_buf4_init(&W, CC_HBAR, 0, 20, 30, 20, 30, 0, "WMbEj");
 
759
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 30, 20, 30, 0, "D <Ij|Ab> (IA,jb)");
 
760
    dpd_buf4_init(&t2, CC_TAMPS, 0, 30, 30, 30, 30, 0, "tiajb");
 
761
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
762
    dpd_buf4_close(&t2);
 
763
    dpd_buf4_close(&D);
 
764
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 20, 20, 20, 0, "D <IJ||AB> (IA,JB)");
 
765
    dpd_buf4_init(&t2, CC_TAMPS, 0, 30, 20, 30, 20, 0, "tiaJB");
 
766
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1); 
 
767
    dpd_buf4_close(&t2);
 
768
    dpd_buf4_close(&D);
 
769
    dpd_buf4_close(&W);
 
770
 
 
771
    dpd_buf4_init(&Y, CC_TMP0, 0, 20, 10, 20, 10, 0, "Y (ME,jn)");
 
772
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 31, 20, 31, 0, "D <Ij|Ab> (IA,bj)");
 
773
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
774
    dpd_buf4_close(&D);
 
775
    dpd_buf4_init(&W, CC_HBAR, 0, 20, 30, 20, 30, 0, "WMbEj");
 
776
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, -1, 1);
 
777
    dpd_buf4_close(&W);
 
778
    dpd_buf4_close(&Y);
 
779
 
 
780
    /*** BABA ***/
 
781
 
 
782
    dpd_buf4_init(&W, CC_HBAR, 0, 30, 20, 30, 20, 0, "WmBeJ");
 
783
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 20, 30, 20, 0, "D <Ij|Ab> (ia,JB)");
 
784
    dpd_buf4_init(&t2, CC_TAMPS, 0, 20, 20, 20, 20, 0, "tIAJB");
 
785
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
786
    dpd_buf4_close(&t2);
 
787
    dpd_buf4_close(&D);
 
788
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 30, 30, 30, 0, "D <ij||ab> (ia,jb)");
 
789
    dpd_buf4_init(&t2, CC_TAMPS, 0, 20, 30, 20, 30, 0, "tIAjb");
 
790
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1); 
 
791
    dpd_buf4_close(&t2);
 
792
    dpd_buf4_close(&D);
 
793
    dpd_buf4_close(&W);
 
794
 
 
795
    dpd_buf4_init(&Y, CC_TMP0, 0, 30, 0, 30, 0, 0, "Y (me,JN)");
 
796
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 21, 30, 21, 0, "D <Ij|Ab> (ia,BJ)");
 
797
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
798
    dpd_buf4_close(&D);
 
799
    dpd_buf4_init(&W, CC_HBAR, 0, 30, 20, 30, 20, 0, "WmBeJ");
 
800
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, -1, 1);
 
801
    dpd_buf4_close(&W);
 
802
    dpd_buf4_close(&Y);
 
803
 
 
804
    /*** ABBA ***/
 
805
  
 
806
    dpd_buf4_init(&W, CC_HBAR, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
807
    dpd_buf4_init(&t2, CC_TAMPS, 0, 24, 27, 24, 27, 0, "tIbjA");
 
808
    dpd_buf4_init(&D, CC_DINTS, 0, 24, 27, 24, 27, 0, "D <Ij|Ab> (Ib,jA)");
 
809
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
810
    dpd_buf4_close(&D);
 
811
    dpd_buf4_close(&t2);
 
812
    dpd_buf4_close(&W);
 
813
 
 
814
    dpd_buf4_init(&Y, CC_TMP0, 0, 24, 22, 24, 22, 0, "Y (Me,Jn)");
 
815
    dpd_buf4_init(&D, CC_DINTS, 0, 24, 26, 24, 26, 0, "D <Ij|Ab> (Ib,Aj)");
 
816
    dpd_contract244(&tIA, &D, &Y, 1, 2, 1, 1, 0);
 
817
    dpd_buf4_close(&D);
 
818
    dpd_buf4_init(&W, CC_HBAR, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
819
    dpd_contract424(&Y, &tia, &W, 3, 0, 0, 1, 1);
 
820
    dpd_buf4_close(&W);
 
821
    dpd_buf4_close(&Y);
 
822
 
 
823
    /*** BAAB ***/
 
824
  
 
825
    dpd_buf4_init(&W, CC_HBAR, 0, 27, 27, 27, 27, 0, "WmBEj");
 
826
    dpd_buf4_init(&t2, CC_TAMPS, 0, 27, 24, 27, 24, 0, "tiBJa");
 
827
    dpd_buf4_init(&D, CC_DINTS, 0, 27, 24, 27, 24, 0, "D <iJ|aB> (iB,Ja)");
 
828
    dpd_contract444(&D, &t2, &W, 0, 0, 0.5, 1);
 
829
    dpd_buf4_close(&D);
 
830
    dpd_buf4_close(&t2);
 
831
    dpd_buf4_close(&W);
 
832
 
 
833
    dpd_buf4_init(&Y, CC_TMP0, 0, 27, 23, 27, 23, 0, "Y (mE,jN)");
 
834
    dpd_buf4_init(&D, CC_DINTS, 0, 27, 25, 27, 25, 0, "D <iJ|aB> (iB,aJ)");
 
835
    dpd_contract244(&tia, &D, &Y, 1, 2, 1, 1, 0);
 
836
    dpd_buf4_close(&D);
 
837
    dpd_buf4_init(&W, CC_HBAR, 0, 27, 27, 27, 27, 0, "WmBEj");
 
838
    dpd_contract424(&Y, &tIA, &W, 3, 0, 0, 1, 1);
 
839
    dpd_buf4_close(&W);
 
840
    dpd_buf4_close(&Y);
 
841
 
 
842
    dpd_file2_close(&tIA);
 
843
    dpd_file2_close(&tia);
 
844
 
 
845
    /* D(me,nf) * T2(jb,nf) --> W(me,jb) */
 
846
    dpd_buf4_init(&Wmbej, CC_HBAR, 0, 30, 30, 30, 30, 0, "Wmbej");
 
847
 
 
848
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 30, 30, 30, 0, "D <ij||ab> (ia,jb)");
 
849
    dpd_buf4_init(&tiajb, CC_TAMPS, 0, 30, 30, 30, 30, 0, "tiajb");
 
850
    dpd_contract444(&D, &tiajb, &Wmbej, 0, 0, 0.5, 1);
 
851
    dpd_buf4_close(&D);
 
852
    dpd_buf4_close(&tiajb);
 
853
 
 
854
    /* D(me,NF) * T2(jb,NF) --> W(me,jb) */
 
855
    dpd_buf4_init(&tiaJB, CC_TAMPS, 0, 30, 20, 30, 20, 0, "tiaJB");
 
856
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 20, 30, 20, 0, "D <Ij|Ab> (ia,JB)");
 
857
    dpd_contract444(&D, &tiaJB, &Wmbej, 0, 0, 0.5, 1);
 
858
    dpd_buf4_close(&D);
 
859
    dpd_buf4_close(&tiaJB);
 
860
 
 
861
    dpd_buf4_close(&Wmbej);
 
862
 
 
863
 
 
864
    /* D(ME,NF) * T2(JB,NF) --> W(ME,JB) */
 
865
    dpd_buf4_init(&WMBEJ, CC_HBAR, 0, 20, 20, 20, 20, 0, "WMBEJ");
 
866
 
 
867
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 20, 20, 20, 0, "D <IJ||AB> (IA,JB)");
 
868
    dpd_buf4_init(&tIAJB, CC_TAMPS, 0, 20, 20, 20, 20, 0, "tIAJB");
 
869
    dpd_contract444(&D, &tIAJB, &WMBEJ, 0, 0, 0.5, 1);
 
870
    dpd_buf4_close(&D);
 
871
    dpd_buf4_close(&tIAJB);
 
872
 
 
873
    /* D(ME,nf) * T2(JB,nf) --> W(ME,JB) */
 
874
    dpd_buf4_init(&tIAjb, CC_TAMPS, 0, 20, 30, 20, 30, 0, "tIAjb");
 
875
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 30, 20, 30, 0, "D <Ij|Ab> (IA,jb)");
 
876
    dpd_contract444(&D, &tIAjb, &WMBEJ, 0, 0, 0.5, 1);
 
877
    dpd_buf4_close(&D);
 
878
    dpd_buf4_close(&tIAjb);
 
879
 
 
880
    dpd_buf4_close(&WMBEJ);
 
881
 
 
882
 
 
883
    /* D(me,nf) * T2(JB,nf) --> W(me,JB) */
 
884
    dpd_buf4_init(&WmBeJ, CC_HBAR, 0, 30, 20, 30, 20, 0, "WmBeJ");
 
885
 
 
886
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 30, 30, 30, 0, "D <ij||ab> (ia,jb)");
 
887
    dpd_buf4_init(&tIAjb, CC_TAMPS, 0, 20, 30, 20, 30, 0, "tIAjb");
 
888
    dpd_contract444(&D, &tIAjb, &WmBeJ, 0, 0, 0.5, 1);
 
889
    dpd_buf4_close(&D);
 
890
    dpd_buf4_close(&tIAjb);
 
891
 
 
892
    /* D(me,NF) * T2(JB,NF) --> W(me,JB) */
 
893
    dpd_buf4_init(&D, CC_DINTS, 0, 30, 20, 30, 20, 0, "D <Ij|Ab> (ia,JB)");
 
894
    dpd_buf4_init(&tIAJB, CC_TAMPS, 0, 20, 20, 20, 20, 0, "tIAJB");
 
895
    dpd_contract444(&D, &tIAJB, &WmBeJ, 0, 0, 0.5, 1);
 
896
    dpd_buf4_close(&D);
 
897
    dpd_buf4_close(&tIAJB);
 
898
 
 
899
    dpd_buf4_close(&WmBeJ);
 
900
 
 
901
 
 
902
    /* D(ME,NF) * T2(jb,NF) --> W(ME,jb) */
 
903
    dpd_buf4_init(&WMbEj, CC_HBAR, 0, 20, 30, 20, 30, 0, "WMbEj");
 
904
 
 
905
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 20, 20, 20, 0, "D <IJ||AB> (IA,JB)");
 
906
    dpd_buf4_init(&tiaJB, CC_TAMPS, 0, 30, 20, 30, 20, 0, "tiaJB");
 
907
    dpd_contract444(&D, &tiaJB, &WMbEj, 0, 0, 0.5, 1);
 
908
    dpd_buf4_close(&D);
 
909
    dpd_buf4_close(&tiaJB);
 
910
 
 
911
    /* D(ME,nf) * T2(jb,nf) --> W(ME,jb) */
 
912
    dpd_buf4_init(&D, CC_DINTS, 0, 20, 30, 20, 30, 0, "D <Ij|Ab> (IA,jb)");
 
913
    dpd_buf4_init(&tiajb, CC_TAMPS, 0, 30, 30, 30, 30, 0, "tiajb");
 
914
    dpd_contract444(&D, &tiajb, &WMbEj, 0, 0, 0.5, 1);
 
915
    dpd_buf4_close(&D);
 
916
    dpd_buf4_close(&tiajb);
 
917
 
 
918
    dpd_buf4_close(&WMbEj);
 
919
 
 
920
 
 
921
    /* D(mE,Nf) * T2(jB,Nf) --> W(mE,jB) */
 
922
    dpd_buf4_init(&WmBEj, CC_HBAR, 0, 27, 27, 27, 27, 0, "WmBEj");
 
923
 
 
924
    dpd_buf4_init(&D, CC_DINTS, 0, 27, 24, 27, 24, 0, "D <iJ|aB> (iB,Ja)");
 
925
    dpd_buf4_init(&tjAIb, CC_TAMPS, 0, 27, 24, 27, 24, 0, "tjAIb");
 
926
    dpd_contract444(&D, &tjAIb, &WmBEj, 0, 0, 0.5, 1);
 
927
    dpd_buf4_close(&D);
 
928
    dpd_buf4_close(&tjAIb);
 
929
 
 
930
    dpd_buf4_close(&WmBEj);
 
931
 
 
932
 
 
933
    /* D(Me,nF) * T2(Jb,nF) --> W(Me,Jb) */
 
934
    dpd_buf4_init(&WMbeJ, CC_HBAR, 0, 24, 24, 24, 24, 0, "WMbeJ");
 
935
 
 
936
    dpd_buf4_init(&D, CC_DINTS, 0, 24, 27, 24, 27, 0, "D <Ij|Ab> (Ib,jA)");
 
937
    dpd_buf4_init(&tIbjA, CC_TAMPS, 0, 24, 27, 24, 27, 0, "tIbjA");
 
938
    dpd_contract444(&D, &tIbjA, &WMbeJ, 0, 0, 0.5, 1);
 
939
    dpd_buf4_close(&D);
 
940
    dpd_buf4_close(&tIbjA);
 
941
 
 
942
    dpd_buf4_close(&WMbeJ);
 
943
 
 
944
  } /** UHF **/
 
945
 
 
946
  return;
 
947
}
 
948
 
 
949
 
 
950
}} // namespace psi::cchbar