mirror of
https://github.com/TREX-CoE/irpjast.git
synced 2025-01-03 10:06:11 +01:00
Added CHAMP jastrow caller
This commit is contained in:
parent
243c056c71
commit
5bb7336871
229
hpsi.f
Normal file
229
hpsi.f
Normal file
@ -0,0 +1,229 @@
|
||||
subroutine hpsi(coord,psid,psij,energy,ipass,ifr)
|
||||
|
||||
c Written by Cyrus Umrigar, modified by Claudia Filippi and A. Scemama
|
||||
c modified by Claudio Amovilli and Franca Floris for PCM and QM-MMPOl
|
||||
|
||||
implicit real*8(a-h,o-z)
|
||||
include 'vmc.h'
|
||||
include 'pseudo.h'
|
||||
include 'force.h'
|
||||
include 'pcm.h'
|
||||
include 'mmpol.h'
|
||||
include 'efield.h'
|
||||
include 'optjas.h'
|
||||
include 'mstates.h'
|
||||
|
||||
c Calculates energy
|
||||
|
||||
common /const/ pi,hb,etrial,delta,deltai,fbias,nelec,imetro,ipr
|
||||
common /contr2/ ijas,icusp,icusp2,isc,ianalyt_lap
|
||||
&,ifock,i3body,irewgt,iaver,istrch
|
||||
common /elec/ nup,ndn
|
||||
|
||||
common /coefs/ coef(MBASIS,MORB,MWF),nbasis,norb
|
||||
|
||||
common /dets/ cdet(MDET,MSTATES,MWF),ndet
|
||||
common /csfs/ ccsf(MDET,MSTATES,MWF),cxdet(MDET*MDETCSFX)
|
||||
&,icxdet(MDET*MDETCSFX),iadet(MDET),ibdet(MDET),ncsf,nstates
|
||||
|
||||
common /optwf_contrl/ ioptjas,ioptorb,ioptci,nparm
|
||||
|
||||
common /wfsec/ iwftype(MFORCE),iwf,nwftype
|
||||
|
||||
common /distance/ rshift(3,MELEC,MCENT),rvec_en(3,MELEC,MCENT)
|
||||
&,r_en(MELEC,MCENT),rvec_ee(3,MMAT_DIM2),r_ee(MMAT_DIM2)
|
||||
|
||||
common /slater/ slmui(MMAT_DIM),slmdi(MMAT_DIM)
|
||||
&,fpu(3,MMAT_DIM),fpd(3,MMAT_DIM)
|
||||
&,fppu(MMAT_DIM),fppd(MMAT_DIM)
|
||||
&,ddx(3,MELEC),d2dx2(MELEC)
|
||||
common /multislater/ detu(MDET),detd(MDET)
|
||||
|
||||
common /jaso/ fso(MELEC,MELEC),fijo(3,MELEC,MELEC)
|
||||
&,d2ijo(MELEC,MELEC),d2o,fsumo,fjo(3,MELEC)
|
||||
|
||||
common /pseudo/ vps(MELEC,MCENT,MPS_L),vpso(MELEC,MCENT,MPS_L,MFORCE)
|
||||
&,lpot(MCTYPE),nloc
|
||||
|
||||
common /casula/ t_vpsp(MCENT,MPS_QUAD,MELEC),icasula,i_vpsp
|
||||
common /pcm_hpsi/ pepcms,pepcmv,qopcm,enfpcm(MCHS)
|
||||
common /mmpol_hpsi/ peQMdp,peQMq,eek_pol(3,MCHMM)
|
||||
|
||||
common /velocity_jastrow/vj(3,MELEC),vjn(3,MELEC)
|
||||
|
||||
common /multidet/ kref,numrep_det(MDET,2),irepcol_det(MELEC,MDET,2),ireporb_det(MELEC,MDET,2)
|
||||
& ,iwundet(MDET,2),iactv(2),ivirt(2)
|
||||
|
||||
common /Bloc/ b(MORB,MELEC),xmatu(MELEC**2),xmatd(MELEC**2)
|
||||
& ,tildem(MELEC,MORB,2)
|
||||
|
||||
common /ycompact/ ymat(MORB,MELEC,2,MSTATES),dymat(MORB,MELEC,2,MSTATES)
|
||||
|
||||
common /force_analy/ iforce_analy
|
||||
|
||||
! ====RLPB for debug===
|
||||
common /config/ xold(3, MELEC), xnew(3, MELEC), vold(3, MELEC)
|
||||
dimension ran(3, MELEC)
|
||||
! =====================
|
||||
|
||||
dimension coord(3,*),psid(*),energy(*)
|
||||
dimension denergy(MSTATES),eloc_det(MDET,2),vpsp_det(2),dvpsp_dj(MPARMJ)
|
||||
|
||||
iwf=iwftype(ifr)
|
||||
|
||||
c pe_ee computed in distances (called from distances if iperiodic != 0)
|
||||
c pe_en(loc) computed in distances if nloc=0 or called from distances if iperiodic!=0
|
||||
c pe_en(loc) computed in nonloc_pot if nloc!=0 and iperiodic=0
|
||||
c pe_en(nonloc) computed in nonloc_pot if nloc !=0
|
||||
|
||||
c distances needed for Jastrow, determinants, and potential energy
|
||||
call distances(0,coord)
|
||||
|
||||
c local potential contributions
|
||||
call pot_local(pe_local)
|
||||
|
||||
c external potential on a grid (e.g. MM from CPMD)
|
||||
call p2gtid('qmmm:iqmmm',iqmmm,0,1)
|
||||
if(iqmmm.eq.1) then
|
||||
ext_pot=0
|
||||
call qmmm_extpot_ene(coord,nelec,ext_pot)
|
||||
pe_local=pe_local+ext_pot
|
||||
endif
|
||||
|
||||
c external charges
|
||||
if(iefield.eq.1) then
|
||||
ext_pot=0
|
||||
call efield_extpot_ene(coord,nelec,ext_pot)
|
||||
pe_local=pe_local+ext_pot
|
||||
endif
|
||||
|
||||
c PCM polarization charges
|
||||
if(ipcm.gt.1) then
|
||||
pepcms=0
|
||||
pepcmv=0
|
||||
call pcm_extpot_ene(coord,nelec,pepcms,pepcmv)
|
||||
pepcm=pepcms+pepcmv
|
||||
pe_local=pe_local+pepcm
|
||||
endif
|
||||
|
||||
c QM-MMPOL (charges+induced dipoles)
|
||||
if(immpol.gt.1) then
|
||||
peQMdp=0
|
||||
peQMq=0
|
||||
call mmpol_extpot_ene(coord,nelec,peQMdp,peQMq)
|
||||
peQM=peQMdp+peQMq
|
||||
pe_local=pe_local+peQM
|
||||
endif
|
||||
|
||||
if(ipr.ge.3) write(6,'(''pe_loc before nonloc_pot'',9f12.5)') pe_local
|
||||
|
||||
c get contribution from jastrow (also compute derivatives wrt parameters and nuclei)
|
||||
if(ianalyt_lap.eq.1) then
|
||||
! BEGIN DEBUG JASTROW RLPB
|
||||
! Here we are messing up with the xold variable in common block!
|
||||
|
||||
! We compare the output of both procedures
|
||||
!call random_seed()
|
||||
!do i = 1, 10
|
||||
! call random_number(ran)
|
||||
! xold = ran
|
||||
! call distances(0, xold)
|
||||
! call jastrow(xold,vj,d2j,psij,ifr)
|
||||
! call irp_full_jastrow
|
||||
!end do
|
||||
|
||||
! Here we benchmark both procedures
|
||||
|
||||
call cpu_time(tchamp_init)
|
||||
do i = 1, 100000
|
||||
call distances(0, coord)
|
||||
call jastrow(coord,vj,d2j,psij,ifr)
|
||||
end do
|
||||
call cpu_time(tchamp_final)
|
||||
|
||||
call cpu_time(tirp_init)
|
||||
do i = 1, 100000
|
||||
call irp_full_jastrow
|
||||
end do
|
||||
call cpu_time(tirp_final)
|
||||
|
||||
print *, "BEGIN ELAPSED TIMES"
|
||||
print *, "CHAMP = ", tchamp_final - tchamp_init
|
||||
print *, "IRP = ", tirp_final - tirp_init
|
||||
print *, "END ELAPSED TIMES"
|
||||
! END DEBUG JASTROW RLPB
|
||||
|
||||
!call jastrow(coord,vj,d2j,psij,ifr)
|
||||
else
|
||||
call jastrow_num(coord,vj,d2j,psij)
|
||||
endif
|
||||
if(ipr.ge.3) write(6,'(''d2j,psij'',9f12.5)') d2j,psij
|
||||
|
||||
c compute reference determinant, its derivatives, and kinetic contribution to B_eloc and its derivatives
|
||||
call determinant(ipass,coord,rvec_en,r_en)
|
||||
|
||||
call compute_bmatrices_kin
|
||||
|
||||
c compute pseudo-potential contribution
|
||||
c nonloc_pot must be called after determinant because slater matrices are needed
|
||||
if(nloc.gt.0)
|
||||
& call nonloc_pot(coord,rshift,rvec_en,r_en,pe_local,vpsp_det,dvpsp_dj,t_vpsp,i_vpsp,ifr)
|
||||
|
||||
if(ipr.ge.3) then
|
||||
write(6,'(''pe_loc after nonloc_pot'',9f12.5)') pe_local
|
||||
write(6,'(''pe_ref after nonloc_pot'',9f12.5)') (vpsp_det(ii),ii=1,2)
|
||||
endif
|
||||
|
||||
call multideterminant_hpsi(vj,vpsp_det,eloc_det)
|
||||
|
||||
e_other=pe_local-hb*d2j
|
||||
do 10 i=1,nelec
|
||||
10 e_other=e_other-hb*(vj(1,i)**2+vj(2,i)**2+vj(3,i)**2)
|
||||
|
||||
do 30 istate=1,nstates
|
||||
|
||||
c combine determinantal quantities to obtain trial wave function
|
||||
call determinant_psit(psid(istate),istate)
|
||||
|
||||
c compute energy using Ymat
|
||||
denergy(istate)=0
|
||||
do 20 iab=1,2
|
||||
nel=nup
|
||||
if(iab.eq.2) nel=ndn
|
||||
do 20 jrep=ivirt(iab),norb
|
||||
do 20 irep=iactv(iab),nel
|
||||
20 denergy(istate)=denergy(istate)+ymat(jrep,irep,iab,istate)*tildem(irep,jrep,iab)
|
||||
denergy(istate)=denergy(istate)*detu(kref)*detd(kref)/psid(istate)
|
||||
|
||||
energy(istate)=denergy(istate)+eloc_det(kref,1)+eloc_det(kref,2)+e_other
|
||||
|
||||
if(ipr.ge.2) then
|
||||
write(6,'(''state'',i4)') istate
|
||||
write(6,'(''psid,psij'',9d12.5)') psid(istate),psij
|
||||
write(6,'(''psitot '',e18.11)') psid(istate)*exp(psij)
|
||||
c do k=1,ndet
|
||||
c write(6,'(''psitot_k '',i6,3e18.8)') k, detu(k),detd(k),detu(k)*detd(k)*exp(psij)
|
||||
c write(6,'(''psitot_k '',i6,3e18.8)') k, detu(k),detd(k),cdet(k,1,1)*detu(k)*detd(k)*exp(psij)
|
||||
c enddo
|
||||
c do 25 i=1,nelec
|
||||
c do 25 k=1,3
|
||||
c 25 write(6,'(''vj'',2e18.11)') vj(k,i)
|
||||
if(ipr.ge.3) write(6,'(''energy'',9f16.10)') energy(istate)
|
||||
endif
|
||||
|
||||
30 continue
|
||||
|
||||
if(ifr.eq.1) then
|
||||
if(iforce_analy.eq.1) call compute_force(psid(1),denergy(1))
|
||||
|
||||
call optorb_compute(psid,energy,denergy)
|
||||
|
||||
call optjas_deloc(psid,energy,dvpsp_dj,vj)
|
||||
|
||||
call optci_deloc(eloc_det,e_other,psid,energy)
|
||||
|
||||
call prop_compute(coord)
|
||||
endif
|
||||
|
||||
return
|
||||
end
|
Loading…
Reference in New Issue
Block a user