mirror of
https://github.com/TREX-CoE/qmckl.git
synced 2025-01-05 11:00:36 +01:00
Fixed bugs. Now gives the correct J_{een}.
This commit is contained in:
parent
3474987940
commit
d19fa51ded
@ -202,7 +202,7 @@ for i in range(elec_num):
|
|||||||
type_nucl_num = 1
|
type_nucl_num = 1
|
||||||
aord_num = 5
|
aord_num = 5
|
||||||
bord_num = 5
|
bord_num = 5
|
||||||
cord_num = 23
|
cord_num = 5
|
||||||
dim_cord_vect= 23
|
dim_cord_vect= 23
|
||||||
type_nucl_vector = [ 1, 1]
|
type_nucl_vector = [ 1, 1]
|
||||||
aord_vector = [
|
aord_vector = [
|
||||||
@ -860,19 +860,22 @@ qmckl_exit_code qmckl_set_jastrow_cord_vector(qmckl_context context, double cons
|
|||||||
|
|
||||||
int32_t mask = 1 << 5;
|
int32_t mask = 1 << 5;
|
||||||
|
|
||||||
int64_t cord_num;
|
qmckl_exit_code rc = qmckl_provide_dim_cord_vect(context);
|
||||||
qmckl_exit_code rc = qmckl_get_jastrow_cord_num(context, &cord_num);
|
if (rc != QMCKL_SUCCESS) return rc;
|
||||||
|
|
||||||
|
int64_t dim_cord_vect;
|
||||||
|
rc = qmckl_get_jastrow_dim_cord_vect(context, &dim_cord_vect);
|
||||||
if (rc != QMCKL_SUCCESS) return rc;
|
if (rc != QMCKL_SUCCESS) return rc;
|
||||||
|
|
||||||
int64_t type_nucl_num;
|
int64_t type_nucl_num;
|
||||||
rc = qmckl_get_jastrow_type_nucl_num(context, &type_nucl_num);
|
rc = qmckl_get_jastrow_type_nucl_num(context, &type_nucl_num);
|
||||||
if (rc != QMCKL_SUCCESS) return rc;
|
if (rc != QMCKL_SUCCESS) return rc;
|
||||||
|
|
||||||
if (cord_num == 0) {
|
if (dim_cord_vect == 0) {
|
||||||
return qmckl_failwith( context,
|
return qmckl_failwith( context,
|
||||||
QMCKL_FAILURE,
|
QMCKL_FAILURE,
|
||||||
"qmckl_set_jastrow_coefficient",
|
"qmckl_set_jastrow_coefficient",
|
||||||
"cord_num is not set");
|
"dim_cord_vect is not set");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cord_vector == NULL) {
|
if (cord_vector == NULL) {
|
||||||
@ -892,7 +895,7 @@ qmckl_exit_code qmckl_set_jastrow_cord_vector(qmckl_context context, double cons
|
|||||||
}
|
}
|
||||||
|
|
||||||
qmckl_memory_info_struct mem_info = qmckl_memory_info_struct_zero;
|
qmckl_memory_info_struct mem_info = qmckl_memory_info_struct_zero;
|
||||||
mem_info.size = cord_num * type_nucl_num * sizeof(double);
|
mem_info.size = dim_cord_vect * type_nucl_num * sizeof(double);
|
||||||
double* new_array = (double*) qmckl_malloc(context, mem_info);
|
double* new_array = (double*) qmckl_malloc(context, mem_info);
|
||||||
|
|
||||||
if(new_array == NULL) {
|
if(new_array == NULL) {
|
||||||
@ -1324,20 +1327,20 @@ end function qmckl_compute_asymp_jasb_f
|
|||||||
#+CALL: generate_c_header(table=qmckl_asymp_jasb_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
#+CALL: generate_c_header(table=qmckl_asymp_jasb_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
||||||
|
|
||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
#+begin_src c :tangle (eval h_private_func) :comments org
|
#+BEGIN_src c :tangle (eval h_func) :comments org
|
||||||
qmckl_exit_code qmckl_compute_asymp_jasb (
|
qmckl_exit_code qmckl_compute_asymp_jasb (
|
||||||
const qmckl_context context,
|
const qmckl_context context,
|
||||||
const int64_t bord_num,
|
const int64_t bord_num,
|
||||||
const double* bord_vector,
|
const double* bord_vector,
|
||||||
const double rescale_factor_kappa_ee,
|
const double rescale_factor_kappa_ee,
|
||||||
double* const asymp_jasb );
|
double* const asymp_jasb );
|
||||||
#+end_src
|
#+END_src
|
||||||
|
|
||||||
|
|
||||||
#+CALL: generate_c_interface(table=qmckl_asymp_jasb_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
#+CALL: generate_c_interface(table=qmckl_asymp_jasb_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
||||||
|
|
||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
#+begin_src f90 :tangle (eval f) :comments org :exports none
|
#+BEGIN_src f90 :tangle (eval f) :comments org :exports none
|
||||||
integer(c_int32_t) function qmckl_compute_asymp_jasb &
|
integer(c_int32_t) function qmckl_compute_asymp_jasb &
|
||||||
(context, bord_num, bord_vector, rescale_factor_kappa_ee, asymp_jasb) &
|
(context, bord_num, bord_vector, rescale_factor_kappa_ee, asymp_jasb) &
|
||||||
bind(C) result(info)
|
bind(C) result(info)
|
||||||
@ -1356,7 +1359,7 @@ end function qmckl_compute_asymp_jasb_f
|
|||||||
(context, bord_num, bord_vector, rescale_factor_kappa_ee, asymp_jasb)
|
(context, bord_num, bord_vector, rescale_factor_kappa_ee, asymp_jasb)
|
||||||
|
|
||||||
end function qmckl_compute_asymp_jasb
|
end function qmckl_compute_asymp_jasb
|
||||||
#+end_src
|
#+END_src
|
||||||
|
|
||||||
*** Test
|
*** Test
|
||||||
#+name: asymp_jasb
|
#+name: asymp_jasb
|
||||||
@ -1411,6 +1414,8 @@ rc = qmckl_set_jastrow_aord_vector(context, aord_vector);
|
|||||||
assert(rc == QMCKL_SUCCESS);
|
assert(rc == QMCKL_SUCCESS);
|
||||||
rc = qmckl_set_jastrow_bord_vector(context, bord_vector);
|
rc = qmckl_set_jastrow_bord_vector(context, bord_vector);
|
||||||
assert(rc == QMCKL_SUCCESS);
|
assert(rc == QMCKL_SUCCESS);
|
||||||
|
rc = qmckl_set_jastrow_bord_vector(context, bord_vector);
|
||||||
|
assert(rc == QMCKL_SUCCESS);
|
||||||
rc = qmckl_set_jastrow_cord_vector(context, cord_vector);
|
rc = qmckl_set_jastrow_cord_vector(context, cord_vector);
|
||||||
assert(rc == QMCKL_SUCCESS);
|
assert(rc == QMCKL_SUCCESS);
|
||||||
rc = qmckl_set_jastrow_dependencies(context);
|
rc = qmckl_set_jastrow_dependencies(context);
|
||||||
@ -3031,7 +3036,6 @@ integer function qmckl_compute_een_rescaled_e_f(context, walk_num, elec_num, cor
|
|||||||
|
|
||||||
end do
|
end do
|
||||||
|
|
||||||
|
|
||||||
end function qmckl_compute_een_rescaled_e_f
|
end function qmckl_compute_een_rescaled_e_f
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
@ -4328,7 +4332,6 @@ qmckl_exit_code qmckl_provide_cord_vect_full(qmckl_context context)
|
|||||||
qmckl_exit_code rc =
|
qmckl_exit_code rc =
|
||||||
qmckl_compute_cord_vect_full(context,
|
qmckl_compute_cord_vect_full(context,
|
||||||
ctx->nucleus.num,
|
ctx->nucleus.num,
|
||||||
ctx->jastrow.cord_num,
|
|
||||||
ctx->jastrow.dim_cord_vect,
|
ctx->jastrow.dim_cord_vect,
|
||||||
ctx->jastrow.type_nucl_num,
|
ctx->jastrow.type_nucl_num,
|
||||||
ctx->jastrow.type_nucl_vector,
|
ctx->jastrow.type_nucl_vector,
|
||||||
@ -4490,26 +4493,24 @@ end function qmckl_compute_dim_cord_vect_f
|
|||||||
#+NAME: qmckl_factor_cord_vect_full_args
|
#+NAME: qmckl_factor_cord_vect_full_args
|
||||||
| qmckl_context | context | in | Global state |
|
| qmckl_context | context | in | Global state |
|
||||||
| int64_t | nucl_num | in | Number of atoms |
|
| int64_t | nucl_num | in | Number of atoms |
|
||||||
| int64_t | cord_num | in | Order of polynomials |
|
|
||||||
| int64_t | dim_cord_vect | in | dimension of cord full table |
|
| int64_t | dim_cord_vect | in | dimension of cord full table |
|
||||||
| int64_t | type_nucl_num | in | dimension of cord full table |
|
| int64_t | type_nucl_num | in | dimension of cord full table |
|
||||||
| int64_t | type_nucl_vector[nucl_num] | in | dimension of cord full table |
|
| int64_t | type_nucl_vector[nucl_num] | in | dimension of cord full table |
|
||||||
| double | cord_vector[cord_num][type_nucl_num] | in | dimension of cord full table |
|
| double | cord_vector[dim_cord_vect][type_nucl_num] | in | dimension of cord full table |
|
||||||
| double | cord_vect_full[dim_cord_vect][nucl_num] | out | Full list of coefficients |
|
| double | cord_vect_full[dim_cord_vect][nucl_num] | out | Full list of coefficients |
|
||||||
|
|
||||||
#+begin_src f90 :comments org :tangle (eval f) :noweb yes
|
#+begin_src f90 :comments org :tangle (eval f) :noweb yes
|
||||||
integer function qmckl_compute_cord_vect_full_f(context, nucl_num, cord_num, dim_cord_vect, type_nucl_num, &
|
integer function qmckl_compute_cord_vect_full_f(context, nucl_num, dim_cord_vect, type_nucl_num, &
|
||||||
type_nucl_vector, cord_vector, cord_vect_full) &
|
type_nucl_vector, cord_vector, cord_vect_full) &
|
||||||
result(info)
|
result(info)
|
||||||
use qmckl
|
use qmckl
|
||||||
implicit none
|
implicit none
|
||||||
integer(qmckl_context), intent(in) :: context
|
integer(qmckl_context), intent(in) :: context
|
||||||
integer*8 , intent(in) :: nucl_num
|
integer*8 , intent(in) :: nucl_num
|
||||||
integer*8 , intent(in) :: cord_num
|
|
||||||
integer*8 , intent(in) :: dim_cord_vect
|
integer*8 , intent(in) :: dim_cord_vect
|
||||||
integer*8 , intent(in) :: type_nucl_num
|
integer*8 , intent(in) :: type_nucl_num
|
||||||
integer*8 , intent(in) :: type_nucl_vector(nucl_num)
|
integer*8 , intent(in) :: type_nucl_vector(nucl_num)
|
||||||
double precision , intent(in) :: cord_vector(cord_num, type_nucl_num)
|
double precision , intent(in) :: cord_vector(type_nucl_num, dim_cord_vect)
|
||||||
double precision , intent(out) :: cord_vect_full(nucl_num,dim_cord_vect)
|
double precision , intent(out) :: cord_vect_full(nucl_num,dim_cord_vect)
|
||||||
double precision :: x
|
double precision :: x
|
||||||
integer*8 :: i, a, k, l, nw
|
integer*8 :: i, a, k, l, nw
|
||||||
@ -4526,11 +4527,6 @@ integer function qmckl_compute_cord_vect_full_f(context, nucl_num, cord_num, dim
|
|||||||
return
|
return
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (cord_num <= 0) then
|
|
||||||
info = QMCKL_INVALID_ARG_3
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
if (type_nucl_num <= 0) then
|
if (type_nucl_num <= 0) then
|
||||||
info = QMCKL_INVALID_ARG_4
|
info = QMCKL_INVALID_ARG_4
|
||||||
return
|
return
|
||||||
@ -4543,7 +4539,7 @@ integer function qmckl_compute_cord_vect_full_f(context, nucl_num, cord_num, dim
|
|||||||
|
|
||||||
|
|
||||||
do a = 1, nucl_num
|
do a = 1, nucl_num
|
||||||
cord_vect_full(1:dim_cord_vect,a) = cord_vector(1:dim_cord_vect,type_nucl_vector(a))
|
cord_vect_full(a,1:dim_cord_vect) = cord_vector(type_nucl_vector(a),1:dim_cord_vect)
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end function qmckl_compute_cord_vect_full_f
|
end function qmckl_compute_cord_vect_full_f
|
||||||
@ -4556,7 +4552,6 @@ end function qmckl_compute_cord_vect_full_f
|
|||||||
qmckl_exit_code qmckl_compute_cord_vect_full (
|
qmckl_exit_code qmckl_compute_cord_vect_full (
|
||||||
const qmckl_context context,
|
const qmckl_context context,
|
||||||
const int64_t nucl_num,
|
const int64_t nucl_num,
|
||||||
const int64_t cord_num,
|
|
||||||
const int64_t dim_cord_vect,
|
const int64_t dim_cord_vect,
|
||||||
const int64_t type_nucl_num,
|
const int64_t type_nucl_num,
|
||||||
const int64_t* type_nucl_vector,
|
const int64_t* type_nucl_vector,
|
||||||
@ -4570,14 +4565,7 @@ end function qmckl_compute_cord_vect_full_f
|
|||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
#+begin_src f90 :tangle (eval f) :comments org :exports none
|
#+begin_src f90 :tangle (eval f) :comments org :exports none
|
||||||
integer(c_int32_t) function qmckl_compute_cord_vect_full &
|
integer(c_int32_t) function qmckl_compute_cord_vect_full &
|
||||||
(context, &
|
(context, nucl_num, dim_cord_vect, type_nucl_num, type_nucl_vector, cord_vector, cord_vect_full) &
|
||||||
nucl_num, &
|
|
||||||
cord_num, &
|
|
||||||
dim_cord_vect, &
|
|
||||||
type_nucl_num, &
|
|
||||||
type_nucl_vector, &
|
|
||||||
cord_vector, &
|
|
||||||
cord_vect_full) &
|
|
||||||
bind(C) result(info)
|
bind(C) result(info)
|
||||||
|
|
||||||
use, intrinsic :: iso_c_binding
|
use, intrinsic :: iso_c_binding
|
||||||
@ -4585,23 +4573,15 @@ end function qmckl_compute_cord_vect_full_f
|
|||||||
|
|
||||||
integer (c_int64_t) , intent(in) , value :: context
|
integer (c_int64_t) , intent(in) , value :: context
|
||||||
integer (c_int64_t) , intent(in) , value :: nucl_num
|
integer (c_int64_t) , intent(in) , value :: nucl_num
|
||||||
integer (c_int64_t) , intent(in) , value :: cord_num
|
|
||||||
integer (c_int64_t) , intent(in) , value :: dim_cord_vect
|
integer (c_int64_t) , intent(in) , value :: dim_cord_vect
|
||||||
integer (c_int64_t) , intent(in) , value :: type_nucl_num
|
integer (c_int64_t) , intent(in) , value :: type_nucl_num
|
||||||
integer (c_int64_t) , intent(in) :: type_nucl_vector(nucl_num)
|
integer (c_int64_t) , intent(in) :: type_nucl_vector(nucl_num)
|
||||||
real (c_double ) , intent(in) :: cord_vector(type_nucl_num,cord_num)
|
real (c_double ) , intent(in) :: cord_vector(type_nucl_num,dim_cord_vect)
|
||||||
real (c_double ) , intent(out) :: cord_vect_full(nucl_num,dim_cord_vect)
|
real (c_double ) , intent(out) :: cord_vect_full(nucl_num,dim_cord_vect)
|
||||||
|
|
||||||
integer(c_int32_t), external :: qmckl_compute_cord_vect_full_f
|
integer(c_int32_t), external :: qmckl_compute_cord_vect_full_f
|
||||||
info = qmckl_compute_cord_vect_full_f &
|
info = qmckl_compute_cord_vect_full_f &
|
||||||
(context, &
|
(context, nucl_num, dim_cord_vect, type_nucl_num, type_nucl_vector, cord_vector, cord_vect_full)
|
||||||
nucl_num, &
|
|
||||||
cord_num, &
|
|
||||||
dim_cord_vect, &
|
|
||||||
type_nucl_num, &
|
|
||||||
type_nucl_vector, &
|
|
||||||
cord_vector, &
|
|
||||||
cord_vect_full)
|
|
||||||
|
|
||||||
end function qmckl_compute_cord_vect_full
|
end function qmckl_compute_cord_vect_full
|
||||||
#+end_src
|
#+end_src
|
||||||
@ -4708,7 +4688,6 @@ end function qmckl_compute_lkpm_combined_index_f
|
|||||||
end function qmckl_compute_lkpm_combined_index
|
end function qmckl_compute_lkpm_combined_index
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
*** Test
|
*** Test
|
||||||
|
|
||||||
#+name: helper_funcs
|
#+name: helper_funcs
|
||||||
@ -4924,10 +4903,10 @@ integer function qmckl_compute_factor_een_f(context, walk_num, elec_num, nucl_nu
|
|||||||
implicit none
|
implicit none
|
||||||
integer(qmckl_context), intent(in) :: context
|
integer(qmckl_context), intent(in) :: context
|
||||||
integer*8 , intent(in) :: walk_num, elec_num, cord_num, nucl_num, dim_cord_vect
|
integer*8 , intent(in) :: walk_num, elec_num, cord_num, nucl_num, dim_cord_vect
|
||||||
integer*8 , intent(in) :: lkpm_combined_index(4,dim_cord_vect)
|
integer*8 , intent(in) :: lkpm_combined_index(dim_cord_vect,4)
|
||||||
double precision , intent(in) :: cord_vect_full(dim_cord_vect, nucl_num)
|
double precision , intent(in) :: cord_vect_full(nucl_num, dim_cord_vect)
|
||||||
double precision , intent(in) :: een_rescaled_e(walk_num, elec_num, elec_num, 0:cord_num)
|
double precision , intent(in) :: een_rescaled_e(0:cord_num, elec_num, elec_num, walk_num)
|
||||||
double precision , intent(in) :: een_rescaled_n(walk_num, elec_num, nucl_num, 0:cord_num)
|
double precision , intent(in) :: een_rescaled_n(0:cord_num, nucl_num, elec_num, walk_num)
|
||||||
double precision , intent(out) :: factor_een(walk_num)
|
double precision , intent(out) :: factor_een(walk_num)
|
||||||
|
|
||||||
integer*8 :: i, a, j, l, k, p, m, n, nw
|
integer*8 :: i, a, j, l, k, p, m, n, nw
|
||||||
@ -4964,23 +4943,27 @@ integer function qmckl_compute_factor_een_f(context, walk_num, elec_num, nucl_nu
|
|||||||
|
|
||||||
do nw =1, walk_num
|
do nw =1, walk_num
|
||||||
do n = 1, dim_cord_vect
|
do n = 1, dim_cord_vect
|
||||||
l = lkpm_combined_index(1, n)
|
l = lkpm_combined_index(n, 1)
|
||||||
k = lkpm_combined_index(2, n)
|
k = lkpm_combined_index(n, 2)
|
||||||
p = lkpm_combined_index(3, n)
|
p = lkpm_combined_index(n, 3)
|
||||||
m = lkpm_combined_index(4, n)
|
m = lkpm_combined_index(n, 4)
|
||||||
|
|
||||||
do a = 1, nucl_num
|
do a = 1, nucl_num
|
||||||
accu2 = 0.0d0
|
accu2 = 0.0d0
|
||||||
cn = cord_vect_full(n, a)
|
cn = cord_vect_full(a, n)
|
||||||
do j = 1, elec_num
|
do j = 1, elec_num
|
||||||
accu = 0.0d0
|
accu = 0.0d0
|
||||||
do i = 1, elec_num
|
do i = 1, elec_num
|
||||||
accu = accu + een_rescaled_e(nw, i, j, k) * &
|
accu = accu + een_rescaled_e(k,i,j,nw) * &
|
||||||
een_rescaled_n(nw, i, a, m)
|
een_rescaled_n(m,a,i,nw)
|
||||||
|
!if(nw .eq. 1) then
|
||||||
|
! print *,l,k,p,m,j,i,een_rescaled_e(k,i,j,nw), een_rescaled_n(m,a,i,nw), accu
|
||||||
|
!endif
|
||||||
end do
|
end do
|
||||||
accu2 = accu2 + accu * een_rescaled_n(nw, j, a, m + l)
|
accu2 = accu2 + accu * een_rescaled_n(m + l,a,j,nw)
|
||||||
|
!print *, l,m,nw,accu, accu2, een_rescaled_n(m + l, a, j, nw), cn, factor_een(nw)
|
||||||
end do
|
end do
|
||||||
factor_een(nw) = factor_een(nw) + accu2 + cn
|
factor_een(nw) = factor_een(nw) + accu2 * cn
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
@ -5006,7 +4989,6 @@ end function qmckl_compute_factor_een_f
|
|||||||
double* const factor_een );
|
double* const factor_een );
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
#+CALL: generate_c_interface(table=qmckl_factor_een_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
#+CALL: generate_c_interface(table=qmckl_factor_een_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
|
||||||
|
|
||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
@ -5097,9 +5079,10 @@ print("factor_een:",factor_een)
|
|||||||
/* Check if Jastrow is properly initialized */
|
/* Check if Jastrow is properly initialized */
|
||||||
assert(qmckl_jastrow_provided(context));
|
assert(qmckl_jastrow_provided(context));
|
||||||
|
|
||||||
//double factor_een[walk_num];
|
double factor_een[walk_num];
|
||||||
//rc = qmckl_get_jastrow_factor_een(context, &(factor_een[0]));
|
rc = qmckl_get_jastrow_factor_een(context, &(factor_een[0]));
|
||||||
|
|
||||||
|
assert(fabs(factor_een[0] + 0.37407972141304213) < 1e-12);
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
** Electron-electron-nucleus Jastrow \(f_{een}\) derivative
|
** Electron-electron-nucleus Jastrow \(f_{een}\) derivative
|
||||||
|
Loading…
Reference in New Issue
Block a user