File: Contract_Hamiltonian.c

package info (click to toggle)
openmx 3.5-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 134,876 kB
  • sloc: ansic: 152,771; python: 876; makefile: 576; xml: 63; perl: 18; sh: 4
file content (78 lines) | stat: -rw-r--r-- 1,822 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**********************************************************************
  Contract_Hamiltonian.c:

     Contract_Hamiltonian.c is a subroutine to contract the Hamitonian and  
     overlap matrices

  Log of Contract_Hamiltonian.c:

     8/Jan/2004  Released by T.Ozaki

***********************************************************************/

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
#include "openmx_common.h"

void Contract_Hamiltonian(double *****H,   double *****CntH,
                          double *****OLP, double *****CntOLP)
{
  int spin,Gc_AN,Mc_AN,h_AN,Mh_AN,Gh_AN;
  int p,q,p0,q0,al,be,Cwan,Hwan;
  double sumH[2],sumS,tmp0;

  for (Mc_AN=1; Mc_AN<=Matomnum; Mc_AN++){
    Gc_AN = M2G[Mc_AN];
    Cwan = WhatSpecies[Gc_AN];

    for (h_AN=0; h_AN<=FNAN[Gc_AN]; h_AN++){
      Gh_AN = natn[Gc_AN][h_AN];
      Hwan = WhatSpecies[Gh_AN];
      Mh_AN = F_G2M[Gh_AN];

      for (al=0; al<Spe_Total_CNO[Cwan]; al++){
        for (be=0; be<Spe_Total_CNO[Hwan]; be++){

          sumH[0] = 0.0;
          sumH[1] = 0.0;
          sumS    = 0.0;

          for (p=0; p<Spe_Specified_Num[Cwan][al]; p++){
            p0 = Spe_Trans_Orbital[Cwan][al][p];

            for (q=0; q<Spe_Specified_Num[Hwan][be]; q++){
              q0 = Spe_Trans_Orbital[Hwan][be][q];
              tmp0 = CntCoes[Mc_AN][al][p]*CntCoes[Mh_AN][be][q]; 
              for (spin=0; spin<=SpinP_switch; spin++){
                sumH[spin] = sumH[spin] + tmp0*H[spin][Mc_AN][h_AN][p0][q0];
              }

              sumS = sumS + tmp0*OLP[0][Mc_AN][h_AN][p0][q0];
            }
          }

          for (spin=0; spin<=SpinP_switch; spin++){ 
            CntH[spin][Mc_AN][h_AN][al][be] = sumH[spin];
	  }

          CntOLP[0][Mc_AN][h_AN][al][be] = sumS;

	}
      }      

    }
  }
}