mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-10 21:18:29 +01:00
Removed touch in copy_H_apply_buffer_to_wf
This commit is contained in:
parent
85709d2fd4
commit
8343697d6f
@ -93,7 +93,9 @@ class H_apply(object):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
s["size_max"] = str(1024*128)
|
s["size_max"] = str(1024*128)
|
||||||
s["copy_buffer"] = "call copy_h_apply_buffer_to_wf"
|
s["copy_buffer"] = """call copy_H_apply_buffer_to_wf
|
||||||
|
SOFT_TOUCH psi_det psi_coef N_det
|
||||||
|
"""
|
||||||
s["printout_now"] = """write(output_Dets,*) &
|
s["printout_now"] = """write(output_Dets,*) &
|
||||||
100.*float(i_generator)/float(N_det_generators), '% in ', wall_1-wall_0, 's'"""
|
100.*float(i_generator)/float(N_det_generators), '% in ', wall_1-wall_0, 's'"""
|
||||||
self.data = s
|
self.data = s
|
||||||
@ -216,7 +218,8 @@ class H_apply(object):
|
|||||||
self.data["params_post"] += ", select_max(min(i_generator,size(select_max,1)))"
|
self.data["params_post"] += ", select_max(min(i_generator,size(select_max,1)))"
|
||||||
self.data["size_max"] = str(1024*128)
|
self.data["size_max"] = str(1024*128)
|
||||||
self.data["copy_buffer"] = """
|
self.data["copy_buffer"] = """
|
||||||
call copy_h_apply_buffer_to_wf
|
call copy_H_apply_buffer_to_wf
|
||||||
|
SOFT_TOUCH psi_det psi_coef N_det
|
||||||
selection_criterion_min = min(selection_criterion_min, maxval(select_max))*0.1d0
|
selection_criterion_min = min(selection_criterion_min, maxval(select_max))*0.1d0
|
||||||
selection_criterion = selection_criterion_min
|
selection_criterion = selection_criterion_min
|
||||||
call write_double(output_Dets,selection_criterion,'Selection criterion')
|
call write_double(output_Dets,selection_criterion,'Selection criterion')
|
||||||
|
@ -98,6 +98,7 @@ subroutine copy_H_apply_buffer_to_wf
|
|||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Copies the H_apply buffer to psi_coef. You need to touch psi_det, psi_coef and N_det
|
! Copies the H_apply buffer to psi_coef. You need to touch psi_det, psi_coef and N_det
|
||||||
! after calling this function.
|
! after calling this function.
|
||||||
|
! After calling this subroutine, N_det, psi_det and psi_coef need to be touched
|
||||||
END_DOC
|
END_DOC
|
||||||
integer(bit_kind), allocatable :: buffer_det(:,:,:)
|
integer(bit_kind), allocatable :: buffer_det(:,:,:)
|
||||||
double precision, allocatable :: buffer_coef(:,:)
|
double precision, allocatable :: buffer_coef(:,:)
|
||||||
@ -173,7 +174,6 @@ subroutine copy_H_apply_buffer_to_wf
|
|||||||
H_apply_buffer(j)%N_det = 0
|
H_apply_buffer(j)%N_det = 0
|
||||||
!$OMP END PARALLEL
|
!$OMP END PARALLEL
|
||||||
call normalize(psi_coef,N_det)
|
call normalize(psi_coef,N_det)
|
||||||
SOFT_TOUCH psi_det psi_coef N_det
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -382,6 +382,7 @@ subroutine $subroutine($params_main)
|
|||||||
nmax = mod( N_det_generators,nproc )
|
nmax = mod( N_det_generators,nproc )
|
||||||
|
|
||||||
|
|
||||||
|
!$ call omp_init_lock(lck)
|
||||||
call start_progress(N_det_generators,'Selection (norm)',0.d0)
|
call start_progress(N_det_generators,'Selection (norm)',0.d0)
|
||||||
|
|
||||||
call wall_time(wall_0)
|
call wall_time(wall_0)
|
||||||
@ -440,7 +441,6 @@ subroutine $subroutine($params_main)
|
|||||||
|
|
||||||
deallocate( mask )
|
deallocate( mask )
|
||||||
|
|
||||||
!$ call omp_init_lock(lck)
|
|
||||||
!$OMP PARALLEL DEFAULT(SHARED) &
|
!$OMP PARALLEL DEFAULT(SHARED) &
|
||||||
!$OMP PRIVATE(i_generator,wall_1,wall_0,ispin,k,mask,iproc)
|
!$OMP PRIVATE(i_generator,wall_1,wall_0,ispin,k,mask,iproc)
|
||||||
call wall_time(wall_0)
|
call wall_time(wall_0)
|
||||||
|
@ -194,8 +194,19 @@ subroutine make_s2_eigenfunction
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
deallocate(d,det_buffer)
|
deallocate(d,det_buffer)
|
||||||
call copy_H_apply_buffer_to_wf
|
|
||||||
|
|
||||||
|
double precision :: c(N_states), e_2_pert(N_states), H_pert_diag(N_states)
|
||||||
|
|
||||||
|
call copy_H_apply_buffer_to_wf
|
||||||
|
! do i=1,N_det
|
||||||
|
! if (psi_coef(i,1) == 0.d0) then
|
||||||
|
! call pt2_epstein_nesbet_2x2(psi_det(1,1,i),c,e_2_pert,H_pert_diag,N_int,N_det,N_states)
|
||||||
|
! do k=1,N_states
|
||||||
|
! psi_coef(i,k) = c(k)
|
||||||
|
! enddo
|
||||||
|
! endif
|
||||||
|
! enddo
|
||||||
|
SOFT_TOUCH N_det psi_coef psi_det
|
||||||
! !TODO DEBUG
|
! !TODO DEBUG
|
||||||
! do i=1,N_det
|
! do i=1,N_det
|
||||||
! do j=i+1,N_det
|
! do j=i+1,N_det
|
||||||
|
Loading…
Reference in New Issue
Block a user