~ubuntu-branches/ubuntu/precise/psicode/precise

« back to all changes in this revision

Viewing changes to src/bin/cclambda/get_moinfo.c

  • Committer: Bazaar Package Importer
  • Author(s): Michael Banck
  • Date: 2006-09-10 14:01:33 UTC
  • Revision ID: james.westby@ubuntu.com-20060910140133-ib2j86trekykfsfv
Tags: upstream-3.2.3
ImportĀ upstreamĀ versionĀ 3.2.3

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