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

« back to all changes in this revision

Viewing changes to src/bin/cceom/get_moinfo.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 <stdlib.h>
3
 
#include <libipv1/ip_lib.h>
4
 
#include <libciomr/libciomr.h>
5
 
#include <libchkpt/chkpt.h>
6
 
#include <libpsio/psio.h>
7
 
#define EXTERN
8
 
#include "globals.h"
9
 
 
10
 
/*
11
 
** get_moinfo():  Routine to obtain basic orbital information from
12
 
** CHKPT and CC_INFO.
13
 
**
14
 
** T. Daniel Crawford, October 1996
15
 
** Modified by TDC, March 1999
16
 
*/
17
 
 
18
 
void get_moinfo(void)
19
 
{
20
 
  int i, j, h, p, q, errcod, nactive, nirreps, sym;
21
 
  double ***C, ***Ca, ***Cb;
22
 
  psio_address next;
23
 
 
24
 
  chkpt_init(PSIO_OPEN_OLD);
25
 
  moinfo.nirreps = chkpt_rd_nirreps();
26
 
  moinfo.nmo = chkpt_rd_nmo();
27
 
  moinfo.nso = chkpt_rd_nso();
28
 
  moinfo.iopen = chkpt_rd_iopen();
29
 
  moinfo.labels = chkpt_rd_irr_labs();
30
 
  moinfo.enuc = chkpt_rd_enuc();
31
 
  moinfo.escf = chkpt_rd_escf();
32
 
  moinfo.orbspi = chkpt_rd_orbspi();
33
 
  moinfo.clsdpi = chkpt_rd_clsdpi();
34
 
  moinfo.openpi = chkpt_rd_openpi();
35
 
  moinfo.phase = chkpt_rd_phase_check();
36
 
  chkpt_close();
37
 
 
38
 
  sym = 0;
39
 
  for (i=0;i<moinfo.nirreps;++i)
40
 
    for (j=0;j<moinfo.openpi[i];++j)
41
 
      sym = sym ^ i;
42
 
  moinfo.sym = sym;
43
 
 
44
 
  nirreps = moinfo.nirreps;
45
 
 
46
 
  psio_read_entry(CC_INFO, "Reference Wavefunction", (char *) &(params.ref), 
47
 
                  sizeof(int));
48
 
 
49
 
  /* Get frozen and active orbital lookups from CC_INFO */
50
 
  moinfo.frdocc = init_int_array(nirreps);
51
 
  moinfo.fruocc = init_int_array(nirreps);
52
 
  psio_read_entry(CC_INFO, "Frozen Core Orbs Per Irrep",
53
 
                  (char *) moinfo.frdocc, sizeof(int)*nirreps);
54
 
  psio_read_entry(CC_INFO, "Frozen Virt Orbs Per Irrep",
55
 
                  (char *) moinfo.fruocc, sizeof(int)*nirreps);
56
 
  
57
 
  psio_read_entry(CC_INFO, "No. of Active Orbitals", (char *) &(nactive),
58
 
                  sizeof(int)); 
59
 
 
60
 
  if (params.ref == 0 || params.ref == 1) { /** RHF or ROHF **/
61
 
 
62
 
    moinfo.occpi = init_int_array(nirreps);
63
 
    moinfo.virtpi = init_int_array(nirreps);
64
 
    psio_read_entry(CC_INFO, "Active Occ Orbs Per Irrep",
65
 
                    (char *) moinfo.occpi, sizeof(int)*nirreps);
66
 
    psio_read_entry(CC_INFO, "Active Virt Orbs Per Irrep",
67
 
                    (char *) moinfo.virtpi, sizeof(int)*nirreps);
68
 
 
69
 
    moinfo.occ_sym = init_int_array(nactive);
70
 
    moinfo.vir_sym = init_int_array(nactive);
71
 
    psio_read_entry(CC_INFO, "Active Occ Orb Symmetry",
72
 
                    (char *) moinfo.occ_sym, sizeof(int)*nactive);
73
 
    psio_read_entry(CC_INFO, "Active Virt Orb Symmetry",
74
 
                    (char *) moinfo.vir_sym, sizeof(int)*nactive);
75
 
 
76
 
    moinfo.occ_off = init_int_array(moinfo.nirreps);
77
 
    moinfo.vir_off = init_int_array(moinfo.nirreps);
78
 
    psio_read_entry(CC_INFO, "Active Occ Orb Offsets",
79
 
                    (char *) moinfo.occ_off, sizeof(int)*moinfo.nirreps);
80
 
    psio_read_entry(CC_INFO, "Active Virt Orb Offsets",
81
 
                    (char *) moinfo.vir_off, sizeof(int)*moinfo.nirreps);
82
 
  }
83
 
 
84
 
  else { /** UHF **/
85
 
 
86
 
    moinfo.aoccpi = init_int_array(nirreps);
87
 
    moinfo.boccpi = init_int_array(nirreps);
88
 
    moinfo.avirtpi = init_int_array(nirreps);
89
 
    moinfo.bvirtpi = init_int_array(nirreps);
90
 
 
91
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orbs Per Irrep",
92
 
                    (char *) moinfo.aoccpi, sizeof(int)*moinfo.nirreps);
93
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orbs Per Irrep",
94
 
                    (char *) moinfo.boccpi, sizeof(int)*moinfo.nirreps);
95
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orbs Per Irrep",
96
 
                    (char *) moinfo.avirtpi, sizeof(int)*moinfo.nirreps);
97
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orbs Per Irrep",
98
 
                    (char *) moinfo.bvirtpi, sizeof(int)*moinfo.nirreps);
99
 
 
100
 
    moinfo.aocc_sym = init_int_array(nactive);
101
 
    moinfo.bocc_sym = init_int_array(nactive);
102
 
    moinfo.avir_sym = init_int_array(nactive);
103
 
    moinfo.bvir_sym = init_int_array(nactive);
104
 
 
105
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Symmetry",
106
 
                    (char *) moinfo.aocc_sym, sizeof(int)*nactive);
107
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Symmetry",
108
 
                    (char *) moinfo.bocc_sym, sizeof(int)*nactive);
109
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Symmetry",
110
 
                    (char *) moinfo.avir_sym, sizeof(int)*nactive);
111
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Symmetry",
112
 
                    (char *) moinfo.bvir_sym, sizeof(int)*nactive);
113
 
 
114
 
    moinfo.aocc_off = init_int_array(moinfo.nirreps);
115
 
    moinfo.bocc_off = init_int_array(moinfo.nirreps);
116
 
    moinfo.avir_off = init_int_array(moinfo.nirreps);
117
 
    moinfo.bvir_off = init_int_array(moinfo.nirreps);
118
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Offsets",
119
 
                    (char *) moinfo.aocc_off, sizeof(int)*moinfo.nirreps);
120
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Offsets",
121
 
                    (char *) moinfo.bocc_off, sizeof(int)*moinfo.nirreps);
122
 
 
123
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Offsets",
124
 
                    (char *) moinfo.avir_off, sizeof(int)*moinfo.nirreps);
125
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Offsets",
126
 
                    (char *) moinfo.bvir_off, sizeof(int)*moinfo.nirreps);
127
 
  }
128
 
 
129
 
  /* Build orbsym array (for AO-basis BT2) */
130
 
  moinfo.orbsym = init_int_array(moinfo.nso);
131
 
  for(h=0,q=0; h < nirreps; h++)
132
 
    for(p=0; p < moinfo.orbspi[h]; p++)
133
 
      moinfo.orbsym[q++] = h;
134
 
 
135
 
  /* Get the active virtual orbitals */
136
 
  if(params.ref == 0 || params.ref == 1) { /** RHF/ROHF **/
137
 
 
138
 
    C = (double ***) malloc(nirreps * sizeof(double **));
139
 
    next = PSIO_ZERO;
140
 
    for(h=0; h < nirreps; h++) {
141
 
      if(moinfo.orbspi[h] && moinfo.virtpi[h]) {
142
 
        C[h] = block_matrix(moinfo.orbspi[h],moinfo.virtpi[h]);
143
 
        psio_read(CC_INFO, "RHF/ROHF Active Virtual Orbitals", (char *) C[h][0],
144
 
                  moinfo.orbspi[h]*moinfo.virtpi[h]*sizeof(double), next, &next);
145
 
      }
146
 
    }
147
 
    moinfo.C = C;
148
 
  }
149
 
  else if(params.ref == 2) { /** UHF **/
150
 
 
151
 
    Ca = (double ***) malloc(nirreps * sizeof(double **));
152
 
    next = PSIO_ZERO;
153
 
    for(h=0; h < nirreps; h++) {
154
 
      if(moinfo.orbspi[h] && moinfo.avirtpi[h]) {
155
 
        Ca[h] = block_matrix(moinfo.orbspi[h],moinfo.avirtpi[h]);
156
 
        psio_read(CC_INFO, "UHF Active Alpha Virtual Orbs", (char *) Ca[h][0],
157
 
                  moinfo.orbspi[h]*moinfo.avirtpi[h]*sizeof(double), next, &next);
158
 
      }
159
 
    }
160
 
    moinfo.Ca = Ca;
161
 
 
162
 
 
163
 
    Cb = (double ***) malloc(nirreps * sizeof(double **));
164
 
    next = PSIO_ZERO;
165
 
    for(h=0; h < nirreps; h++) {
166
 
      if(moinfo.orbspi[h] && moinfo.bvirtpi[h]) {
167
 
        Cb[h] = block_matrix(moinfo.orbspi[h],moinfo.bvirtpi[h]);
168
 
        psio_read(CC_INFO, "UHF Active Beta Virtual Orbs", (char *) Cb[h][0],
169
 
                  moinfo.orbspi[h]*moinfo.bvirtpi[h]*sizeof(double), next, &next);
170
 
      }
171
 
    }
172
 
    moinfo.Cb = Cb;
173
 
  }
174
 
 
175
 
  /* Adjust clsdpi array for frozen orbitals */
176
 
  for(i=0; i < nirreps; i++)
177
 
    moinfo.clsdpi[i] -= moinfo.frdocc[i];
178
 
 
179
 
  moinfo.uoccpi = init_int_array(moinfo.nirreps);
180
 
  for(i=0; i < nirreps; i++)
181
 
    moinfo.uoccpi[i] = moinfo.orbspi[i] - moinfo.clsdpi[i] -
182
 
      moinfo.openpi[i] - moinfo.fruocc[i] -
183
 
      moinfo.frdocc[i];
184
 
 
185
 
  if(params.ref == 0) {
186
 
    moinfo.nvirt = 0;
187
 
    for(h=0; h < moinfo.nirreps; h++) moinfo.nvirt += moinfo.virtpi[h];
188
 
  }
189
 
 
190
 
  psio_read_entry(CC_INFO, "Reference Energy", (char *) &(moinfo.eref), 
191
 
                  sizeof(double));
192
 
 
193
 
  fprintf(outfile,"\n\tNuclear Rep. energy (chkpt)   = %20.15f\n",moinfo.enuc);
194
 
  fprintf(outfile,  "\tSCF energy          (chkpt)   = %20.15f\n",moinfo.escf);
195
 
  fprintf(outfile,  "\tReference energy    (file100) = %20.15f\n",moinfo.eref);
196
 
 
197
 
  fflush(outfile);
198
 
}
199
 
 
200
 
/* Frees memory allocated in get_moinfo() and dumps out the energy. */
201
 
void cleanup(void)
202
 
{
203
 
  int i, h;
204
 
 
205
 
  if(params.ref == 0 || params.ref == 1) {
206
 
    for(h=0; h < moinfo.nirreps; h++)
207
 
      if(moinfo.orbspi[h] && moinfo.virtpi[h]) free_block(moinfo.C[h]);
208
 
    free(moinfo.C);
209
 
  }
210
 
  else if(params.ref == 2) {
211
 
    for(h=0; h < moinfo.nirreps; h++)
212
 
      if(moinfo.orbspi[h] && moinfo.avirtpi[h]) free_block(moinfo.Ca[h]);
213
 
    free(moinfo.Ca);
214
 
    for(h=0; h < moinfo.nirreps; h++)
215
 
      if(moinfo.orbspi[h] && moinfo.bvirtpi[h]) free_block(moinfo.Cb[h]);
216
 
    free(moinfo.Cb);
217
 
  }
218
 
 
219
 
  free(moinfo.orbspi);
220
 
  free(moinfo.orbsym);
221
 
  free(moinfo.clsdpi);
222
 
  free(moinfo.openpi);
223
 
  free(moinfo.uoccpi);
224
 
  free(moinfo.fruocc);
225
 
  free(moinfo.frdocc);
226
 
  for(i=0; i < moinfo.nirreps; i++)
227
 
    free(moinfo.labels[i]);
228
 
  free(moinfo.labels);
229
 
  if(params.ref == 2) {
230
 
    free(moinfo.aoccpi);
231
 
    free(moinfo.boccpi);
232
 
    free(moinfo.avirtpi);
233
 
    free(moinfo.bvirtpi);
234
 
    free(moinfo.aocc_sym);
235
 
    free(moinfo.bocc_sym);
236
 
    free(moinfo.avir_sym);
237
 
    free(moinfo.bvir_sym);
238
 
  }
239
 
  else {
240
 
    free(moinfo.occpi);
241
 
    free(moinfo.virtpi);
242
 
    free(moinfo.occ_sym);
243
 
    free(moinfo.vir_sym);
244
 
  }
245
 
 
246
 
}
247