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

« back to all changes in this revision

Viewing changes to src/bin/cis/get_moinfo.cc

  • 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
/*! \file
 
2
    \ingroup CIS
 
3
    \brief Enter brief description of file here 
 
4
*/
 
5
#include <cstdio>
 
6
#include <cstdlib>
 
7
#include <libipv1/ip_lib.h>
 
8
#include <libciomr/libciomr.h>
 
9
#include <libchkpt/chkpt.h>
 
10
#include <libpsio/psio.h>
 
11
#include "MOInfo.h"
 
12
#include "Params.h"
 
13
#include "Local.h"
 
14
#define EXTERN
 
15
#include "globals.h"
 
16
 
 
17
namespace psi { namespace cis {
 
18
 
 
19
/*
 
20
** get_moinfo():  Routine to obtain basic orbital information from
 
21
** CHKPT and CC_INFO.
 
22
**
 
23
** T. Daniel Crawford, October 1996
 
24
** Modified by TDC, March 1999
 
25
*/
 
26
 
 
27
void get_moinfo(void)
 
28
{
 
29
  int i, h, p, q, errcod, nactive, nirreps;
 
30
  psio_address next;
 
31
 
 
32
  chkpt_init(PSIO_OPEN_OLD);
 
33
  moinfo.nirreps = chkpt_rd_nirreps();
 
34
  moinfo.nmo = chkpt_rd_nmo();
 
35
  moinfo.nso = chkpt_rd_nso();
 
36
  moinfo.labels = chkpt_rd_irr_labs();
 
37
  moinfo.enuc = chkpt_rd_enuc();
 
38
  moinfo.escf = chkpt_rd_escf();
 
39
  moinfo.orbspi = chkpt_rd_orbspi();
 
40
  moinfo.clsdpi = chkpt_rd_clsdpi();
 
41
  moinfo.openpi = chkpt_rd_openpi();
 
42
  chkpt_close();
 
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 == 2) { /** UHF **/
 
61
 
 
62
    moinfo.aoccpi = init_int_array(nirreps);
 
63
    moinfo.boccpi = init_int_array(nirreps);
 
64
    moinfo.avirtpi = init_int_array(nirreps);
 
65
    moinfo.bvirtpi = init_int_array(nirreps);
 
66
 
 
67
    psio_read_entry(CC_INFO, "Active Alpha Occ Orbs Per Irrep",
 
68
                    (char *) moinfo.aoccpi, sizeof(int)*moinfo.nirreps);
 
69
    psio_read_entry(CC_INFO, "Active Beta Occ Orbs Per Irrep",
 
70
                    (char *) moinfo.boccpi, sizeof(int)*moinfo.nirreps);
 
71
    psio_read_entry(CC_INFO, "Active Alpha Virt Orbs Per Irrep",
 
72
                    (char *) moinfo.avirtpi, sizeof(int)*moinfo.nirreps);
 
73
    psio_read_entry(CC_INFO, "Active Beta Virt Orbs Per Irrep",
 
74
                    (char *) moinfo.bvirtpi, sizeof(int)*moinfo.nirreps);
 
75
 
 
76
    moinfo.aocc_sym = init_int_array(nactive);
 
77
    moinfo.bocc_sym = init_int_array(nactive);
 
78
    moinfo.avir_sym = init_int_array(nactive);
 
79
    moinfo.bvir_sym = init_int_array(nactive);
 
80
 
 
81
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Symmetry",
 
82
                    (char *) moinfo.aocc_sym, sizeof(int)*nactive);
 
83
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Symmetry",
 
84
                    (char *) moinfo.bocc_sym, sizeof(int)*nactive);
 
85
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Symmetry",
 
86
                    (char *) moinfo.avir_sym, sizeof(int)*nactive);
 
87
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Symmetry",
 
88
                    (char *) moinfo.bvir_sym, sizeof(int)*nactive);
 
89
 
 
90
    moinfo.aocc_off = init_int_array(moinfo.nirreps);
 
91
    moinfo.bocc_off = init_int_array(moinfo.nirreps);
 
92
    moinfo.avir_off = init_int_array(moinfo.nirreps);
 
93
    moinfo.bvir_off = init_int_array(moinfo.nirreps);
 
94
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Offsets",
 
95
                    (char *) moinfo.aocc_off, sizeof(int)*moinfo.nirreps);
 
96
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Offsets",
 
97
                    (char *) moinfo.bocc_off, sizeof(int)*moinfo.nirreps);
 
98
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Offsets",
 
99
                    (char *) moinfo.avir_off, sizeof(int)*moinfo.nirreps);
 
100
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Offsets",
 
101
                    (char *) moinfo.bvir_off, sizeof(int)*moinfo.nirreps);
 
102
 
 
103
  }
 
104
  else { /** RHF or ROHF **/
 
105
 
 
106
    moinfo.occpi = init_int_array(nirreps);
 
107
    moinfo.virtpi = init_int_array(nirreps);
 
108
    psio_read_entry(CC_INFO, "Active Occ Orbs Per Irrep",
 
109
                    (char *) moinfo.occpi, sizeof(int)*nirreps);
 
110
    psio_read_entry(CC_INFO, "Active Virt Orbs Per Irrep",
 
111
                    (char *) moinfo.virtpi, sizeof(int)*nirreps);
 
112
 
 
113
    moinfo.occ_sym = init_int_array(nactive);
 
114
    moinfo.vir_sym = init_int_array(nactive);
 
115
    psio_read_entry(CC_INFO, "Active Occ Orb Symmetry",
 
116
                    (char *) moinfo.occ_sym, sizeof(int)*nactive);
 
117
    psio_read_entry(CC_INFO, "Active Virt Orb Symmetry",
 
118
                    (char *) moinfo.vir_sym, sizeof(int)*nactive);
 
119
 
 
120
    moinfo.occ_off = init_int_array(moinfo.nirreps);
 
121
    moinfo.vir_off = init_int_array(moinfo.nirreps);
 
122
    psio_read_entry(CC_INFO, "Active Occ Orb Offsets",
 
123
                    (char *) moinfo.occ_off, sizeof(int)*moinfo.nirreps);
 
124
    psio_read_entry(CC_INFO, "Active Virt Orb Offsets",
 
125
                    (char *) moinfo.vir_off, sizeof(int)*moinfo.nirreps);
 
126
  }
 
127
 
 
128
  /* Adjust clsdpi array for frozen orbitals */
 
129
  for(i=0; i < nirreps; i++)
 
130
    moinfo.clsdpi[i] -= moinfo.frdocc[i];
 
131
 
 
132
  moinfo.uoccpi = init_int_array(moinfo.nirreps);
 
133
  for(i=0; i < nirreps; i++)
 
134
    moinfo.uoccpi[i] = moinfo.orbspi[i] - moinfo.clsdpi[i] -
 
135
      moinfo.openpi[i] - moinfo.fruocc[i] -
 
136
      moinfo.frdocc[i];
 
137
 
 
138
  psio_read_entry(CC_INFO, "Reference Energy", (char *) &(moinfo.eref), 
 
139
                  sizeof(double));
 
140
 
 
141
  fprintf(outfile,"\n\tNuclear Rep. energy (chkpt)   = %20.15f\n",moinfo.enuc);
 
142
  fprintf(outfile,  "\tSCF energy          (chkpt)   = %20.15f\n",moinfo.escf);
 
143
  fprintf(outfile,  "\tReference energy    (file100) = %20.15f\n",moinfo.eref);
 
144
}
 
145
 
 
146
/* Frees memory allocated in get_moinfo() and dumps out the energy. */
 
147
void cleanup(void)
 
148
{
 
149
  int i;
 
150
 
 
151
  free(moinfo.orbspi);
 
152
  free(moinfo.clsdpi);
 
153
  free(moinfo.openpi);
 
154
  free(moinfo.uoccpi);
 
155
  free(moinfo.fruocc);
 
156
  free(moinfo.frdocc);
 
157
  for(i=0; i < moinfo.nirreps; i++)
 
158
    free(moinfo.labels[i]);
 
159
  free(moinfo.labels);
 
160
  if(params.ref == 2) {
 
161
    free(moinfo.aoccpi);
 
162
    free(moinfo.boccpi);
 
163
    free(moinfo.avirtpi);
 
164
    free(moinfo.bvirtpi);
 
165
    free(moinfo.aocc_sym);
 
166
    free(moinfo.bocc_sym);
 
167
    free(moinfo.avir_sym);
 
168
    free(moinfo.bvir_sym);
 
169
    free(moinfo.aocc_off);
 
170
    free(moinfo.bocc_off);
 
171
    free(moinfo.avir_off);
 
172
    free(moinfo.bvir_off);
 
173
  }
 
174
  else {
 
175
    free(moinfo.occpi);
 
176
    free(moinfo.virtpi);
 
177
    free(moinfo.occ_sym);
 
178
    free(moinfo.vir_sym);
 
179
    free(moinfo.occ_off);
 
180
    free(moinfo.vir_off);
 
181
  }
 
182
 
 
183
}
 
184
 
 
185
 
 
186
}} // namespace psi::cis