1
0
mirror of https://gitlab.com/scemama/qp_plugins_scemama.git synced 2025-01-07 03:43:08 +01:00
qp_plugins_scemama/devel/svdwf/svdwf.irp.f

71 lines
1.8 KiB
FortranFixed
Raw Normal View History

2020-09-30 20:44:53 +02:00
program svdwf
implicit none
BEGIN_DOC
! TODO : Make the SVD of the alpha-beta wave function and print singular values.
END_DOC
read_wf = .True.
TOUCH read_wf
call run()
end
subroutine run
implicit none
double precision, allocatable :: U(:,:), Vt(:,:), D(:), A(:,:)
integer :: i, j, k, p, q
2020-12-23 00:29:55 +01:00
double precision :: entropy
2020-09-30 20:44:53 +02:00
allocate( A (n_det_alpha_unique, n_det_beta_unique), &
U (n_det_alpha_unique, n_det_alpha_unique), &
Vt(n_det_beta_unique, n_det_beta_unique), &
D(max(n_det_beta_unique,n_det_alpha_unique)) )
2020-12-23 02:21:15 +01:00
do j=1,n_det_beta_unique
do i=1,n_det_alpha_unique
A(i,j) = 0.D0
enddo
enddo
2020-09-30 20:44:53 +02:00
do k=1,N_det
i = psi_bilinear_matrix_rows(k)
j = psi_bilinear_matrix_columns(k)
A(i,j) = psi_bilinear_matrix_values(k,1)
enddo
2020-12-23 02:21:15 +01:00
if (N_det == 1) then
D(1) = 1.d0
U(1,1) = 1.d0
Vt(1,1) = 1.d0
else
call randomized_svd(A, size(A,1), &
2020-09-30 20:44:53 +02:00
U, size(U,1), D, Vt, size(Vt,1), n_det_alpha_unique, n_det_beta_unique, &
2020-12-23 02:21:15 +01:00
6,min(n_det_beta_unique,1000))
endif
2020-09-30 20:44:53 +02:00
2020-12-23 00:29:55 +01:00
entropy = 0.d0
2021-07-28 17:24:03 +02:00
k=n_det_beta_unique
2020-09-30 20:44:53 +02:00
do i=1,n_det_beta_unique
print *, i, real(D(i)), real(D(i)**2), real(sum(D(1:i)**2))
2020-12-23 00:29:55 +01:00
entropy -= D(i) * dlog(D(i))
2020-09-30 20:44:53 +02:00
if (D(i) < 1.d-15) then
k = i
exit
endif
enddo
print *, 'threshold: ', 2.858 * D(k/2)
2020-12-23 00:29:55 +01:00
print *, 'Entropy : ', entropy
2020-12-23 02:21:15 +01:00
2021-07-28 17:24:03 +02:00
call ezfio_set_spindeterminants_n_svd_coefs(min(n_det_beta_unique,n_det_alpha_unique))
2021-03-08 12:54:34 +01:00
call ezfio_set_spindeterminants_psi_svd_alpha(U)
call ezfio_set_spindeterminants_psi_svd_beta (Vt)
call ezfio_set_spindeterminants_psi_svd_coefs(D)
2020-12-23 00:29:55 +01:00
! do i=1,n_det_alpha_unique
! print '(I6,4(X,F12.8))', i, U(i,1:4)
! enddo
! print *, ''
! do i=1,n_det_beta_unique
! print '(I6,4(X,F12.8))', i, Vt(1:4,i)
! enddo
2020-12-23 02:21:15 +01:00
2020-09-30 20:44:53 +02:00
end