-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathVCA_HAMILTONIAN_DIRECT_HxV.f90
137 lines (124 loc) · 4.81 KB
/
VCA_HAMILTONIAN_DIRECT_HxV.f90
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
! > SPARSE MAT-VEC DIRECT ON-THE-FLY PRODUCT
MODULE VCA_HAMILTONIAN_DIRECT_HxV
USE VCA_HAMILTONIAN_COMMON
implicit none
private
integer :: iiup,iidw
integer :: iud,jj
integer :: i,iup,idw
integer :: j,jup,jdw
integer :: m,mup,mdw
integer :: ishift
integer :: isector,jsector
integer :: ms
integer :: impi
integer :: ilat,jlat,iorb,jorb,ispin,jspin,is,js,ilat_bath,iorb_bath
integer :: kp,k1,k2,k3,k4
integer :: ialfa,ibeta
real(8) :: sg1,sg2,sg3,sg4
complex(8) :: htmp,htmpup,htmpdw
logical :: Jcondition
integer :: Nfoo,Nfoo2
complex(8),dimension(:,:,:,:,:),allocatable :: diag_hybr ![Nlat,Nlat_bath,Nspin,Norb,Norb_bath]
complex(8),dimension(:,:,:),allocatable :: bath_diag ![Nlat_bath,Nspin,Norb_bath]
!>Sparse Mat-Vec direct on-the-fly product
public :: directMatVec_main
!public :: directMatVec_orbs
#ifdef _MPI
public :: directMatVec_MPI_main
!public :: directMatVec_MPI_orbs
#endif
contains
subroutine directMatVec_main(Nloc,vin,Hv)
integer :: Nloc
complex(8),dimension(Nloc) :: vin
complex(8),dimension(Nloc) :: Hv
complex(8),dimension(:),allocatable :: vt,Hvt
integer,dimension(Ns) :: ibup,ibdw
integer,dimension(2*Ns_Ud) :: Indices,Jndices ![2-2*Norb]
integer,dimension(Ns_Ud,Ns_Orb) :: Nups,Ndws ![1,Ns]-[Norb,1+Nbath]
integer,dimension(Nlat,Norb) :: Nup,Ndw
!
if(.not.Hstatus)stop "directMatVec_cc ERROR: Hsector NOT set"
isector=Hsector
!
if(Nloc/=getdim(isector))stop "directMatVec_cc ERROR: Nloc != dim(isector)"
!
!Get diagonal hybridization, bath energy
if(Nlat_bath>0 .and. Norb_bath>0)then
include "VCA_HAMILTONIAN/diag_hybr_bath.f90"
endif
!
Hv=zero
!
!-----------------------------------------------!
!LOCAL HAMILTONIAN PART: H_loc*vin = vout
include "VCA_HAMILTONIAN/direct/HxV_local.f90"
!
!UP HAMILTONIAN TERMS
include "VCA_HAMILTONIAN/direct/HxV_up.f90"
!
!DW HAMILTONIAN TERMS
include "VCA_HAMILTONIAN/direct/HxV_dw.f90"
!-----------------------------------------------!
!
if(allocated(diag_hybr))deallocate(diag_hybr)
if(allocated(bath_diag))deallocate(bath_diag)
return
end subroutine directMatVec_main
#ifdef _MPI
subroutine directMatVec_MPI_main(Nloc,vin,Hv)
integer :: Nloc
complex(8),dimension(Nloc) :: Vin
complex(8),dimension(Nloc) :: Hv
complex(8),dimension(:),allocatable :: vt,Hvt
integer,dimension(Ns) :: ibup,ibdw
integer,dimension(2*Ns_Ud) :: Indices,Jndices ![2-2*Norb]
integer,dimension(Ns_Ud,Ns_Orb) :: Nups,Ndws ![1,Ns]-[Norb,1+Nbath]
integer,dimension(Nlat,Norb) :: Nup,Ndw
!
integer,allocatable,dimension(:) :: Counts,Displs
!
if(.not.Hstatus)stop "directMatVec_cc ERROR: Hsector NOT set"
isector=Hsector
!
!Get diagonal hybridization, bath energy
if(Nlat_bath>0 .and. Norb_bath>0)then
include "VCA_HAMILTONIAN/diag_hybr_bath.f90"
endif
!
!
if(MpiComm==MPI_UNDEFINED.OR.MpiComm==Mpi_Comm_Null)&
stop "directMatVec_MPI_cc ERRROR: MpiComm = MPI_UNDEFINED"
! if(.not.MpiStatus)stop "directMatVec_MPI_cc ERROR: MpiStatus = F"
!
!
Hv=zero
!
!-----------------------------------------------!
!LOCAL HAMILTONIAN PART: H_loc*vin = vout
include "VCA_HAMILTONIAN/direct_mpi/HxV_local.f90"
!
!NON-LOCAL TERMS:
!
!UP HAMILTONIAN TERMS: MEMORY CONTIGUOUS
include "VCA_HAMILTONIAN/direct_mpi/HxV_up.f90"
!
!DW HAMILTONIAN TERMS: MEMORY NON-CONTIGUOUS
mpiQup=DimUp/MpiSize
if(MpiRank<mod(DimUp,MpiSize))MpiQup=MpiQup+1
allocate(vt(mpiQup*DimDw)) ;vt=zero
allocate(Hvt(mpiQup*DimDw));Hvt=zero
call vector_transpose_MPI(DimUp,MpiQdw,Vin,DimDw,MpiQup,vt) !Vin^T --> Vt
include "VCA_HAMILTONIAN/direct_mpi/HxV_dw.f90"
deallocate(vt) ; allocate(vt(DimUp*mpiQdw)) ;vt=zero !reallocate Vt
call vector_transpose_MPI(DimDw,mpiQup,Hvt,DimUp,mpiQdw,vt) !Hvt^T --> Vt
Hv = Hv + Vt
!-----------------------------------------------!
!
if(allocated(diag_hybr))deallocate(diag_hybr)
if(allocated(bath_diag))deallocate(bath_diag)
return
end subroutine directMatVec_MPI_main
#endif
END MODULE VCA_HAMILTONIAN_DIRECT_HxV