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

« back to all changes in this revision

Viewing changes to src/bin/cclambda/cc2_fmiL2.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 <libdpd/dpd.h>
3
 
#define EXTERN
4
 
#include "globals.h"
5
 
 
6
 
/** The RHF/ROHF contractions can be improved here **/
7
 
 
8
 
void cc2_fmiL2(int L_irr)
9
 
{
10
 
  int h, m;
11
 
  dpdbuf4 Lijab, LIJAB, LIjAb;
12
 
  dpdbuf4 newLijab, newLIJAB, newLIjAb;
13
 
  dpdfile2 fij, fIJ, F;
14
 
  dpdbuf4 X, X1, X2;
15
 
  dpdbuf4 L2, newL2;
16
 
 
17
 
  /* RHS -= P(ij)*Limab*Fjm */
18
 
  if(params.ref == 0) { /** RHF **/
19
 
 
20
 
    dpd_buf4_init(&X, CC_TMP0, L_irr, 0, 5, 0, 5, 0, "X(Ij,Ab)");
21
 
 
22
 
    dpd_buf4_init(&L2, CC_LAMBDA, L_irr, 0, 5, 0, 5, 0, "LIjAb");
23
 
    dpd_file2_init(&F, CC_OEI, 0, 0, 0, "fIJ");
24
 
    dpd_contract244(&F, &L2, &X, 1, 0, 0, -1.0, 0);
25
 
    dpd_file2_close(&F);
26
 
    dpd_buf4_close(&L2);
27
 
 
28
 
    dpd_buf4_sort_axpy(&X, CC_LAMBDA, qpsr, 0, 5, "New LIjAb", 1);
29
 
    dpd_buf4_init(&newL2, CC_LAMBDA, L_irr, 0, 5, 0, 5, 0, "New LIjAb");
30
 
    dpd_buf4_axpy(&X, &newL2, 1);
31
 
    dpd_buf4_close(&newL2);
32
 
 
33
 
    dpd_buf4_close(&X);
34
 
  }
35
 
  else if(params.ref == 1) { /** RHF/ROHF **/
36
 
 
37
 
    dpd_file2_init(&fIJ, CC_OEI, 0, 0, 0, "fIJ");
38
 
    dpd_file2_init(&fij, CC_OEI, 0, 0, 0, "fij");
39
 
 
40
 
    dpd_buf4_init(&LIJAB, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "LIJAB");
41
 
    dpd_buf4_init(&X1, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(0,7) 1");
42
 
    dpd_contract424(&LIJAB, &fIJ, &X1, 1, 1, 1, -1.0, 0.0);
43
 
    dpd_buf4_init(&X2, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(0,7) 2");
44
 
    dpd_contract244(&fIJ, &LIJAB, &X2, 1, 0, 0, -1.0, 0.0);
45
 
    dpd_buf4_close(&LIJAB);
46
 
    dpd_buf4_axpy(&X1, &X2, 1.0);
47
 
    dpd_buf4_close(&X1);
48
 
    dpd_buf4_init(&newLIJAB, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "New LIJAB");
49
 
    dpd_buf4_axpy(&X2, &newLIJAB, 1.0);
50
 
    dpd_buf4_close(&X2);
51
 
    dpd_buf4_close(&newLIJAB);
52
 
 
53
 
    dpd_buf4_init(&Lijab, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "Lijab");
54
 
    dpd_buf4_init(&X1, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(0,7) 1");
55
 
    dpd_contract424(&Lijab, &fij, &X1, 1, 1, 1, -1.0, 0.0);
56
 
    dpd_buf4_init(&X2, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(0,7) 2");
57
 
    dpd_contract244(&fij, &Lijab, &X2, 1, 0, 0, -1.0, 0.0);
58
 
    dpd_buf4_close(&Lijab);
59
 
    dpd_buf4_axpy(&X1, &X2, 1.0);
60
 
    dpd_buf4_close(&X1);
61
 
    dpd_buf4_init(&newLijab, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "New Lijab");
62
 
    dpd_buf4_axpy(&X2, &newLijab, 1.0);
63
 
    dpd_buf4_close(&X2);
64
 
    dpd_buf4_close(&newLijab);
65
 
 
66
 
    dpd_buf4_init(&LIjAb, CC_LAMBDA, L_irr, 0, 5, 0, 5, 0, "LIjAb");
67
 
    dpd_buf4_init(&newLIjAb, CC_LAMBDA, L_irr, 0, 5, 0, 5, 0, "New LIjAb");
68
 
    dpd_contract424(&LIjAb, &fij, &newLIjAb, 1, 1, 1, -1.0, 1.0);
69
 
    dpd_contract244(&fIJ, &LIjAb, &newLIjAb, 1, 0, 0, -1.0, 1.0);
70
 
    dpd_buf4_close(&LIjAb);
71
 
    dpd_buf4_close(&newLIjAb);
72
 
 
73
 
    dpd_file2_close(&fij);
74
 
    dpd_file2_close(&fIJ);
75
 
  }
76
 
  else if(params.ref == 2) { /** UHF **/
77
 
 
78
 
    dpd_file2_init(&fIJ, CC_OEI, 0, 0, 0, "fIJ");
79
 
    dpd_file2_init(&fij, CC_OEI, 0, 2, 2, "fij");
80
 
    dpd_file2_copy(&fIJ, CC_OEI, "fIJ diag");
81
 
    dpd_file2_copy(&fij, CC_OEI, "fij diag");
82
 
    dpd_file2_close(&fIJ);
83
 
    dpd_file2_close(&fij);
84
 
 
85
 
    dpd_file2_init(&fIJ, CC_OEI, 0, 0, 0, "fIJ diag");
86
 
    dpd_file2_init(&fij, CC_OEI, 0, 2, 2, "fij diag");
87
 
 
88
 
    dpd_file2_mat_init(&fIJ);
89
 
    dpd_file2_mat_rd(&fIJ);
90
 
    dpd_file2_mat_init(&fij);
91
 
    dpd_file2_mat_rd(&fij);
92
 
 
93
 
    for(h=0; h < moinfo.nirreps; h++) {
94
 
      for(m=0; m < fIJ.params->rowtot[h]; m++) 
95
 
        fIJ.matrix[h][m][m] = 0;
96
 
 
97
 
      for(m=0; m < fij.params->rowtot[h]; m++) 
98
 
        fij.matrix[h][m][m] = 0;
99
 
    }
100
 
 
101
 
    dpd_file2_mat_wrt(&fIJ);
102
 
    dpd_file2_mat_close(&fIJ);
103
 
    dpd_file2_mat_wrt(&fij);
104
 
    dpd_file2_mat_close(&fij);
105
 
 
106
 
    dpd_file2_close(&fIJ);
107
 
    dpd_file2_close(&fij);
108
 
 
109
 
    dpd_file2_init(&fIJ, CC_OEI, 0, 0, 0, "fIJ diag");
110
 
    dpd_file2_init(&fij, CC_OEI, 0, 2, 2, "fij diag");
111
 
 
112
 
    /** X(IJ,AB) = F(I,M) L(MJ,AB) **/
113
 
    dpd_buf4_init(&X, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(IJ,AB) B");
114
 
    dpd_buf4_init(&LIJAB, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "LIJAB");
115
 
    dpd_contract244(&fIJ, &LIJAB, &X, 1, 0, 0, -1, 0);
116
 
    dpd_buf4_close(&LIJAB);
117
 
    /** X(IJ,AB) --> X'(JI,AB) **/
118
 
    dpd_buf4_sort(&X, CC_TMP1, qprs, 0, 7, "X'(JI,AB)");
119
 
    dpd_buf4_close(&X);
120
 
 
121
 
    /** X(IJ,AB) = X(IJ,AB) - X'(JI,AB) **/
122
 
    dpd_buf4_init(&X1, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X(IJ,AB) B");
123
 
    dpd_buf4_init(&X2, CC_TMP1, L_irr, 0, 7, 0, 7, 0, "X'(JI,AB)");
124
 
    dpd_buf4_axpy(&X2, &X1, -1.0);
125
 
    dpd_buf4_close(&X2);
126
 
    /** L(IJ,AB) <--- X(IJ,AB) **/
127
 
    dpd_buf4_init(&newLIJAB, CC_LAMBDA, L_irr, 0, 7, 2, 7, 0, "New LIJAB");
128
 
    dpd_buf4_axpy(&X1, &newLIJAB, 1.0);
129
 
    dpd_buf4_close(&X1);
130
 
    dpd_buf4_close(&newLIJAB);
131
 
 
132
 
 
133
 
    /** X(ij,ab) = F(i,m) L(mj,ab) **/
134
 
    dpd_buf4_init(&X, CC_TMP1, L_irr, 10, 17, 10, 17, 0, "X(ij,ab) B");
135
 
    dpd_buf4_init(&LIJAB, CC_LAMBDA, L_irr, 10, 17, 12, 17, 0, "Lijab");
136
 
    dpd_contract244(&fij, &LIJAB, &X, 1, 0, 0, -1, 0);
137
 
    dpd_buf4_close(&LIJAB);
138
 
    /** X(ij,ab) --> X'(ji,ab) **/
139
 
    dpd_buf4_sort(&X, CC_TMP1, qprs, 10, 17, "X'(ji,ab)");
140
 
    dpd_buf4_close(&X);
141
 
 
142
 
    /** X(ij,ab) = X(ij,ab) - X'(ji,ab) **/
143
 
    dpd_buf4_init(&X1, CC_TMP1, L_irr, 10, 17, 10, 17, 0, "X(ij,ab) B");
144
 
    dpd_buf4_init(&X2, CC_TMP1, L_irr, 10, 17, 10, 17, 0, "X'(ji,ab)");
145
 
    dpd_buf4_axpy(&X2, &X1, -1.0);
146
 
    dpd_buf4_close(&X2);
147
 
    /** L(ij,ab) <--- X(ij,ab) **/
148
 
    dpd_buf4_init(&newLIJAB, CC_LAMBDA, L_irr, 10, 17, 12, 17, 0, "New Lijab");
149
 
    dpd_buf4_axpy(&X1, &newLIJAB, 1.0);
150
 
    dpd_buf4_close(&X1);
151
 
    dpd_buf4_close(&newLIJAB);
152
 
 
153
 
    /** L(Ij,Ab) <-- L(Im,Ab) F(j,m) - F(I,M) L(Mj,Ab) **/
154
 
    dpd_buf4_init(&LIjAb, CC_LAMBDA, L_irr, 22, 28, 22, 28, 0, "LIjAb");
155
 
    dpd_buf4_init(&newLIjAb, CC_LAMBDA, L_irr, 22, 28, 22, 28, 0, "New LIjAb");
156
 
    dpd_contract424(&LIjAb, &fij, &newLIjAb, 1, 1, 1, -1, 1);
157
 
    dpd_contract244(&fIJ, &LIjAb, &newLIjAb, 1, 0, 0, -1, 1);
158
 
    dpd_buf4_close(&LIjAb);
159
 
    dpd_buf4_close(&newLIjAb);
160
 
 
161
 
    dpd_file2_close(&fij);
162
 
    dpd_file2_close(&fIJ);
163
 
  }
164
 
}