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

« back to all changes in this revision

Viewing changes to src/bin/ccresponse/LHX1Y1.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
1
#include <stdio.h>
2
2
#include <string.h>
3
3
#include <libdpd/dpd.h>
 
4
#include <libciomr/libciomr.h>
 
5
#include <libqt/qt.h>
4
6
#define EXTERN
5
7
#include "globals.h"
6
8
 
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".  
 
14
**
 
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.
 
17
**
 
18
** Type-II residuals are computed once in lambda_residuals(): L1*Fme
 
19
** and L2*Wmbej.
 
20
**
 
21
** TDC, 9/10/05
 
22
*/
 
23
 
 
24
void build_XY(char *, char *, int, double, char *, char *, int, double);
8
25
 
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)
11
28
{
12
29
 
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;
15
 
  double polar;
16
 
  char lbl[32];
17
 
 
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);
24
 
 
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);
30
 
  dpd_file2_close(&F);
31
 
  dpd_contract222(&Zmi, &Y1, &ZIA, 1, 1, -1, 0);
32
 
 
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);
37
 
  dpd_file2_close(&F);
38
 
  dpd_contract222(&Zmi, &X1, &ZIA, 1, 1, -1, 1);
39
 
  dpd_file2_close(&Zmi);
40
 
 
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);
46
 
  dpd_buf4_close(&W1);
47
 
  dpd_contract222(&X1, &Zae, &ZIA, 0, 0, 1, 1);
48
 
 
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);
52
 
  dpd_buf4_close(&W1);
53
 
  dpd_contract222(&Y1, &Zae, &ZIA, 0, 0, 1, 1);
54
 
  dpd_file2_close(&Zae);
55
 
 
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);
61
 
  dpd_buf4_close(&W1);
62
 
  dpd_contract222(&Zmi, &X1, &ZIA, 1, 1, 1, 1);
63
 
 
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);
67
 
  dpd_buf4_close(&W1);
68
 
  dpd_contract222(&Zmi, &Y1, &ZIA, 1, 1, 1, 1);
69
 
  dpd_file2_close(&Zmi);
70
 
 
71
 
  dpd_file2_close(&Y1);
72
 
  dpd_file2_close(&X1);
73
 
 
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);
77
 
  dpd_file2_close(&L1);
78
 
  dpd_file2_close(&ZIA);
79
 
 
80
 
  /*  fprintf(outfile, "L(1)HX1Y1 = %20.12f\n", polar); */
81
 
 
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);
87
 
 
88
 
 
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);
96
 
  dpd_buf4_close(&W1);
97
 
  dpd_buf4_close(&Z1);
98
 
  dpd_buf4_close(&ZIjAb);
99
 
 
100
 
  /* Contraction of Wabef with Zijef */
101
 
  dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) anti");
102
 
 
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);
106
 
  dpd_buf4_close(&I);
107
 
  dpd_buf4_sort_axpy(&Z2, CC_TMP0, rspq, 0, 5, "Z(Ij,Ab) Final", 1);
108
 
  dpd_buf4_close(&Z2);
109
 
 
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);
114
 
  dpd_buf4_close(&I);
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);
118
 
  dpd_buf4_close(&Z2);
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);
122
 
  dpd_buf4_close(&I);
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);
126
 
  dpd_buf4_close(&Z2);
127
 
  dpd_buf4_close(&Z1);
128
 
  dpd_buf4_close(&ZIjAb);
129
 
 
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");
133
 
  dpd_buf4_close(&Z1);
134
 
 
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);
139
 
  dpd_buf4_close(&W1);
140
 
  dpd_buf4_close(&Z1);
141
 
  dpd_buf4_sort(&Z2, CC_TMP0, prqs, 0, 5, "Z(Ij,Ab) I");
142
 
  dpd_buf4_close(&Z2);
143
 
 
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);
148
 
  dpd_buf4_close(&W1);
149
 
  dpd_buf4_close(&Z1);
150
 
  dpd_buf4_sort(&Z2, CC_TMP0, rpqs, 0, 5, "Z(Ij,Ab) II");
151
 
  dpd_buf4_close(&Z2);
152
 
 
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);
156
 
  dpd_buf4_close(&Z2);
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);
160
 
  dpd_buf4_close(&Z1);
161
 
  dpd_buf4_close(&ZIjAb);
162
 
 
163
 
 
164
 
  dpd_buf4_init(&ZIjAb, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(Ij,Ab) Final");
165
 
 
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);
171
 
  dpd_buf4_close(&I);
172
 
  dpd_buf4_close(&Z1);
173
 
 
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);
177
 
  dpd_buf4_close(&T2);
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");
181
 
  dpd_buf4_close(&Z1);
182
 
  dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(jI,bA) temp");
183
 
  dpd_buf4_axpy(&Z1, &ZIjAb, 1);
184
 
  dpd_buf4_close(&Z1);
185
 
 
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);
191
 
  dpd_buf4_close(&I);
192
 
  dpd_buf4_close(&Z1);
193
 
 
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);
197
 
  dpd_buf4_close(&T2);
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");
201
 
  dpd_buf4_close(&Z1);
202
 
  dpd_buf4_init(&Z1, CC_TMP0, 0, 0, 5, 0, 5, 0, "Z(jI,bA) temp");
203
 
  dpd_buf4_axpy(&Z1, &ZIjAb, 1);
204
 
  dpd_buf4_close(&Z1);
205
 
 
206
 
  /* Close the X and Y matices */
207
 
  dpd_file2_close(&Y1);
208
 
  dpd_file2_close(&X1);
209
 
 
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);
213
 
  dpd_buf4_close(&L2);
214
 
  dpd_buf4_close(&ZIjAb);
215
 
 
216
 
  return polar;
 
32
  double polar, polar_I, polar_II;
 
33
  char lbl[32];
 
34
  int Gbm, Gfe, bm, b, m, Gb, Gm, Ge, Gf, B, M, fe, f, e, ef, nrows, ncols;
 
35
  double *X;
 
36
 
 
37
  build_XY(pert_x, cart_x, irrep_x, omega_x, pert_y, cart_y, irrep_y, omega_y);
 
38
 
 
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);
 
43
  dpd_buf4_close(&Z1);
 
44
  dpd_buf4_close(&L2);
 
45
 
 
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);
 
50
  dpd_buf4_close(&Z1);
 
51
  dpd_buf4_close(&L2);
 
52
 
 
53
  return polar_I+polar_II;
 
54
}
 
55
 
 
56
/* build_XY(): Compute products of X1 and Y1 for the
 
57
** <0|L*(HBAR*X1*Y1)|0> part of the response function.
 
58
** 
 
59
** For the Type-I residuals:
 
60
** X*Y(ij,ab) = X(i,a) * Y(j,b)
 
61
**
 
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)]
 
64
** 
 
65
** TDC, 9/10/05
 
66
**/
 
67
 
 
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)
 
70
{
 
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;
 
73
  int nirreps;
 
74
  dpdbuf4 Z, Z1;
 
75
  dpdfile2 X1, Y1;
 
76
  char lbl[32];
 
77
 
 
78
  nirreps = moinfo.nirreps;
 
79
 
 
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);
 
84
 
 
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);
 
89
 
 
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]);
 
110
      }
 
111
    }
 
112
    dpd_buf4_mat_irrep_wrt(&Z, h);
 
113
    dpd_buf4_mat_irrep_close(&Z, h);
 
114
  }
 
115
  dpd_buf4_close(&Z);
 
116
 
 
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];
 
135
 
 
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]);
 
140
      }       
 
141
    }
 
142
    dpd_buf4_mat_irrep_wrt(&Z, h);
 
143
    dpd_buf4_mat_irrep_close(&Z, h);
 
144
  }
 
145
  dpd_buf4_close(&Z);
 
146
 
 
147
  dpd_file2_mat_close(&X1);
 
148
  dpd_file2_close(&X1);
 
149
  dpd_file2_mat_close(&Y1);
 
150
  dpd_file2_close(&Y1);
 
151
 
217
152
}