2
#include <libipv1/ip_lib.h>
3
#include <libciomr/libciomr.h>
4
#include <libpsio/psio.h>
5
#include <libchkpt/chkpt.h>
10
** get_moinfo(): Routine to obtain basic orbital information from
13
** T. Daniel Crawford, October 1996.
14
** Modified by TDC, March 1999.
19
int i, h, errcod, nactive, nirreps;
21
chkpt_init(PSIO_OPEN_OLD);
22
moinfo.nirreps = chkpt_rd_nirreps();
23
moinfo.nmo = chkpt_rd_nmo();
24
moinfo.iopen = chkpt_rd_iopen();
25
moinfo.labels = chkpt_rd_irr_labs();
26
moinfo.orbspi = chkpt_rd_orbspi();
27
moinfo.clsdpi = chkpt_rd_clsdpi();
28
moinfo.openpi = chkpt_rd_openpi();
29
moinfo.phase = chkpt_rd_phase_check();
32
nirreps = moinfo.nirreps;
34
psio_read_entry(CC_INFO, "Reference Wavefunction", (char *) &(params.ref),
37
/* Get frozen and active orbital lookups from CC_INFO */
38
moinfo.frdocc = init_int_array(moinfo.nirreps);
39
moinfo.fruocc = init_int_array(moinfo.nirreps);
40
psio_read_entry(CC_INFO, "Frozen Core Orbs Per Irrep",
41
(char *) moinfo.frdocc, sizeof(int)*moinfo.nirreps);
42
psio_read_entry(CC_INFO, "Frozen Virt Orbs Per Irrep",
43
(char *) moinfo.fruocc, sizeof(int)*moinfo.nirreps);
45
psio_read_entry(CC_INFO, "No. of Active Orbitals", (char *) &(nactive),
48
if(params.ref == 0 || params.ref == 1) { /** RHF or ROHF **/
50
moinfo.occpi = init_int_array(moinfo.nirreps);
51
moinfo.virtpi = init_int_array(moinfo.nirreps);
52
psio_read_entry(CC_INFO, "Active Occ Orbs Per Irrep",
53
(char *) moinfo.occpi, sizeof(int)*moinfo.nirreps);
54
psio_read_entry(CC_INFO, "Active Virt Orbs Per Irrep",
55
(char *) moinfo.virtpi, sizeof(int)*moinfo.nirreps);
57
moinfo.occ_sym = init_int_array(nactive);
58
moinfo.vir_sym = init_int_array(nactive);
59
psio_read_entry(CC_INFO, "Active Occ Orb Symmetry",
60
(char *) moinfo.occ_sym, sizeof(int)*nactive);
61
psio_read_entry(CC_INFO, "Active Virt Orb Symmetry",
62
(char *) moinfo.vir_sym, sizeof(int)*nactive);
64
moinfo.occ_off = init_int_array(moinfo.nirreps);
65
moinfo.vir_off = init_int_array(moinfo.nirreps);
66
psio_read_entry(CC_INFO, "Active Occ Orb Offsets",
67
(char *) moinfo.occ_off, sizeof(int)*moinfo.nirreps);
68
psio_read_entry(CC_INFO, "Active Virt Orb Offsets",
69
(char *) moinfo.vir_off, sizeof(int)*moinfo.nirreps);
71
else if(params.ref == 2) { /** UHF **/
73
moinfo.aoccpi = init_int_array(nirreps);
74
moinfo.boccpi = init_int_array(nirreps);
75
moinfo.avirtpi = init_int_array(nirreps);
76
moinfo.bvirtpi = init_int_array(nirreps);
78
psio_read_entry(CC_INFO, "Active Alpha Occ Orbs Per Irrep",
79
(char *) moinfo.aoccpi, sizeof(int)*moinfo.nirreps);
80
psio_read_entry(CC_INFO, "Active Beta Occ Orbs Per Irrep",
81
(char *) moinfo.boccpi, sizeof(int)*moinfo.nirreps);
82
psio_read_entry(CC_INFO, "Active Alpha Virt Orbs Per Irrep",
83
(char *) moinfo.avirtpi, sizeof(int)*moinfo.nirreps);
84
psio_read_entry(CC_INFO, "Active Beta Virt Orbs Per Irrep",
85
(char *) moinfo.bvirtpi, sizeof(int)*moinfo.nirreps);
87
moinfo.aocc_sym = init_int_array(nactive);
88
moinfo.bocc_sym = init_int_array(nactive);
89
moinfo.avir_sym = init_int_array(nactive);
90
moinfo.bvir_sym = init_int_array(nactive);
92
psio_read_entry(CC_INFO, "Active Alpha Occ Orb Symmetry",
93
(char *) moinfo.aocc_sym, sizeof(int)*nactive);
94
psio_read_entry(CC_INFO, "Active Beta Occ Orb Symmetry",
95
(char *) moinfo.bocc_sym, sizeof(int)*nactive);
96
psio_read_entry(CC_INFO, "Active Alpha Virt Orb Symmetry",
97
(char *) moinfo.avir_sym, sizeof(int)*nactive);
98
psio_read_entry(CC_INFO, "Active Beta Virt Orb Symmetry",
99
(char *) moinfo.bvir_sym, sizeof(int)*nactive);
101
moinfo.aocc_off = init_int_array(moinfo.nirreps);
102
moinfo.bocc_off = init_int_array(moinfo.nirreps);
103
moinfo.avir_off = init_int_array(moinfo.nirreps);
104
moinfo.bvir_off = init_int_array(moinfo.nirreps);
106
psio_read_entry(CC_INFO, "Active Alpha Occ Orb Offsets",
107
(char *) moinfo.aocc_off, sizeof(int)*moinfo.nirreps);
108
psio_read_entry(CC_INFO, "Active Beta Occ Orb Offsets",
109
(char *) moinfo.bocc_off, sizeof(int)*moinfo.nirreps);
111
psio_read_entry(CC_INFO, "Active Alpha Virt Orb Offsets",
112
(char *) moinfo.avir_off, sizeof(int)*moinfo.nirreps);
113
psio_read_entry(CC_INFO, "Active Beta Virt Orb Offsets",
114
(char *) moinfo.bvir_off, sizeof(int)*moinfo.nirreps);
118
/* Adjust clsdpi array for frozen orbitals */
119
for(i=0; i < moinfo.nirreps; i++)
120
moinfo.clsdpi[i] -= moinfo.frdocc[i];
122
moinfo.uoccpi = init_int_array(moinfo.nirreps);
123
for(i=0; i < moinfo.nirreps; i++)
124
moinfo.uoccpi[i] = moinfo.orbspi[i] - moinfo.clsdpi[i] -
125
moinfo.openpi[i] - moinfo.fruocc[i] -
129
/* Frees memory allocated in get_moinfo() and dumps some info. */
140
for(i=0; i < moinfo.nirreps; i++)
141
free(moinfo.labels[i]);
143
if(params.ref == 2) {
146
free(moinfo.avirtpi);
147
free(moinfo.bvirtpi);
148
free(moinfo.aocc_sym);
149
free(moinfo.bocc_sym);
150
free(moinfo.avir_sym);
151
free(moinfo.bvir_sym);
154
free(moinfo.occ_sym);
155
free(moinfo.vir_sym);
156
free(moinfo.occ_off);
157
free(moinfo.vir_off);