~ubuntu-branches/ubuntu/vivid/psicode/vivid

« back to all changes in this revision

Viewing changes to src/bin/cctriples/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 <libipv1/ip_lib.h>
3
 
#include <libciomr/libciomr.h>
4
 
#include <libpsio/psio.h>
5
 
#include <libchkpt/chkpt.h>
6
 
#define EXTERN
7
 
#include "globals.h"
8
 
 
9
 
/*
10
 
** get_moinfo():  Routine to obtain basic orbital information from
11
 
** CHKPT and CC_INFO.
12
 
**
13
 
** T. Daniel Crawford, October 1996.
14
 
** Modified by TDC, March 1999.
15
 
*/
16
 
 
17
 
void get_moinfo(void)
18
 
{
19
 
  int i, h, errcod, nactive, nirreps;
20
 
  char *junk;
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.enuc = chkpt_rd_enuc();
27
 
  moinfo.escf = chkpt_rd_escf();
28
 
  moinfo.orbspi = chkpt_rd_orbspi();
29
 
  moinfo.clsdpi = chkpt_rd_clsdpi();
30
 
  moinfo.openpi = chkpt_rd_openpi();
31
 
  moinfo.phase = chkpt_rd_phase_check();
32
 
  chkpt_close();
33
 
 
34
 
  nirreps = moinfo.nirreps;
35
 
 
36
 
  errcod = ip_string("WFN", &(params.wfn), 0);
37
 
  if(strcmp(params.wfn, "CCSD") && strcmp(params.wfn, "CCSD_T") &&
38
 
     strcmp(params.wfn,"BCCD") && strcmp(params.wfn,"BCCD_T")) {
39
 
    fprintf(outfile, "Invalid value of input keyword WFN: %s\n", params.wfn);
40
 
    exit(PSI_RETURN_FAILURE);
41
 
  }
42
 
 
43
 
  params.semicanonical = 0;
44
 
  errcod = ip_string("REFERENCE", &(junk),0);
45
 
  /* if no reference is given, assume rhf */
46
 
  if (errcod != IPE_OK) params.ref = 0;
47
 
  else {
48
 
    if(!strcmp(junk, "RHF")) params.ref = 0;
49
 
    else if(!strcmp(junk,"ROHF") && !strcmp(params.wfn,"CCSD_T")) {
50
 
      params.ref = 2;
51
 
      params.semicanonical = 1;
52
 
    }
53
 
    else if(!strcmp(junk, "ROHF")) params.ref = 1;
54
 
    else if(!strcmp(junk, "UHF")) params.ref = 2;
55
 
    else { 
56
 
      printf("Invalid value of input keyword REFERENCE: %s\n", junk);
57
 
      exit(PSI_RETURN_FAILURE); 
58
 
    }
59
 
    free(junk);
60
 
  }
61
 
  /*psio_read_entry(CC_INFO, "Reference Wavefunction", (char *) &(params.ref), 
62
 
                  sizeof(int));*/
63
 
 
64
 
  /* Get frozen and active orbital lookups from CC_INFO */
65
 
  moinfo.frdocc = init_int_array(moinfo.nirreps);
66
 
  moinfo.fruocc = init_int_array(moinfo.nirreps);
67
 
  psio_read_entry(CC_INFO, "Frozen Core Orbs Per Irrep",
68
 
                  (char *) moinfo.frdocc, sizeof(int)*moinfo.nirreps);
69
 
  psio_read_entry(CC_INFO, "Frozen Virt Orbs Per Irrep",
70
 
                  (char *) moinfo.fruocc, sizeof(int)*moinfo.nirreps);
71
 
 
72
 
  psio_read_entry(CC_INFO, "No. of Active Orbitals", (char *) &(nactive),
73
 
                  sizeof(int)); 
74
 
 
75
 
  if(params.ref == 2) { /** UHF **/
76
 
 
77
 
    moinfo.aoccpi = init_int_array(nirreps);
78
 
    moinfo.boccpi = init_int_array(nirreps);
79
 
    moinfo.avirtpi = init_int_array(nirreps);
80
 
    moinfo.bvirtpi = init_int_array(nirreps);
81
 
 
82
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orbs Per Irrep",
83
 
                    (char *) moinfo.aoccpi, sizeof(int)*moinfo.nirreps);
84
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orbs Per Irrep",
85
 
                    (char *) moinfo.boccpi, sizeof(int)*moinfo.nirreps);
86
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orbs Per Irrep",
87
 
                    (char *) moinfo.avirtpi, sizeof(int)*moinfo.nirreps);
88
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orbs Per Irrep",
89
 
                    (char *) moinfo.bvirtpi, sizeof(int)*moinfo.nirreps);
90
 
 
91
 
    moinfo.aocc_sym = init_int_array(nactive);
92
 
    moinfo.bocc_sym = init_int_array(nactive);
93
 
    moinfo.avir_sym = init_int_array(nactive);
94
 
    moinfo.bvir_sym = init_int_array(nactive);
95
 
 
96
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Symmetry",
97
 
                    (char *) moinfo.aocc_sym, sizeof(int)*nactive);
98
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Symmetry",
99
 
                    (char *) moinfo.bocc_sym, sizeof(int)*nactive);
100
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Symmetry",
101
 
                    (char *) moinfo.avir_sym, sizeof(int)*nactive);
102
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Symmetry",
103
 
                    (char *) moinfo.bvir_sym, sizeof(int)*nactive);
104
 
 
105
 
    moinfo.aocc_off = init_int_array(moinfo.nirreps);
106
 
    moinfo.bocc_off = init_int_array(moinfo.nirreps);
107
 
    moinfo.avir_off = init_int_array(moinfo.nirreps);
108
 
    moinfo.bvir_off = init_int_array(moinfo.nirreps);
109
 
 
110
 
    psio_read_entry(CC_INFO, "Active Alpha Occ Orb Offsets",
111
 
                    (char *) moinfo.aocc_off, sizeof(int)*moinfo.nirreps);
112
 
    psio_read_entry(CC_INFO, "Active Beta Occ Orb Offsets",
113
 
                    (char *) moinfo.bocc_off, sizeof(int)*moinfo.nirreps);
114
 
 
115
 
    psio_read_entry(CC_INFO, "Active Alpha Virt Orb Offsets",
116
 
                    (char *) moinfo.avir_off, sizeof(int)*moinfo.nirreps);
117
 
    psio_read_entry(CC_INFO, "Active Beta Virt Orb Offsets",
118
 
                    (char *) moinfo.bvir_off, sizeof(int)*moinfo.nirreps);
119
 
 
120
 
  }
121
 
  else { /** RHF or ROHF **/
122
 
  
123
 
    moinfo.occpi = init_int_array(moinfo.nirreps);
124
 
    moinfo.virtpi = init_int_array(moinfo.nirreps);
125
 
    psio_read_entry(CC_INFO, "Active Occ Orbs Per Irrep",
126
 
                    (char *) moinfo.occpi, sizeof(int)*moinfo.nirreps);
127
 
    psio_read_entry(CC_INFO, "Active Virt Orbs Per Irrep",
128
 
                    (char *) moinfo.virtpi, sizeof(int)*moinfo.nirreps);
129
 
 
130
 
    psio_read_entry(CC_INFO, "No. of Active Orbitals", (char *) &(nactive),
131
 
                    sizeof(int)); 
132
 
 
133
 
    moinfo.occ_sym = init_int_array(nactive);
134
 
    moinfo.vir_sym = init_int_array(nactive);
135
 
    psio_read_entry(CC_INFO, "Active Occ Orb Symmetry",
136
 
                    (char *) moinfo.occ_sym, sizeof(int)*nactive);
137
 
    psio_read_entry(CC_INFO, "Active Virt Orb Symmetry",
138
 
                    (char *) moinfo.vir_sym, sizeof(int)*nactive);
139
 
 
140
 
    moinfo.occ_off = init_int_array(moinfo.nirreps);
141
 
    moinfo.vir_off = init_int_array(moinfo.nirreps);
142
 
    psio_read_entry(CC_INFO, "Active Occ Orb Offsets",
143
 
                    (char *) moinfo.occ_off, sizeof(int)*moinfo.nirreps);
144
 
    psio_read_entry(CC_INFO, "Active Virt Orb Offsets",
145
 
                    (char *) moinfo.vir_off, sizeof(int)*moinfo.nirreps);
146
 
 
147
 
  }
148
 
 
149
 
  /* Adjust clsdpi array for frozen orbitals */
150
 
  for(i=0; i < moinfo.nirreps; i++)
151
 
    moinfo.clsdpi[i] -= moinfo.frdocc[i];
152
 
 
153
 
  moinfo.uoccpi = init_int_array(moinfo.nirreps);
154
 
  for(i=0; i < moinfo.nirreps; i++)
155
 
    moinfo.uoccpi[i] = moinfo.orbspi[i] - moinfo.clsdpi[i] -
156
 
      moinfo.openpi[i] - moinfo.fruocc[i] -
157
 
      moinfo.frdocc[i];
158
 
  
159
 
  fprintf(outfile,"\n\n");
160
 
  fprintf(outfile, "\tWave function   =    %6s\n",params.wfn);
161
 
  if(params.semicanonical) {
162
 
  fprintf(outfile, "\tReference wfn   =    ROHF changed to UHF for Semicanonical Orbitals\n");
163
 
  }
164
 
  else {
165
 
  fprintf(outfile, "\tReference wfn   =    %5s\n",
166
 
           (params.ref == 0) ? "RHF" : ((params.ref == 1) ? "ROHF" : "UHF"));
167
 
  }
168
 
  psio_read_entry(CC_INFO, "Reference Energy", (char *) &(moinfo.eref),
169
 
                  sizeof(double));
170
 
  psio_read_entry(CC_INFO, "CCSD Energy", (char *) &(moinfo.ecc),
171
 
                  sizeof(double));
172
 
 
173
 
  fprintf(outfile,"\n\tNuclear Rep. energy (chkpt)   = %20.15f\n",moinfo.enuc);
174
 
  fprintf(outfile,  "\tSCF energy          (chkpt)   = %20.15f\n",moinfo.escf);
175
 
  fprintf(outfile,  "\tReference energy    (file100) = %20.15f\n",moinfo.eref);
176
 
  fprintf(outfile,  "\tCCSD energy         (file100) = %20.15f\n",moinfo.ecc);
177
 
  fprintf(outfile,  "\tTotal CCSD energy   (file100) = %20.15f\n", 
178
 
          moinfo.eref+moinfo.ecc);
179
 
}
180
 
 
181
 
/* Frees memory allocated in get_moinfo() and dumps some info. */
182
 
void cleanup(void)
183
 
{
184
 
  int i;
185
 
 
186
 
  free(moinfo.orbspi);
187
 
  free(moinfo.clsdpi);
188
 
  free(moinfo.openpi);
189
 
  free(moinfo.uoccpi);
190
 
  free(moinfo.fruocc);
191
 
  free(moinfo.frdocc);
192
 
  for(i=0; i < moinfo.nirreps; i++)
193
 
    free(moinfo.labels[i]);
194
 
  free(moinfo.labels);
195
 
  if(params.ref == 2) {
196
 
    free(moinfo.aoccpi);
197
 
    free(moinfo.boccpi);
198
 
    free(moinfo.avirtpi);
199
 
    free(moinfo.bvirtpi);
200
 
    free(moinfo.aocc_sym);
201
 
    free(moinfo.bocc_sym);
202
 
    free(moinfo.avir_sym);
203
 
    free(moinfo.bvir_sym);
204
 
  }
205
 
  else {
206
 
    free(moinfo.occ_sym);
207
 
    free(moinfo.vir_sym);
208
 
    free(moinfo.occ_off);
209
 
    free(moinfo.vir_off);
210
 
    free(moinfo.occpi);
211
 
    free(moinfo.virtpi);
212
 
  }
213
 
}
214