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

« back to all changes in this revision

Viewing changes to src/bin/mp2/cache.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 MP2
 
3
    \brief Enter brief description of file here 
 
4
*/
 
5
#include <cstdio>
 
6
#include <cstdlib>
 
7
#include <libciomr/libciomr.h>
 
8
#include <ccfiles.h>
 
9
#include <psifiles.h>
 
10
 
 
11
namespace psi{ namespace mp2{
 
12
 
 
13
void cache_abcd_rhf(int **cachelist);
 
14
void cache_iabc_rhf(int **cachelist);
 
15
void cache_ijab_rhf(int **cachelist);
 
16
void cache_iajb_rhf(int **cachelist);
 
17
void cache_ijka_rhf(int **cachelist);
 
18
void cache_ijkl_rhf(int **cachelist);
 
19
 
 
20
void cache_abcd_uhf(int **cachelist);
 
21
void cache_iabc_uhf(int **cachelist);
 
22
void cache_ijab_uhf(int **cachelist);
 
23
void cache_iajb_uhf(int **cachelist);
 
24
void cache_ijka_uhf(int **cachelist);
 
25
void cache_ijkl_uhf(int **cachelist);
 
26
 
 
27
int **cacheprep_uhf(int level, int *cachefiles)
 
28
{
 
29
  int **cachelist;
 
30
 
 
31
  /* The listing of CC files whose entries may be cached */
 
32
  cachefiles[CC_AINTS] = 1;
 
33
  cachefiles[CC_CINTS] = 1;
 
34
  cachefiles[CC_DINTS] = 1;
 
35
  cachefiles[CC_EINTS] = 1;
 
36
  cachefiles[CC_DENOM] = 1;
 
37
  cachefiles[CC_TAMPS] = 1;
 
38
  cachefiles[CC_LAMPS] = 1;
 
39
  cachefiles[CC_HBAR] = 1;
 
40
 
 
41
  /* The listing of DPD patterns which may be cached */
 
42
  cachelist = init_int_matrix(32,32);
 
43
 
 
44
  if(level == 0) return cachelist;
 
45
  else if(level == 1) {
 
46
 
 
47
      /*** Cache oooo and ooov ***/
 
48
      cache_ijkl_uhf(cachelist);
 
49
      cache_ijka_uhf(cachelist);
 
50
 
 
51
      return cachelist;
 
52
    }
 
53
  else if(level == 2) {
 
54
 
 
55
      /*** Cache oooo, ooov, oovv, and ovov ***/
 
56
      cache_ijkl_uhf(cachelist);
 
57
      cache_ijka_uhf(cachelist);
 
58
      cache_ijab_uhf(cachelist);
 
59
      cache_iajb_uhf(cachelist);
 
60
 
 
61
      return cachelist;
 
62
    }
 
63
  else if(level == 3) {
 
64
 
 
65
      /*** Cache, oooo, oov, oovv, ovov, and ovvv ***/
 
66
 
 
67
      cache_ijkl_uhf(cachelist);
 
68
      cache_ijka_uhf(cachelist);
 
69
      cache_ijab_uhf(cachelist);
 
70
      cache_iajb_uhf(cachelist);
 
71
      cache_iabc_uhf(cachelist);
 
72
 
 
73
      return cachelist;
 
74
    }
 
75
  else if(level == 4) {
 
76
 
 
77
      /*** Cache everything ***/
 
78
      cache_ijkl_uhf(cachelist);
 
79
      cache_ijka_uhf(cachelist);
 
80
      cache_ijab_uhf(cachelist);
 
81
      cache_iajb_uhf(cachelist);
 
82
      cache_iabc_uhf(cachelist);
 
83
      cache_abcd_uhf(cachelist);
 
84
 
 
85
      return cachelist;
 
86
    }
 
87
  else { printf("Error: invalid cache level!\n"); exit(PSI_RETURN_FAILURE); }
 
88
}
 
89
 
 
90
int **cacheprep_rhf(int level, int *cachefiles)
 
91
{
 
92
  int **cachelist;
 
93
 
 
94
  /* The listing of CC files whose entries may be cached */
 
95
  cachefiles[CC_AINTS] = 1;
 
96
  cachefiles[CC_CINTS] = 1;
 
97
  cachefiles[CC_DINTS] = 1;
 
98
  cachefiles[CC_EINTS] = 1;
 
99
  cachefiles[CC_DENOM] = 1;
 
100
  cachefiles[CC_TAMPS] = 1;
 
101
  cachefiles[CC_LAMPS] = 1;
 
102
  cachefiles[CC_HBAR] = 1;
 
103
 
 
104
  /* The listing of DPD patterns which may be cached */
 
105
  cachelist = init_int_matrix(12,12);
 
106
 
 
107
  if(level == 0) return cachelist;
 
108
  else if(level == 1) {
 
109
 
 
110
      /*** Cache oooo and ooov ***/
 
111
      cache_ijkl_rhf(cachelist);
 
112
      cache_ijka_rhf(cachelist);
 
113
 
 
114
      return cachelist;
 
115
    }
 
116
  else if(level == 2) {
 
117
 
 
118
      /*** Cache oooo, ooov, oovv, and ovov ***/
 
119
      cache_ijkl_rhf(cachelist);
 
120
      cache_ijka_rhf(cachelist);
 
121
      cache_ijab_rhf(cachelist);
 
122
      cache_iajb_rhf(cachelist);
 
123
 
 
124
      return cachelist;
 
125
    }
 
126
  else if(level == 3) {
 
127
 
 
128
      /*** Cache, oooo, oov, oovv, ovov, and ovvv ***/
 
129
 
 
130
      cache_ijkl_rhf(cachelist);
 
131
      cache_ijka_rhf(cachelist);
 
132
      cache_ijab_rhf(cachelist);
 
133
      cache_iajb_rhf(cachelist);
 
134
      cache_iabc_rhf(cachelist);
 
135
 
 
136
      return cachelist;
 
137
    }
 
138
  else if(level == 4) {
 
139
 
 
140
      /*** Cache everything ***/
 
141
      cache_ijkl_rhf(cachelist);
 
142
      cache_ijka_rhf(cachelist);
 
143
      cache_ijab_rhf(cachelist);
 
144
      cache_iajb_rhf(cachelist);
 
145
      cache_iabc_rhf(cachelist);
 
146
      cache_abcd_rhf(cachelist);
 
147
 
 
148
      return cachelist;
 
149
    }
 
150
  else { printf("Error: invalid cache level!\n"); exit(PSI_RETURN_FAILURE); }
 
151
}
 
152
 
 
153
void cache_abcd_uhf(int **cachelist)
 
154
{
 
155
  /* <ab|cd> */
 
156
  cachelist[5][5] = 1;
 
157
  cachelist[5][6] = 1;
 
158
  cachelist[5][7] = 1;
 
159
  cachelist[5][8] = 1;
 
160
  cachelist[5][9] = 1;
 
161
  cachelist[6][5] = 1;
 
162
  cachelist[6][6] = 1;
 
163
  cachelist[6][7] = 1;
 
164
  cachelist[6][8] = 1;
 
165
  cachelist[6][9] = 1;
 
166
  cachelist[7][5] = 1;
 
167
  cachelist[7][6] = 1;
 
168
  cachelist[7][7] = 1;
 
169
  cachelist[7][8] = 1;
 
170
  cachelist[7][9] = 1;
 
171
  cachelist[8][5] = 1;
 
172
  cachelist[8][6] = 1;
 
173
  cachelist[8][7] = 1;
 
174
  cachelist[8][8] = 1;
 
175
  cachelist[8][9] = 1;
 
176
  cachelist[9][5] = 1;
 
177
  cachelist[9][6] = 1;
 
178
  cachelist[9][7] = 1;
 
179
  cachelist[9][8] = 1;
 
180
  cachelist[9][9] = 1;
 
181
  /* <AB|CD> */
 
182
  cachelist[15][15] = 1;
 
183
  cachelist[15][16] = 1;
 
184
  cachelist[15][17] = 1;
 
185
  cachelist[15][18] = 1;
 
186
  cachelist[15][19] = 1;
 
187
  cachelist[16][15] = 1;
 
188
  cachelist[16][16] = 1;
 
189
  cachelist[16][17] = 1;
 
190
  cachelist[16][18] = 1;
 
191
  cachelist[16][19] = 1;
 
192
  cachelist[17][15] = 1;
 
193
  cachelist[17][16] = 1;
 
194
  cachelist[17][17] = 1;
 
195
  cachelist[17][18] = 1;
 
196
  cachelist[17][19] = 1;
 
197
  cachelist[18][15] = 1;
 
198
  cachelist[18][16] = 1;
 
199
  cachelist[18][17] = 1;
 
200
  cachelist[18][18] = 1;
 
201
  cachelist[18][19] = 1;
 
202
  cachelist[19][15] = 1;
 
203
  cachelist[19][16] = 1;
 
204
  cachelist[19][17] = 1;
 
205
  cachelist[19][18] = 1;
 
206
  cachelist[19][19] = 1;
 
207
  /* <Ab|Cd> */
 
208
  cachelist[28][28] = 1;
 
209
  cachelist[29][29] = 1;
 
210
  cachelist[28][29] = 1;
 
211
  cachelist[29][28] = 1;
 
212
}
 
213
 
 
214
void cache_abcd_rhf(int **cachelist)
 
215
{
 
216
  /* <ab|cd> */
 
217
  cachelist[5][5] = 1;
 
218
  cachelist[5][6] = 1;
 
219
  cachelist[5][7] = 1;
 
220
  cachelist[5][8] = 1;
 
221
  cachelist[5][9] = 1;
 
222
  cachelist[6][5] = 1;
 
223
  cachelist[6][6] = 1;
 
224
  cachelist[6][7] = 1;
 
225
  cachelist[6][8] = 1;
 
226
  cachelist[6][9] = 1;
 
227
  cachelist[7][5] = 1;
 
228
  cachelist[7][6] = 1;
 
229
  cachelist[7][7] = 1;
 
230
  cachelist[7][8] = 1;
 
231
  cachelist[7][9] = 1;
 
232
  cachelist[8][5] = 1;
 
233
  cachelist[8][6] = 1;
 
234
  cachelist[8][7] = 1;
 
235
  cachelist[8][8] = 1;
 
236
  cachelist[8][9] = 1;
 
237
  cachelist[9][5] = 1;
 
238
  cachelist[9][6] = 1;
 
239
  cachelist[9][7] = 1;
 
240
  cachelist[9][8] = 1;
 
241
  cachelist[9][9] = 1;
 
242
}
 
243
 
 
244
void cache_iabc_rhf(int **cachelist)
 
245
{
 
246
  /* <ia|bc> */
 
247
  cachelist[10][5] = 1;
 
248
  cachelist[10][6] = 1;
 
249
  cachelist[10][7] = 1;
 
250
  cachelist[10][8] = 1;
 
251
  cachelist[10][9] = 1;
 
252
  cachelist[11][5] = 1;
 
253
  cachelist[11][6] = 1;
 
254
  cachelist[11][7] = 1;
 
255
  cachelist[11][8] = 1;
 
256
  cachelist[11][9] = 1;
 
257
  /* <ab|ci> */
 
258
  cachelist[5][10] = 1;
 
259
  cachelist[5][11] = 1;
 
260
  cachelist[6][10] = 1;
 
261
  cachelist[6][11] = 1;
 
262
  cachelist[7][10] = 1;
 
263
  cachelist[7][11] = 1;
 
264
  cachelist[8][10] = 1;
 
265
  cachelist[8][11] = 1;
 
266
  cachelist[9][10] = 1;
 
267
  cachelist[9][11] = 1;
 
268
}
 
269
 
 
270
void cache_iabc_uhf(int **cachelist)
 
271
{
 
272
  /* <IA|BC> */
 
273
  cachelist[20][5] = 1;
 
274
  cachelist[20][6] = 1;
 
275
  cachelist[20][7] = 1;
 
276
  cachelist[20][8] = 1;
 
277
  cachelist[20][9] = 1;
 
278
  cachelist[21][5] = 1;
 
279
  cachelist[21][6] = 1;
 
280
  cachelist[21][7] = 1;
 
281
  cachelist[21][8] = 1;
 
282
  cachelist[21][9] = 1;
 
283
  /* <AB|CI> */
 
284
  cachelist[5][20] = 1;
 
285
  cachelist[5][21] = 1;
 
286
  cachelist[6][20] = 1;
 
287
  cachelist[6][21] = 1;
 
288
  cachelist[7][20] = 1;
 
289
  cachelist[7][21] = 1;
 
290
  cachelist[8][20] = 1;
 
291
  cachelist[8][21] = 1;
 
292
  cachelist[9][20] = 1;
 
293
  cachelist[9][21] = 1;
 
294
 
 
295
  /* <ia|bc> */
 
296
  cachelist[30][15] = 1;
 
297
  cachelist[30][16] = 1;
 
298
  cachelist[30][17] = 1;
 
299
  cachelist[30][18] = 1;
 
300
  cachelist[30][19] = 1;
 
301
  cachelist[31][15] = 1;
 
302
  cachelist[31][16] = 1;
 
303
  cachelist[31][17] = 1;
 
304
  cachelist[31][18] = 1;
 
305
  cachelist[31][19] = 1;
 
306
  /* <ab|ci> */
 
307
  cachelist[15][30] = 1;
 
308
  cachelist[15][31] = 1;
 
309
  cachelist[16][30] = 1;
 
310
  cachelist[16][31] = 1;
 
311
  cachelist[17][30] = 1;
 
312
  cachelist[17][31] = 1;
 
313
  cachelist[18][30] = 1;
 
314
  cachelist[18][31] = 1;
 
315
  cachelist[19][30] = 1;
 
316
  cachelist[19][31] = 1;
 
317
 
 
318
  /* <Ia|Bc> */
 
319
  cachelist[24][28] = 1;
 
320
  cachelist[24][29] = 1;
 
321
  cachelist[25][28] = 1;
 
322
  cachelist[25][29] = 1;
 
323
 
 
324
  /* <Ab|Ci> */
 
325
  cachelist[28][24] = 1;
 
326
  cachelist[28][25] = 1;
 
327
  cachelist[29][24] = 1;
 
328
  cachelist[29][25] = 1;
 
329
}
 
330
 
 
331
void cache_ijab_rhf(int **cachelist)
 
332
{
 
333
  /* <ij|ab> */
 
334
  cachelist[0][5] = 1;
 
335
  cachelist[0][6] = 1;
 
336
  cachelist[0][7] = 1;
 
337
  cachelist[0][8] = 1;
 
338
  cachelist[0][9] = 1;
 
339
  cachelist[1][5] = 1;
 
340
  cachelist[1][6] = 1;
 
341
  cachelist[1][7] = 1;
 
342
  cachelist[1][8] = 1;
 
343
  cachelist[1][9] = 1;
 
344
  cachelist[2][5] = 1;
 
345
  cachelist[2][6] = 1;
 
346
  cachelist[2][7] = 1;
 
347
  cachelist[2][8] = 1;
 
348
  cachelist[2][9] = 1;
 
349
  cachelist[3][5] = 1;
 
350
  cachelist[3][6] = 1;
 
351
  cachelist[3][7] = 1;
 
352
  cachelist[3][8] = 1;
 
353
  cachelist[3][9] = 1;
 
354
  cachelist[4][5] = 1;
 
355
  cachelist[4][6] = 1;
 
356
  cachelist[4][7] = 1;
 
357
  cachelist[4][8] = 1;
 
358
  cachelist[4][9] = 1;
 
359
  /* <ab|ij> */
 
360
  cachelist[5][0] = 1;
 
361
  cachelist[5][1] = 1;
 
362
  cachelist[5][2] = 1;
 
363
  cachelist[5][3] = 1;
 
364
  cachelist[5][4] = 1;
 
365
  cachelist[6][0] = 1;
 
366
  cachelist[6][1] = 1;
 
367
  cachelist[6][2] = 1;
 
368
  cachelist[6][3] = 1;
 
369
  cachelist[6][4] = 1;
 
370
  cachelist[7][0] = 1;
 
371
  cachelist[7][1] = 1;
 
372
  cachelist[7][2] = 1;
 
373
  cachelist[7][3] = 1;
 
374
  cachelist[7][4] = 1;
 
375
  cachelist[8][0] = 1;
 
376
  cachelist[8][1] = 1;
 
377
  cachelist[8][2] = 1;
 
378
  cachelist[8][3] = 1;
 
379
  cachelist[8][4] = 1;
 
380
  cachelist[9][0] = 1;
 
381
  cachelist[9][1] = 1;
 
382
  cachelist[9][2] = 1;
 
383
  cachelist[9][3] = 1;
 
384
  cachelist[9][4] = 1;
 
385
}
 
386
 
 
387
void cache_ijab_uhf(int **cachelist)
 
388
{
 
389
  /* <IJ|AB> */
 
390
  cachelist[0][5] = 1;
 
391
  cachelist[0][6] = 1;
 
392
  cachelist[0][7] = 1;
 
393
  cachelist[0][8] = 1;
 
394
  cachelist[0][9] = 1;
 
395
  cachelist[1][5] = 1;
 
396
  cachelist[1][6] = 1;
 
397
  cachelist[1][7] = 1;
 
398
  cachelist[1][8] = 1;
 
399
  cachelist[1][9] = 1;
 
400
  cachelist[2][5] = 1;
 
401
  cachelist[2][6] = 1;
 
402
  cachelist[2][7] = 1;
 
403
  cachelist[2][8] = 1;
 
404
  cachelist[2][9] = 1;
 
405
  cachelist[3][5] = 1;
 
406
  cachelist[3][6] = 1;
 
407
  cachelist[3][7] = 1;
 
408
  cachelist[3][8] = 1;
 
409
  cachelist[3][9] = 1;
 
410
  cachelist[4][5] = 1;
 
411
  cachelist[4][6] = 1;
 
412
  cachelist[4][7] = 1;
 
413
  cachelist[4][8] = 1;
 
414
  cachelist[4][9] = 1;
 
415
  /* <AB|IJ> */
 
416
  cachelist[5][0] = 1;
 
417
  cachelist[5][1] = 1;
 
418
  cachelist[5][2] = 1;
 
419
  cachelist[5][3] = 1;
 
420
  cachelist[5][4] = 1;
 
421
  cachelist[6][0] = 1;
 
422
  cachelist[6][1] = 1;
 
423
  cachelist[6][2] = 1;
 
424
  cachelist[6][3] = 1;
 
425
  cachelist[6][4] = 1;
 
426
  cachelist[7][0] = 1;
 
427
  cachelist[7][1] = 1;
 
428
  cachelist[7][2] = 1;
 
429
  cachelist[7][3] = 1;
 
430
  cachelist[7][4] = 1;
 
431
  cachelist[8][0] = 1;
 
432
  cachelist[8][1] = 1;
 
433
  cachelist[8][2] = 1;
 
434
  cachelist[8][3] = 1;
 
435
  cachelist[8][4] = 1;
 
436
  cachelist[9][0] = 1;
 
437
  cachelist[9][1] = 1;
 
438
  cachelist[9][2] = 1;
 
439
  cachelist[9][3] = 1;
 
440
  cachelist[9][4] = 1;
 
441
 
 
442
  /* <ij|ab> */
 
443
  cachelist[10][15] = 1;
 
444
  cachelist[10][16] = 1;
 
445
  cachelist[10][17] = 1;
 
446
  cachelist[10][18] = 1;
 
447
  cachelist[10][19] = 1;
 
448
  cachelist[11][15] = 1;
 
449
  cachelist[11][16] = 1;
 
450
  cachelist[11][17] = 1;
 
451
  cachelist[11][18] = 1;
 
452
  cachelist[11][19] = 1;
 
453
  cachelist[12][15] = 1;
 
454
  cachelist[12][16] = 1;
 
455
  cachelist[12][17] = 1;
 
456
  cachelist[12][18] = 1;
 
457
  cachelist[12][19] = 1;
 
458
  cachelist[13][15] = 1;
 
459
  cachelist[13][16] = 1;
 
460
  cachelist[13][17] = 1;
 
461
  cachelist[13][18] = 1;
 
462
  cachelist[13][19] = 1;
 
463
  cachelist[14][15] = 1;
 
464
  cachelist[14][16] = 1;
 
465
  cachelist[14][17] = 1;
 
466
  cachelist[14][18] = 1;
 
467
  cachelist[14][19] = 1;
 
468
  /* <ab|ij> */
 
469
  cachelist[15][10] = 1;
 
470
  cachelist[15][11] = 1;
 
471
  cachelist[15][12] = 1;
 
472
  cachelist[15][13] = 1;
 
473
  cachelist[15][14] = 1;
 
474
  cachelist[16][10] = 1;
 
475
  cachelist[16][11] = 1;
 
476
  cachelist[16][12] = 1;
 
477
  cachelist[16][13] = 1;
 
478
  cachelist[16][14] = 1;
 
479
  cachelist[17][10] = 1;
 
480
  cachelist[17][11] = 1;
 
481
  cachelist[17][12] = 1;
 
482
  cachelist[17][13] = 1;
 
483
  cachelist[17][14] = 1;
 
484
  cachelist[18][10] = 1;
 
485
  cachelist[18][11] = 1;
 
486
  cachelist[18][12] = 1;
 
487
  cachelist[18][13] = 1;
 
488
  cachelist[18][14] = 1;
 
489
  cachelist[19][10] = 1;
 
490
  cachelist[19][11] = 1;
 
491
  cachelist[19][12] = 1;
 
492
  cachelist[19][13] = 1;
 
493
  cachelist[19][14] = 1;
 
494
 
 
495
  /* <Ij|Ab> */
 
496
  cachelist[22][28] = 1;
 
497
  cachelist[23][28] = 1;
 
498
  cachelist[22][29] = 1;
 
499
  cachelist[23][29] = 1;
 
500
  /* <Ab|Ij> */
 
501
  cachelist[28][22] = 1;
 
502
  cachelist[28][23] = 1;
 
503
  cachelist[29][22] = 1;
 
504
  cachelist[29][23] = 1;
 
505
}
 
506
 
 
507
void cache_iajb_rhf(int **cachelist)
 
508
{
 
509
  /* <ia|jb> */
 
510
  cachelist[10][10] = 1;
 
511
  cachelist[10][11] = 1;
 
512
  cachelist[11][10] = 1;
 
513
  cachelist[11][11] = 1;
 
514
}
 
515
 
 
516
void cache_iajb_uhf(int **cachelist)
 
517
{
 
518
  /* <IA|JB> */
 
519
  cachelist[20][20] = 1;
 
520
  cachelist[20][21] = 1;
 
521
  cachelist[21][20] = 1;
 
522
  cachelist[21][21] = 1;
 
523
  /* <ia|jb> */
 
524
  cachelist[30][30] = 1;
 
525
  cachelist[30][31] = 1;
 
526
  cachelist[31][30] = 1;
 
527
  cachelist[31][31] = 1;
 
528
  /* <Ia|Jb> */
 
529
  cachelist[24][24] = 1;
 
530
  cachelist[24][25] = 1;
 
531
  cachelist[25][24] = 1;
 
532
  cachelist[25][25] = 1;
 
533
}
 
534
 
 
535
void cache_ijka_rhf(int **cachelist)
 
536
{
 
537
  /* <ij|ka> */
 
538
  cachelist[0][10] = 1;
 
539
  cachelist[0][11] = 1;
 
540
  cachelist[1][10] = 1;
 
541
  cachelist[1][11] = 1;
 
542
  cachelist[2][10] = 1;
 
543
  cachelist[2][11] = 1;
 
544
  cachelist[3][10] = 1;
 
545
  cachelist[3][11] = 1;
 
546
  cachelist[4][10] = 1;
 
547
  cachelist[4][11] = 1;
 
548
  /* <ia|jk> */
 
549
  cachelist[10][0] = 1;
 
550
  cachelist[10][1] = 1;
 
551
  cachelist[10][2] = 1;
 
552
  cachelist[10][3] = 1;
 
553
  cachelist[10][4] = 1;
 
554
  cachelist[11][0] = 1;
 
555
  cachelist[11][1] = 1;
 
556
  cachelist[11][2] = 1;
 
557
  cachelist[11][3] = 1;
 
558
  cachelist[11][4] = 1;
 
559
}
 
560
 
 
561
void cache_ijka_uhf(int **cachelist)
 
562
{
 
563
  /* <IJ|KA> */
 
564
  cachelist[0][20] = 1;
 
565
  cachelist[0][21] = 1;
 
566
  cachelist[1][20] = 1;
 
567
  cachelist[1][21] = 1;
 
568
  cachelist[2][20] = 1;
 
569
  cachelist[2][21] = 1;
 
570
  cachelist[3][20] = 1;
 
571
  cachelist[3][21] = 1;
 
572
  cachelist[4][20] = 1;
 
573
  cachelist[4][21] = 1;
 
574
  /* <IA|JK> */
 
575
  cachelist[20][0] = 1;
 
576
  cachelist[20][1] = 1;
 
577
  cachelist[20][2] = 1;
 
578
  cachelist[20][3] = 1;
 
579
  cachelist[20][4] = 1;
 
580
  cachelist[21][0] = 1;
 
581
  cachelist[21][1] = 1;
 
582
  cachelist[21][2] = 1;
 
583
  cachelist[21][3] = 1;
 
584
  cachelist[21][4] = 1;
 
585
 
 
586
  /* <ij|ka> */
 
587
  cachelist[10][30] = 1;
 
588
  cachelist[10][31] = 1;
 
589
  cachelist[11][30] = 1;
 
590
  cachelist[11][31] = 1;
 
591
  cachelist[12][30] = 1;
 
592
  cachelist[12][31] = 1;
 
593
  cachelist[13][30] = 1;
 
594
  cachelist[13][31] = 1;
 
595
  cachelist[14][30] = 1;
 
596
  cachelist[14][31] = 1;
 
597
  /* <ia|jk> */
 
598
  cachelist[30][10] = 1;
 
599
  cachelist[30][11] = 1;
 
600
  cachelist[30][12] = 1;
 
601
  cachelist[30][13] = 1;
 
602
  cachelist[30][14] = 1;
 
603
  cachelist[31][10] = 1;
 
604
  cachelist[31][11] = 1;
 
605
  cachelist[31][12] = 1;
 
606
  cachelist[31][13] = 1;
 
607
  cachelist[31][14] = 1;
 
608
 
 
609
  /* <Ij|Ka> */
 
610
  cachelist[22][24] = 1;
 
611
  cachelist[22][25] = 1;
 
612
  cachelist[23][24] = 1;
 
613
  cachelist[23][25] = 1;
 
614
  /* <Ka|Ij> */
 
615
  cachelist[24][22] = 1;
 
616
  cachelist[25][22] = 1;
 
617
  cachelist[24][23] = 1;
 
618
  cachelist[25][23] = 1;
 
619
}
 
620
 
 
621
void cache_ijkl_rhf(int **cachelist)
 
622
{
 
623
  /* <ij|kl> */
 
624
  cachelist[0][0] = 1;
 
625
  cachelist[0][1] = 1;
 
626
  cachelist[0][2] = 1;
 
627
  cachelist[0][3] = 1;
 
628
  cachelist[0][4] = 1;
 
629
  cachelist[1][0] = 1;
 
630
  cachelist[1][1] = 1;
 
631
  cachelist[1][2] = 1;
 
632
  cachelist[1][3] = 1;
 
633
  cachelist[1][4] = 1;
 
634
  cachelist[2][0] = 1;
 
635
  cachelist[2][1] = 1;
 
636
  cachelist[2][2] = 1;
 
637
  cachelist[2][3] = 1;
 
638
  cachelist[2][4] = 1;
 
639
  cachelist[3][0] = 1;
 
640
  cachelist[3][1] = 1;
 
641
  cachelist[3][2] = 1;
 
642
  cachelist[3][3] = 1;
 
643
  cachelist[3][4] = 1;
 
644
  cachelist[4][0] = 1;
 
645
  cachelist[4][1] = 1;
 
646
  cachelist[4][2] = 1;
 
647
  cachelist[4][3] = 1;
 
648
  cachelist[4][4] = 1;
 
649
}
 
650
 
 
651
void cache_ijkl_uhf(int **cachelist)
 
652
{
 
653
  /* <IJ|KL> */
 
654
  cachelist[0][0] = 1;
 
655
  cachelist[0][1] = 1;
 
656
  cachelist[0][2] = 1;
 
657
  cachelist[0][3] = 1;
 
658
  cachelist[0][4] = 1;
 
659
  cachelist[1][0] = 1;
 
660
  cachelist[1][1] = 1;
 
661
  cachelist[1][2] = 1;
 
662
  cachelist[1][3] = 1;
 
663
  cachelist[1][4] = 1;
 
664
  cachelist[2][0] = 1;
 
665
  cachelist[2][1] = 1;
 
666
  cachelist[2][2] = 1;
 
667
  cachelist[2][3] = 1;
 
668
  cachelist[2][4] = 1;
 
669
  cachelist[3][0] = 1;
 
670
  cachelist[3][1] = 1;
 
671
  cachelist[3][2] = 1;
 
672
  cachelist[3][3] = 1;
 
673
  cachelist[3][4] = 1;
 
674
  cachelist[4][0] = 1;
 
675
  cachelist[4][1] = 1;
 
676
  cachelist[4][2] = 1;
 
677
  cachelist[4][3] = 1;
 
678
  cachelist[4][4] = 1;
 
679
  /* <ij|kl> */
 
680
  cachelist[10][10] = 1;
 
681
  cachelist[10][11] = 1;
 
682
  cachelist[10][12] = 1;
 
683
  cachelist[10][13] = 1;
 
684
  cachelist[10][14] = 1;
 
685
  cachelist[11][10] = 1;
 
686
  cachelist[11][11] = 1;
 
687
  cachelist[11][12] = 1;
 
688
  cachelist[11][13] = 1;
 
689
  cachelist[11][14] = 1;
 
690
  cachelist[12][10] = 1;
 
691
  cachelist[12][11] = 1;
 
692
  cachelist[12][12] = 1;
 
693
  cachelist[12][13] = 1;
 
694
  cachelist[12][14] = 1;
 
695
  cachelist[13][10] = 1;
 
696
  cachelist[13][11] = 1;
 
697
  cachelist[13][12] = 1;
 
698
  cachelist[13][13] = 1;
 
699
  cachelist[13][14] = 1;
 
700
  cachelist[14][10] = 1;
 
701
  cachelist[14][11] = 1;
 
702
  cachelist[14][12] = 1;
 
703
  cachelist[14][13] = 1;
 
704
  cachelist[14][14] = 1;
 
705
  /* <Ij|Kl> */
 
706
  cachelist[22][22] = 1;
 
707
  cachelist[22][23] = 1;
 
708
  cachelist[23][22] = 1;
 
709
  cachelist[23][23] = 1;
 
710
}
 
711
 
 
712
void cachedone_uhf(int **cachelist)
 
713
{
 
714
  free_int_matrix(cachelist);
 
715
}
 
716
 
 
717
void cachedone_rhf(int **cachelist)
 
718
{
 
719
  free_int_matrix(cachelist);
 
720
}
 
721
 
 
722
}} /* End namespaces */