mirror of
https://gitlab.com/scemama/qp_plugins_scemama.git
synced 2025-01-05 02:48:42 +01:00
Compare commits
3 Commits
cf3b4fe449
...
0ac591c407
Author | SHA1 | Date | |
---|---|---|---|
0ac591c407 | |||
08e59877d0 | |||
7b0815354d |
@ -4,6 +4,7 @@ program e_curve
|
|||||||
integer :: i,j,k, kk, nab, m, l
|
integer :: i,j,k, kk, nab, m, l
|
||||||
double precision :: norm, E, hij, num, ci, cj
|
double precision :: norm, E, hij, num, ci, cj
|
||||||
double precision :: e_0(N_states)
|
double precision :: e_0(N_states)
|
||||||
|
double precision, allocatable :: psi_save(:)
|
||||||
PROVIDE mo_two_e_integrals_in_map mo_one_e_integrals
|
PROVIDE mo_two_e_integrals_in_map mo_one_e_integrals
|
||||||
|
|
||||||
if (.not.read_wf) then
|
if (.not.read_wf) then
|
||||||
@ -23,38 +24,31 @@ program e_curve
|
|||||||
double precision :: thresh
|
double precision :: thresh
|
||||||
integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:)
|
integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:)
|
||||||
thresh = 1.d-10
|
thresh = 1.d-10
|
||||||
|
integer :: n_det_prime
|
||||||
|
|
||||||
nab = n_det_alpha_unique+n_det_beta_unique
|
nab = n_det_alpha_unique+n_det_beta_unique
|
||||||
|
|
||||||
|
allocate(psi_save(1:N_det))
|
||||||
|
psi_save(1:N_det) = psi_coef(1:N_det,1)
|
||||||
do while (thresh < 1.d0)
|
do while (thresh < 1.d0)
|
||||||
norm = 0.d0
|
norm = 0.d0
|
||||||
|
n_det_prime = n_det
|
||||||
do k=1,n_det
|
do k=1,n_det
|
||||||
|
psi_coef(k,1) = psi_save(k)
|
||||||
if (dabs(psi_coef(k,1)) < thresh) then
|
if (dabs(psi_coef(k,1)) < thresh) then
|
||||||
psi_coef(k,1) = 0.d0
|
psi_coef(k,1) = 0.d0
|
||||||
|
n_det_prime -= 1
|
||||||
endif
|
endif
|
||||||
norm = norm + psi_coef(k,1)**2
|
norm = norm + psi_coef(k,1)**2
|
||||||
enddo
|
enddo
|
||||||
TOUCH psi_coef
|
TOUCH psi_coef psi_det
|
||||||
norm = norm/dsqrt(norm)
|
norm = norm/dsqrt(norm)
|
||||||
|
psi_coef(:,1) = psi_coef(:,1)/norm
|
||||||
|
|
||||||
psi_coef(1:N_det,1) = psi_coef_sorted(1:N_det,1)
|
E = psi_energy(1)
|
||||||
psi_det(1:N_int,1:2,1:N_det) = psi_det_sorted(1:N_int,1:2,1:N_det)
|
|
||||||
do k=1,n_det
|
|
||||||
if (psi_coef(k,1) == 0.d0) then
|
|
||||||
exit
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
n_det = k-1
|
|
||||||
TOUCH n_det psi_coef psi_det
|
|
||||||
|
|
||||||
j = n_det_alpha_unique+n_det_beta_unique
|
print '(E9.1,2X,I8,2X,2X,F10.8,2X,F15.10)', thresh, n_det_prime, &
|
||||||
call u_0_H_u_0(E,psi_coef,n_det,psi_det,N_int,1,size(psi_coef,1))
|
norm, E
|
||||||
|
|
||||||
print '(E9.1,2X,I8,2X,F10.2,2X,F10.8,2X,F15.10)', thresh, n_det, &
|
|
||||||
dble( elec_alpha_num**3 + elec_alpha_num**2 * (nab-1) ) / &
|
|
||||||
dble( elec_alpha_num**3 + elec_alpha_num**2 * (nab-j)), norm, &
|
|
||||||
psi_energy(1)
|
|
||||||
thresh = thresh * dsqrt(10.d0)
|
thresh = thresh * dsqrt(10.d0)
|
||||||
enddo
|
enddo
|
||||||
print *, '=========================================================='
|
print *, '=========================================================='
|
||||||
|
20
devel/trexio/trexio_file.irp.f
Normal file
20
devel/trexio/trexio_file.irp.f
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
BEGIN_PROVIDER [ character*(1024), trexio_filename ]
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Name of the TREXIO file
|
||||||
|
END_DOC
|
||||||
|
character*(1024) :: prefix
|
||||||
|
|
||||||
|
trexio_filename = trexio_file
|
||||||
|
|
||||||
|
if (trexio_file == 'None') then
|
||||||
|
prefix = trim(ezfio_work_dir)//trim(ezfio_filename)
|
||||||
|
if (backend == 0) then
|
||||||
|
trexio_filename = trim(prefix)//'.h5'
|
||||||
|
else if (backend == 1) then
|
||||||
|
trexio_filename = trim(prefix)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user