3
#include <libipv1/ip_lib.h>
4
#include <libciomr/libciomr.h>
5
#include <libpsio/psio.h>
6
#include <libchkpt/chkpt.h>
11
** get_moinfo(): Routine to obtain basic orbital information from
14
** T. Daniel Crawford, October 1996.
15
** Modified by TDC, March 1999.
16
** Modified for UHF references by TDC, June 2002.
21
int i,j, h, p, q, errcod, nactive, nirreps, sym;
22
double ***C, ***Ca, ***Cb;
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();
40
for (i=0;i<moinfo.nirreps;++i)
41
for (j=0;j<moinfo.openpi[i];++j)
45
psio_read_entry(CC_INFO, "Reference Wavefunction", (char *) &(params.ref),
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);
56
psio_read_entry(CC_INFO, "No. of Active Orbitals", (char *) &(nactive),
59
if(params.ref == 0 || params.ref == 1) { /** RHF or ROHF **/
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);
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);
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);
82
else if(params.ref == 2) { /** UHF **/
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);
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);
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);
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);
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);
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;
132
if(params.ref == 0 || params.ref == 1) { /** RHF/ROHF **/
134
C = (double ***) malloc(moinfo.nirreps * sizeof(double **));
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);
145
else if(params.ref == 2) { /** UHF **/
147
Ca = (double ***) malloc(moinfo.nirreps * sizeof(double **));
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);
159
Cb = (double ***) malloc(moinfo.nirreps * sizeof(double **));
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);
171
/* Adjust clsdpi array for frozen orbitals */
172
for(i=0; i < moinfo.nirreps; i++)
173
moinfo.clsdpi[i] -= moinfo.frdocc[i];
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] -
181
psio_read_entry(CC_INFO, "Reference Energy", (char *) &(moinfo.eref),
183
psio_read_entry(CC_INFO, "CCSD Energy", (char *) &(moinfo.ecc),
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);
195
/* Frees memory allocated in get_moinfo() and dumps some info. */
200
psio_write_entry(CC_INFO, "Lambda Pseudoenergy", (char *) &(moinfo.lcc),
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]);
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]);
212
for(h=0; h < moinfo.nirreps; h++)
213
if(moinfo.orbspi[h] && moinfo.bvirtpi[h]) free_block(moinfo.Cb[h]);
224
for(i=0; i < moinfo.nirreps; i++)
225
free(moinfo.labels[i]);
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);
238
free(moinfo.avirtpi);
239
free(moinfo.bvirtpi);
242
free(moinfo.occ_sym);
243
free(moinfo.vir_sym);
244
free(moinfo.occ_off);
245
free(moinfo.vir_off);