~ubuntu-branches/ubuntu/quantal/psicode/quantal

« back to all changes in this revision

Viewing changes to src/bin/cceom/WbmfeDS.c

  • 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
 
#include <stdio.h>
2
 
#include <math.h>
3
 
#include <libciomr/libciomr.h>
4
 
#include <libqt/qt.h>
5
 
#define EXTERN
6
 
#include "globals.h"
7
 
 
8
 
/* This function computes the H-bar doubles-singles block contribution
9
 
   of Wbmfe to a Sigma vector stored at Sigma plus 'i' */
10
 
 
11
 
void WbmfeDS(int i, int C_irr) {
12
 
  dpdfile2 CME, Cme, XBF, Xbf;
13
 
  dpdbuf4 SIJAB, Sijab, SIjAb;
14
 
  dpdbuf4 WAMEF, Wamef, WAmEf, WaMeF, WM, WP, W, Z;
15
 
  dpdbuf4 TIJAB, TIjAb, Tijab;
16
 
  char CME_lbl[32], Cme_lbl[32], SIJAB_lbl[32], Sijab_lbl[32], SIjAb_lbl[32];
17
 
  int Gbm, Gfe, bm, b, m, Gb, Gm, Ge, Gf, B, M, f, e, fe, ef, nrows, ncols;
18
 
  dpdfile2 C;
19
 
  double *X;
20
 
 
21
 
  if (params.eom_ref == 0) { /* RHF */
22
 
    sprintf(CME_lbl, "%s %d", "CME", i);
23
 
    sprintf(SIjAb_lbl, "%s %d", "SIjAb", i);
24
 
 
25
 
    /* Form Xbf intermediates */
26
 
/*     dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF"); */
27
 
/*     dpd_file2_scm(&XBF, 0.0); */
28
 
/*     dpd_file2_init(&CME, EOM_CME, C_irr, 0, 1, CME_lbl); */
29
 
/*     dpd_buf4_init(&W, CC_HBAR, H_IRR, 11, 5, 11, 5, 0, "WAmEf 2(Am,Ef) - (Am,fE)"); */
30
 
/*     dpd_dot24(&CME, &W, &XBF, 0, 0, 1.0, 1.0); */
31
 
/*     dpd_buf4_close(&W); */
32
 
/*     dpd_file2_close(&CME); */
33
 
 
34
 
    /* OOC code below added 7/27/05, -TDC */
35
 
    /* X(b,f) = [ 2 Wbmfe - Wbmef ] * C(m,e) */
36
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
37
 
    dpd_file2_scm(&XBF, 0.0);
38
 
    dpd_file2_mat_init(&XBF);
39
 
    dpd_file2_mat_rd(&XBF);
40
 
    dpd_file2_init(&C, EOM_CME, C_irr, 0, 1, CME_lbl);
41
 
    dpd_file2_mat_init(&C);
42
 
    dpd_file2_mat_rd(&C);
43
 
    dpd_buf4_init(&W, CC_HBAR, H_IRR, 11, 5, 11, 5, 0, "WAmEf");
44
 
    for(Gbm=0; Gbm < moinfo.nirreps; Gbm++) {
45
 
      Gfe = Gbm ^ H_IRR;
46
 
      dpd_buf4_mat_irrep_row_init(&W, Gbm);
47
 
      X = init_array(W.params->coltot[Gfe]);
48
 
      for(bm=0; bm < W.params->rowtot[Gbm]; bm++) {
49
 
        dpd_buf4_mat_irrep_row_rd(&W, Gbm, bm);
50
 
 
51
 
        b = W.params->roworb[Gbm][bm][0];
52
 
        m = W.params->roworb[Gbm][bm][1];
53
 
        Gb = W.params->psym[b];
54
 
        Gm = Gbm ^ Gb;
55
 
        Ge = Gm ^ C_irr;
56
 
        Gf = Ge ^ Gfe;
57
 
        B = b - moinfo.vir_off[Gb];
58
 
        M = m - moinfo.occ_off[Gm];
59
 
 
60
 
        zero_arr(X, W.params->coltot[Gfe]);
61
 
 
62
 
        for(fe=0; fe < W.params->coltot[Gfe]; fe++) {
63
 
          f = W.params->colorb[Gfe][fe][0];
64
 
          e = W.params->colorb[Gfe][fe][1];
65
 
          ef = W.params->colidx[e][f];
66
 
          X[fe] = 2.0 * W.matrix[Gbm][0][fe] - W.matrix[Gbm][0][ef];
67
 
        }
68
 
 
69
 
        nrows = moinfo.virtpi[Gf];
70
 
        ncols = moinfo.virtpi[Ge];
71
 
 
72
 
        if(nrows && ncols)
73
 
          C_DGEMV('n',nrows,ncols,1,&X[W.col_offset[Gfe][Gf]],ncols,
74
 
                  C.matrix[Gm][M],1,1,XBF.matrix[Gb][B],1);
75
 
 
76
 
      }
77
 
      free(X);
78
 
      dpd_buf4_mat_irrep_row_close(&W, Gbm);
79
 
    }
80
 
    dpd_buf4_close(&W);
81
 
    dpd_file2_close(&C);
82
 
    dpd_file2_mat_wrt(&XBF);
83
 
    dpd_file2_mat_close(&XBF);
84
 
 
85
 
    dpd_buf4_init(&Z, EOM_TMP, C_irr, 0, 5, 0, 5, 0, "WbmfeDS Z(Ij,Ab)");
86
 
    dpd_buf4_init(&TIjAb, CC_TAMPS, H_IRR, 0, 5, 0, 5, 0, "tIjAb");
87
 
    dpd_contract424(&TIjAb, &XBF, &Z, 3, 1, 0, 1.0, 0.0);
88
 
    dpd_buf4_close(&TIjAb);
89
 
    dpd_buf4_sort_axpy(&Z, EOM_SIjAb, qpsr, 0, 5, SIjAb_lbl, 1);
90
 
    dpd_buf4_init(&SIjAb, EOM_SIjAb, C_irr, 0, 5, 0, 5, 0, SIjAb_lbl);
91
 
    dpd_buf4_axpy(&Z, &SIjAb, 1.0);
92
 
    dpd_buf4_close(&Z);
93
 
    dpd_buf4_close(&SIjAb);
94
 
    dpd_file2_close(&XBF);
95
 
  }
96
 
 
97
 
  else if (params.eom_ref == 1) { /* ROHF */
98
 
    sprintf(CME_lbl, "%s %d", "CME", i);
99
 
    sprintf(Cme_lbl, "%s %d", "Cme", i);
100
 
    sprintf(SIJAB_lbl, "%s %d", "SIJAB", i);
101
 
    sprintf(Sijab_lbl, "%s %d", "Sijab", i);
102
 
    sprintf(SIjAb_lbl, "%s %d", "SIjAb", i);
103
 
 
104
 
    /* Form Xbf intermediates */
105
 
    /* XBF = CME * WBMFE + Cme * WBmFe */
106
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
107
 
    dpd_file2_scm(&XBF, 0.0);
108
 
    dpd_file2_init(&CME, EOM_CME, C_irr, 0, 1, CME_lbl);
109
 
    dpd_buf4_init(&WAMEF, CC_HBAR, H_IRR, 11, 5, 11, 7, 0, "WAMEF");
110
 
    dpd_dot24(&CME, &WAMEF, &XBF, 0, 0, 1.0, 1.0);
111
 
    dpd_buf4_close(&WAMEF);
112
 
    dpd_file2_close(&CME);
113
 
    dpd_file2_init(&Cme, EOM_Cme, C_irr, 0, 1, Cme_lbl);
114
 
    dpd_buf4_init(&WAmEf, CC_HBAR, H_IRR, 11, 5, 11, 5, 0, "WAmEf");
115
 
    dpd_dot24(&Cme, &WAmEf, &XBF, 0, 0, 1.0, 1.0);
116
 
    dpd_buf4_close(&WAmEf);
117
 
    dpd_file2_close(&Cme);
118
 
    dpd_file2_close(&XBF);
119
 
 
120
 
    /* Xbf = Cme * Wbmfe + CME * WbMfE */
121
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 1, 1, "Xbf");
122
 
    dpd_file2_scm(&Xbf, 0.0);
123
 
    dpd_file2_init(&Cme, EOM_Cme, C_irr, 0, 1, Cme_lbl);
124
 
    dpd_buf4_init(&Wamef, CC_HBAR, H_IRR, 11, 5, 11, 7, 0, "Wamef");
125
 
    dpd_dot24(&Cme, &Wamef, &Xbf, 0, 0, 1.0, 1.0);
126
 
    dpd_buf4_close(&Wamef);
127
 
    dpd_file2_close(&Cme);
128
 
    dpd_file2_init(&CME, EOM_CME, C_irr, 0, 1, CME_lbl);
129
 
    dpd_buf4_init(&WaMeF, CC_HBAR, H_IRR, 11, 5, 11, 5, 0, "WaMeF");
130
 
    dpd_dot24(&CME, &WaMeF, &Xbf, 0, 0, 1.0, 1.0);
131
 
    dpd_buf4_close(&WaMeF);
132
 
    dpd_file2_close(&CME);
133
 
    dpd_file2_close(&Xbf);
134
 
 
135
 
    /* SIJAB += XBF * TIJAF - XAF * TIJBF */
136
 
    dpd_buf4_init(&WP, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_P");
137
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
138
 
    dpd_buf4_init(&TIJAB, CC_TAMPS, H_IRR, 2, 5, 2, 7, 0, "tIJAB");
139
 
    dpd_contract424(&TIJAB, &XBF, &WP, 3, 1, 0, 1.0, 0.0);
140
 
    dpd_buf4_close(&TIJAB);
141
 
    dpd_file2_close(&XBF);
142
 
    dpd_buf4_sort(&WP, EOM_TMP, pqsr, 2, 5, "WbmfeDS_M"); 
143
 
    dpd_buf4_init(&SIJAB, EOM_SIJAB, C_irr, 2, 5, 2, 7, 0, SIJAB_lbl);
144
 
    dpd_buf4_axpy(&WP, &SIJAB, 1.0);
145
 
    dpd_buf4_close(&WP);
146
 
    dpd_buf4_init(&WM, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_M");
147
 
    dpd_buf4_axpy(&WM, &SIJAB, -1.0);
148
 
    dpd_buf4_close(&WM);
149
 
    dpd_buf4_close(&SIJAB);
150
 
 
151
 
    /* Sijab += Xbf * Tijaf - Xaf * Tijbf */
152
 
    dpd_buf4_init(&WP, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_P");
153
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 1, 1, "Xbf");
154
 
    dpd_buf4_init(&Tijab, CC_TAMPS, H_IRR, 2, 5, 2, 7, 0, "tijab");
155
 
    dpd_contract424(&Tijab, &Xbf, &WP, 3, 1, 0, 1.0, 0.0);
156
 
    dpd_buf4_close(&Tijab);
157
 
    dpd_file2_close(&Xbf);
158
 
    dpd_buf4_sort(&WP, EOM_TMP, pqsr, 2, 5, "WbmfeDS_M");
159
 
    dpd_buf4_init(&Sijab, EOM_Sijab, C_irr, 2, 5, 2, 7, 0, Sijab_lbl);
160
 
    dpd_buf4_axpy(&WP, &Sijab, 1.0);
161
 
    dpd_buf4_close(&WP);
162
 
    dpd_buf4_init(&WM, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_M");
163
 
    dpd_buf4_axpy(&WM, &Sijab, -1.0);
164
 
    dpd_buf4_close(&WM);
165
 
    dpd_buf4_close(&Sijab);
166
 
 
167
 
    /* SIjAb += Xbf * tIjAf + XAF * TIjbF */
168
 
    dpd_buf4_init(&SIjAb, EOM_SIjAb, C_irr, 0, 5, 0, 5, 0, SIjAb_lbl);
169
 
    dpd_buf4_init(&TIjAb, CC_TAMPS, H_IRR, 0, 5, 0, 5, 0, "tIjAb");
170
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 1, 1, "Xbf");
171
 
    dpd_contract424(&TIjAb, &Xbf, &SIjAb, 3, 1, 0, 1.0, 1.0);
172
 
    dpd_file2_close(&Xbf);
173
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
174
 
    dpd_contract244(&XBF, &TIjAb, &SIjAb, 1, 2, 1, 1.0, 1.0);
175
 
    dpd_file2_close(&XBF);
176
 
    dpd_buf4_close(&TIjAb);
177
 
    dpd_buf4_close(&SIjAb);
178
 
  }
179
 
 
180
 
  else { /* UHF */
181
 
    sprintf(CME_lbl, "%s %d", "CME", i);
182
 
    sprintf(Cme_lbl, "%s %d", "Cme", i);
183
 
    sprintf(SIJAB_lbl, "%s %d", "SIJAB", i);
184
 
    sprintf(Sijab_lbl, "%s %d", "Sijab", i);
185
 
    sprintf(SIjAb_lbl, "%s %d", "SIjAb", i);
186
 
 
187
 
    /* Form Xbf intermediates */
188
 
    /* XBF = CME * WBMFE + Cme * WBmFe */
189
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
190
 
    dpd_file2_scm(&XBF, 0.0);
191
 
    dpd_file2_init(&CME, EOM_CME, C_irr, 0, 1, CME_lbl);
192
 
    dpd_buf4_init(&WAMEF, CC_HBAR, H_IRR, 21, 5, 21, 7, 0, "WAMEF");
193
 
    dpd_dot24(&CME, &WAMEF, &XBF, 0, 0, 1.0, 1.0);
194
 
    dpd_buf4_close(&WAMEF);
195
 
    dpd_file2_close(&CME);
196
 
    dpd_file2_init(&Cme, EOM_Cme, C_irr, 2, 3, Cme_lbl);
197
 
    dpd_buf4_init(&WAmEf, CC_HBAR, H_IRR, 26, 28, 26, 28, 0, "WAmEf");
198
 
    dpd_dot24(&Cme, &WAmEf, &XBF, 0, 0, 1.0, 1.0);
199
 
    dpd_buf4_close(&WAmEf);
200
 
    dpd_file2_close(&Cme);
201
 
/*
202
 
fprintf(outfile,"XBF self dot %15.10lf\n", dpd_file2_dot_self(&XBF));
203
 
*/
204
 
    dpd_file2_close(&XBF);
205
 
 
206
 
    /* Xbf = Cme * Wbmfe + CME * WbMfE */
207
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 3, 3, "Xbf");
208
 
    dpd_file2_scm(&Xbf, 0.0);
209
 
    dpd_file2_init(&Cme, EOM_Cme, C_irr, 2, 3, Cme_lbl);
210
 
    dpd_buf4_init(&Wamef, CC_HBAR, H_IRR, 31, 15, 31, 17, 0, "Wamef");
211
 
    dpd_dot24(&Cme, &Wamef, &Xbf, 0, 0, 1.0, 1.0);
212
 
    dpd_buf4_close(&Wamef);
213
 
    dpd_file2_close(&Cme);
214
 
    dpd_file2_init(&CME, EOM_CME, C_irr, 0, 1, CME_lbl);
215
 
    dpd_buf4_init(&WaMeF, CC_HBAR, H_IRR, 25, 29, 25, 29, 0, "WaMeF");
216
 
    dpd_dot24(&CME, &WaMeF, &Xbf, 0, 0, 1.0, 1.0);
217
 
    dpd_buf4_close(&WaMeF);
218
 
    dpd_file2_close(&CME);
219
 
/*
220
 
fprintf(outfile,"Xbf self dot %15.10lf\n", dpd_file2_dot_self(&Xbf));
221
 
*/
222
 
    dpd_file2_close(&Xbf);
223
 
 
224
 
    /* SIJAB += XBF * TIJAF - XAF * TIJBF */
225
 
    dpd_buf4_init(&WP, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_P");
226
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
227
 
    dpd_buf4_init(&TIJAB, CC_TAMPS, H_IRR, 2, 5, 2, 7, 0, "tIJAB");
228
 
    dpd_contract424(&TIJAB, &XBF, &WP, 3, 1, 0, 1.0, 0.0);
229
 
    dpd_buf4_close(&TIJAB);
230
 
    dpd_file2_close(&XBF);
231
 
    dpd_buf4_sort(&WP, EOM_TMP, pqsr, 2, 5, "WbmfeDS_M"); 
232
 
    dpd_buf4_init(&SIJAB, EOM_SIJAB, C_irr, 2, 5, 2, 7, 0, SIJAB_lbl);
233
 
    dpd_buf4_axpy(&WP, &SIJAB, 1.0);
234
 
    dpd_buf4_close(&WP);
235
 
    dpd_buf4_init(&WM, EOM_TMP, C_irr, 2, 5, 2, 5, 0, "WbmfeDS_M");
236
 
    dpd_buf4_axpy(&WM, &SIJAB, -1.0);
237
 
    dpd_buf4_close(&WM);
238
 
    dpd_buf4_close(&SIJAB);
239
 
 
240
 
    /* Sijab += Xbf * Tijaf - Xaf * Tijbf */
241
 
    dpd_buf4_init(&WP, EOM_TMP, C_irr, 12, 15, 12, 15, 0, "WbmfeDS_PB");
242
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 3, 3, "Xbf");
243
 
    dpd_buf4_init(&Tijab, CC_TAMPS, H_IRR, 12, 15, 12, 17, 0, "tijab");
244
 
    dpd_contract424(&Tijab, &Xbf, &WP, 3, 1, 0, 1.0, 0.0);
245
 
    dpd_buf4_close(&Tijab);
246
 
    dpd_file2_close(&Xbf);
247
 
    dpd_buf4_sort(&WP, EOM_TMP, pqsr, 12, 15, "WbmfeDS_MB");
248
 
    dpd_buf4_init(&Sijab, EOM_Sijab, C_irr, 12, 15, 12, 17, 0, Sijab_lbl);
249
 
    dpd_buf4_axpy(&WP, &Sijab, 1.0);
250
 
    dpd_buf4_close(&WP);
251
 
    dpd_buf4_init(&WM, EOM_TMP, C_irr, 12, 15, 12, 15, 0, "WbmfeDS_MB");
252
 
    dpd_buf4_axpy(&WM, &Sijab, -1.0);
253
 
    dpd_buf4_close(&WM);
254
 
    dpd_buf4_close(&Sijab);
255
 
 
256
 
    /* SIjAb += Xbf * tIjAf + XAF * TIjbF */
257
 
    dpd_buf4_init(&SIjAb, EOM_SIjAb, C_irr, 22, 28, 22, 28, 0, SIjAb_lbl);
258
 
    dpd_buf4_init(&TIjAb, CC_TAMPS, H_IRR, 22, 28, 22, 28, 0, "tIjAb");
259
 
    dpd_file2_init(&Xbf, EOM_TMP, C_irr, 3, 3, "Xbf");
260
 
    dpd_contract424(&TIjAb, &Xbf, &SIjAb, 3, 1, 0, 1.0, 1.0);
261
 
    dpd_file2_close(&Xbf);
262
 
    dpd_file2_init(&XBF, EOM_TMP, C_irr, 1, 1, "XBF");
263
 
    dpd_contract244(&XBF, &TIjAb, &SIjAb, 1, 2, 1, 1.0, 1.0);
264
 
    dpd_file2_close(&XBF);
265
 
    dpd_buf4_close(&TIjAb);
266
 
    dpd_buf4_close(&SIjAb);
267
 
  }
268
 
 
269
 
#ifdef EOM_DEBUG
270
 
  check_sum("WbmfeDS",i,C_irr);
271
 
#endif
272
 
  return;
273
 
}