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

« back to all changes in this revision

Viewing changes to src/bin/ccdensity/sort_ltd_rohf.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
 
void sort_ltd_rohf(struct TD_Params S) 
7
 
{
8
 
  int h, nirreps, nmo, nfzv, nfzc, nclsd, nopen;
9
 
  int row, col, i, j, I, J, a, b, A, B, p, q;
10
 
  int *occpi, *virtpi, *occ_off, *vir_off; 
11
 
  int *occ_sym, *vir_sym, *openpi;
12
 
  int *qt_occ, *qt_vir;
13
 
  double chksum, value;
14
 
  psio_address next;
15
 
  dpdfile2 D;
16
 
 
17
 
  nmo = moinfo.nmo;
18
 
  nfzc = moinfo.nfzc;
19
 
  nfzv = moinfo.nfzv;
20
 
  nclsd = moinfo.nclsd;
21
 
  nopen = moinfo.nopen;
22
 
  nirreps = moinfo.nirreps;
23
 
  occpi = moinfo.occpi; virtpi = moinfo.virtpi;
24
 
  occ_off = moinfo.occ_off; vir_off = moinfo.vir_off;
25
 
  occ_sym = moinfo.occ_sym; vir_sym = moinfo.vir_sym;
26
 
  openpi = moinfo.openpi;
27
 
  qt_occ = moinfo.qt_occ; qt_vir = moinfo.qt_vir;
28
 
 
29
 
  moinfo.ltd = block_matrix(nmo, nmo);
30
 
 
31
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 0, "LTDIJ");
32
 
  dpd_file2_mat_init(&D);
33
 
  dpd_file2_mat_rd(&D);
34
 
  for(h=0; h < nirreps; h++) {
35
 
    for(i=0; i < occpi[h]; i++) {
36
 
      I = qt_occ[occ_off[h] + i];
37
 
      for(j=0; j < occpi[h^S.irrep]; j++) {
38
 
        J = qt_occ[occ_off[h^S.irrep] + j];
39
 
        moinfo.ltd[I][J] += D.matrix[h][i][j];
40
 
      }
41
 
    }
42
 
  }
43
 
  dpd_file2_mat_close(&D);
44
 
  dpd_file2_close(&D);
45
 
 
46
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 1, 1, "LTDAB");
47
 
  dpd_file2_mat_init(&D);
48
 
  dpd_file2_mat_rd(&D);
49
 
  for(h=0; h < nirreps; h++) {
50
 
    for(a=0; a < (virtpi[h] - openpi[h]); a++) {
51
 
      A = qt_vir[vir_off[h] + a];
52
 
      for(b=0; b < (virtpi[h^S.irrep] - openpi[h^S.irrep]); b++) {
53
 
        B = qt_vir[vir_off[h^S.irrep] + b];
54
 
        moinfo.ltd[A][B] += D.matrix[h][a][b];
55
 
      }
56
 
    }
57
 
  }
58
 
  dpd_file2_mat_close(&D);
59
 
  dpd_file2_close(&D);
60
 
 
61
 
  /* Note that this component of the density is stored occ-vir */
62
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 1, "LTDAI");
63
 
  dpd_file2_mat_init(&D);
64
 
  dpd_file2_mat_rd(&D);
65
 
  for(h=0; h < nirreps; h++) {
66
 
    for(i=0; i < occpi[h]; i++) {
67
 
      I = qt_occ[occ_off[h] + i];
68
 
      for(a=0; a < (virtpi[h^S.irrep] - openpi[h^S.irrep]); a++) {
69
 
        A = qt_vir[vir_off[h^S.irrep] + a];
70
 
        moinfo.ltd[A][I] += D.matrix[h][i][a];
71
 
      }
72
 
    }
73
 
  }
74
 
  dpd_file2_mat_close(&D);
75
 
  dpd_file2_close(&D);
76
 
 
77
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 1, "LTDIA");
78
 
  dpd_file2_mat_init(&D);
79
 
  dpd_file2_mat_rd(&D);
80
 
  for(h=0; h < nirreps; h++) {
81
 
    for(i=0; i < occpi[h]; i++) {
82
 
      I = qt_occ[occ_off[h] + i];
83
 
      for(a=0; a < (virtpi[h^S.irrep] - openpi[h^S.irrep]); a++) {
84
 
        A = qt_vir[vir_off[h^S.irrep] + a];
85
 
        moinfo.ltd[I][A] += D.matrix[h][i][a];
86
 
      }
87
 
    }
88
 
  }
89
 
  dpd_file2_mat_close(&D);
90
 
  dpd_file2_close(&D);
91
 
 
92
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 0, "LTDij");
93
 
  dpd_file2_mat_init(&D); 
94
 
  dpd_file2_mat_rd(&D);
95
 
  for(h=0; h < nirreps; h++) {
96
 
    for(i=0; i < (occpi[h] - openpi[h]); i++) { 
97
 
      I = qt_occ[occ_off[h] + i];
98
 
      for(j=0; j < (occpi[h^S.irrep] - openpi[h^S.irrep]); j++) {
99
 
        J = qt_occ[occ_off[h^S.irrep] + j];
100
 
        moinfo.ltd[I][J] += D.matrix[h][i][j];
101
 
      }
102
 
    }
103
 
  }
104
 
  dpd_file2_mat_close(&D);
105
 
  dpd_file2_close(&D);
106
 
 
107
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 1, 1, "LTDab");
108
 
  dpd_file2_mat_init(&D);
109
 
  dpd_file2_mat_rd(&D);
110
 
  for(h=0; h < nirreps; h++) {
111
 
    for(a=0; a < virtpi[h]; a++) {
112
 
      A = qt_vir[vir_off[h] + a];
113
 
      for(b=0; b < virtpi[h^S.irrep]; b++) {
114
 
        B = qt_vir[vir_off[h^S.irrep] + b];
115
 
        moinfo.ltd[A][B] += D.matrix[h][a][b];
116
 
      }
117
 
    }
118
 
  }
119
 
  dpd_file2_mat_close(&D);
120
 
  dpd_file2_close(&D);
121
 
 
122
 
  /* Note that this component of the density is stored occ-vir */
123
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 1, "LTDai");
124
 
  dpd_file2_mat_init(&D);
125
 
  dpd_file2_mat_rd(&D);
126
 
  for(h=0; h < nirreps; h++) {
127
 
    for(i=0; i < (occpi[h] - openpi[h]); i++) {
128
 
      I = qt_occ[occ_off[h] + i];
129
 
      for(a=0; a < virtpi[h^S.irrep]; a++) {
130
 
        A = qt_vir[vir_off[h^S.irrep] + a];
131
 
        moinfo.ltd[A][I] += D.matrix[h][i][a];
132
 
      }
133
 
    }
134
 
  }
135
 
  dpd_file2_mat_close(&D);
136
 
  dpd_file2_close(&D);
137
 
 
138
 
  dpd_file2_init(&D, CC_TMP, S.irrep, 0, 1, "LTDia");
139
 
  dpd_file2_mat_init(&D);
140
 
  dpd_file2_mat_rd(&D);
141
 
  for(h=0; h < nirreps; h++) {
142
 
    for(i=0; i < (occpi[h] - openpi[h]); i++) {
143
 
      I = qt_occ[occ_off[h] + i];
144
 
      for(a=0; a < virtpi[h^S.irrep]; a++) {
145
 
        A = qt_vir[vir_off[h^S.irrep] + a];
146
 
        moinfo.ltd[I][A] += D.matrix[h][i][a];
147
 
      }
148
 
    }
149
 
  }
150
 
  dpd_file2_mat_close(&D);
151
 
  dpd_file2_close(&D);
152
 
 
153
 
  /*mat_print(moinfo.ltd,nmo,nmo,outfile);*/
154
 
 
155
 
  return;
156
 
}