1
0
mirror of https://github.com/TREX-CoE/qmckl.git synced 2025-01-09 20:48:56 +01:00

Introduced many tests

This commit is contained in:
Anthony Scemama 2024-12-13 01:13:54 +01:00
parent d76fb10f61
commit edf40dc6ff
2 changed files with 573 additions and 107 deletions

View File

@ -678,25 +678,32 @@ for (int64_t i=0 ; i<3*elec_num*walk_num ; ++i) {
*** Get *** Get
#+begin_src c :comments org :tangle (eval h_func) :noweb yes #+begin_src c :comments org :tangle (eval h_func) :noweb yes
qmckl_exit_code qmckl_get_electron_ee_distance(qmckl_context context, double* const distance); qmckl_exit_code
qmckl_get_electron_ee_distance(qmckl_context context,
double* const distance,
const int64_t size_max);
#+end_src #+end_src
#+begin_src f90 :tangle (eval fh_func) :comments org :exports none #+begin_src f90 :tangle (eval fh_func) :comments org :exports none
interface interface
integer(c_int32_t) function qmckl_get_electron_ee_distance(context, distance) & integer(c_int32_t) function qmckl_get_electron_ee_distance(context, distance, size_max) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
import import
implicit none implicit none
integer (c_int64_t) , intent(in) , value :: context integer (c_int64_t) , intent(in) , value :: context
real (c_double ) , intent(out) :: distance(*) real (c_double ) , intent(out) :: distance(*)
integer (c_int64_t) , intent(in) :: size_max
end function end function
end interface end interface
#+end_src #+end_src
#+begin_src c :comments org :tangle (eval c) :noweb yes :exports none #+begin_src c :comments org :tangle (eval c) :noweb yes :exports none
qmckl_exit_code qmckl_get_electron_ee_distance(qmckl_context context, double* const distance) qmckl_exit_code
qmckl_get_electron_ee_distance(qmckl_context context,
double* const distance,
const int64_t size_max)
{ {
if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) { if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
return QMCKL_NULL_CONTEXT; return QMCKL_NULL_CONTEXT;
@ -707,10 +714,23 @@ qmckl_exit_code qmckl_get_electron_ee_distance(qmckl_context context, double* co
rc = qmckl_provide_ee_distance(context); rc = qmckl_provide_ee_distance(context);
if (rc != QMCKL_SUCCESS) return rc; if (rc != QMCKL_SUCCESS) return rc;
if (distance == NULL) {
return qmckl_failwith( context,
QMCKL_INVALID_ARG_2,
"qmckl_get_electron_ee_distance",
"distance is a null pointer");
}
qmckl_context_struct* const ctx = (qmckl_context_struct*) context; qmckl_context_struct* const ctx = (qmckl_context_struct*) context;
assert (ctx != NULL); assert (ctx != NULL);
size_t sze = ctx->electron.num * ctx->electron.num * ctx->electron.walker.num; const int64_t sze = ctx->electron.num * ctx->electron.num * ctx->electron.walker.num;
if (size_max < sze) {
return qmckl_failwith( context,
QMCKL_INVALID_ARG_3,
"qmckl_get_electron_ee_distance",
"size_max < num*num*walk_num");
}
memcpy(distance, ctx->electron.ee_distance, sze * sizeof(double)); memcpy(distance, ctx->electron.ee_distance, sze * sizeof(double));
return QMCKL_SUCCESS; return QMCKL_SUCCESS;
@ -901,7 +921,7 @@ assert(qmckl_electron_provided(context));
double ee_distance[walk_num * elec_num * elec_num]; double ee_distance[walk_num * elec_num * elec_num];
rc = qmckl_get_electron_ee_distance(context, ee_distance); rc = qmckl_get_electron_ee_distance(context, ee_distance, walk_num * elec_num * elec_num);
// (e1,e2,w) // (e1,e2,w)
// (0,0,0) == 0. // (0,0,0) == 0.

View File

@ -129,7 +129,6 @@ int main() {
#+end_src #+end_src
* Context * Context
:PROPERTIES: :PROPERTIES:
:Name: qmckl_jastrow_champ :Name: qmckl_jastrow_champ
@ -2154,15 +2153,39 @@ for (int i=0 ; i<type_nucl_num ; ++i) {
/* Check if Jastrow is properly initialized */ /* Check if Jastrow is properly initialized */
assert(qmckl_jastrow_champ_provided(context)); assert(qmckl_jastrow_champ_provided(context));
printf("asymp_jasb\n");
double asymp_jasb[2]; double asymp_jasb[2];
rc = qmckl_check(context, rc = qmckl_check(context,
qmckl_get_jastrow_champ_asymp_jasb(context, asymp_jasb,2) qmckl_get_jastrow_champ_asymp_jasb(context, &(asymp_jasb[0]),2)
); );
// calculate asymp_jasb // calculate asymp_jasb
assert(fabs(asymp_jasb[0]-0.7115733522582638) < 1.e-12); assert(fabs(asymp_jasb[0]-0.7115733522582638) < 1.e-12);
assert(fabs(asymp_jasb[1]-1.043287918508297 ) < 1.e-12); assert(fabs(asymp_jasb[1]-1.043287918508297 ) < 1.e-12);
printf("asymp_jasb_hpc\n");
double asymp_jasb_doc[2];
double asymp_jasb_hpc[2];
// calculate asymp_jasb
rc = qmckl_check(context,
qmckl_compute_jastrow_champ_asymp_jasb_doc (context,
bord_num,
b_vector,
rescale_factor_ee,
0,
&(asymp_jasb_doc[0]) )
);
rc = qmckl_check(context,
qmckl_compute_jastrow_champ_asymp_jasb_hpc (context,
bord_num,
b_vector,
rescale_factor_ee,
0,
&(asymp_jasb_hpc[0]) )
);
assert(fabs(asymp_jasb_doc[0]-asymp_jasb_hpc[0]) < 1.e-12);
assert(fabs(asymp_jasb_doc[1]-asymp_jasb_hpc[1]) < 1.e-12);
#+end_src #+end_src
*** Electron-electron rescaled distances *** Electron-electron rescaled distances
@ -2486,9 +2509,12 @@ print ( "[6][5] : ", (1.0 - np.exp(-kappa * np.linalg.norm(elec_6_w1-elec_5_w1))
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
assert(qmckl_electron_provided(context)); assert(qmckl_electron_provided(context));
{
printf("ee_distance_rescaled\n");
double ee_distance_rescaled[walk_num * elec_num * elec_num]; double ee_distance_rescaled[walk_num * elec_num * elec_num];
rc = qmckl_get_jastrow_champ_ee_distance_rescaled(context, ee_distance_rescaled,walk_num*elec_num*elec_num); rc = qmckl_get_jastrow_champ_ee_distance_rescaled(context,
ee_distance_rescaled,
walk_num*elec_num*elec_num);
// (e1,e2,w) // (e1,e2,w)
// (0,0,0) == 0. // (0,0,0) == 0.
@ -2509,7 +2535,38 @@ assert(ee_distance_rescaled[5*elec_num+6] == ee_distance_rescaled[6*elec_num+5])
// value of (1,0,1) // value of (1,0,1)
assert(fabs(ee_distance_rescaled[5*elec_num+6]-0.3941735387855409) < 1.e-12); assert(fabs(ee_distance_rescaled[5*elec_num+6]-0.3941735387855409) < 1.e-12);
printf("ee_distance_rescaled_hpc\n");
double ee_distance[walk_num * elec_num * elec_num];
rc = qmckl_get_electron_ee_distance(context, &(ee_distance[0]), walk_num*elec_num*elec_num);
assert(rc == QMCKL_SUCCESS);
double ee_distance_rescaled_doc[walk_num * elec_num * elec_num * (cord_num+1)];
memset(ee_distance_rescaled_doc, 0, sizeof(ee_distance_rescaled_doc));
rc = qmckl_compute_een_rescaled_e_doc (context, walk_num,
elec_num, cord_num,
rescale_factor_ee,
&(ee_distance[0]),
&(ee_distance_rescaled_doc[0]));
assert(rc == QMCKL_SUCCESS);
double ee_distance_rescaled_hpc[walk_num * elec_num * elec_num * (cord_num+1)];
memset(ee_distance_rescaled_hpc, 0, sizeof(ee_distance_rescaled_hpc));
rc = qmckl_compute_een_rescaled_e_doc (context, walk_num,
elec_num, cord_num,
rescale_factor_ee,
&(ee_distance[0]),
&(ee_distance_rescaled_hpc[0]));
assert(rc == QMCKL_SUCCESS);
for (int64_t i=0 ; i<walk_num*elec_num*elec_num*(cord_num+1) ; i++) {
assert(fabs(ee_distance_rescaled_hpc[i] - ee_distance_rescaled_doc[i]) < 1.e-12);
}
}
#+end_src #+end_src
*** Electron-electron rescaled distance gradients and Laplacian with respect to electron coordinates *** Electron-electron rescaled distance gradients and Laplacian with respect to electron coordinates
The rescaled distances, represented by $C_{ij} = (1 - e^{-\kappa_\text{e} r_{ij}})/\kappa_\text{e}$ The rescaled distances, represented by $C_{ij} = (1 - e^{-\kappa_\text{e} r_{ij}})/\kappa_\text{e}$
@ -2627,7 +2684,7 @@ qmckl_exit_code qmckl_provide_ee_distance_rescaled_gl(qmckl_context context)
return rc; return rc;
} }
ctx->jastrow_champ.ee_distance_rescaled_date = ctx->date; ctx->jastrow_champ.ee_distance_rescaled_gl_date = ctx->date;
} }
return QMCKL_SUCCESS; return QMCKL_SUCCESS;
@ -2885,21 +2942,46 @@ assert(qmckl_electron_provided(context));
for (int i = 0; i < elec_num; i++) { for (int i = 0; i < elec_num; i++) {
for (int j = 0; j < elec_num; j++) { for (int j = 0; j < elec_num; j++) {
for (int k = 0; k < 3; k++){ for (int k = 0; k < 3; k++){
printf("%.10f\t", fd[nw][i][j][k]); // printf("%.10f\t", fd[nw][i][j][k]);
printf("%.10f\n", ee_distance_rescaled_gl[nw][i][j][k]); // printf("%.10f\n", ee_distance_rescaled_gl[nw][i][j][k]);
assert(fabs(fd[nw][i][j][k] - ee_distance_rescaled_gl[nw][i][j][k]) < 1.e-8); assert(fabs(fd[nw][i][j][k] - ee_distance_rescaled_gl[nw][i][j][k]) < 1.e-8);
} }
int k=3; int k=3;
if (i != j) { if (i != j) {
printf("%.10f\t", fd[nw][i][j][k]); // printf("%.10f\t", fd[nw][i][j][k]);
printf("%.10f\n", ee_distance_rescaled_gl[nw][i][j][k]); // printf("%.10f\n", ee_distance_rescaled_gl[nw][i][j][k]);
assert(fabs(fd[nw][i][j][k] - ee_distance_rescaled_gl[nw][i][j][k]) < 1.e-6); assert(fabs(fd[nw][i][j][k] - ee_distance_rescaled_gl[nw][i][j][k]) < 1.e-6);
} }
} }
} }
} }
printf("OK\n"); printf("OK\n");
printf("ee_distance_rescaled_gl_hpc\n");
double ee_distance_rescaled_gl_doc[walk_num*elec_num*elec_num*4];
rc = qmckl_compute_ee_distance_rescaled_gl_doc (context,
elec_num,
rescale_factor_ee,
walk_num,
&(elec_coord[0][0][0]),
&(ee_distance_rescaled_gl_doc[0]));
assert(rc == QMCKL_SUCCESS);
double ee_distance_rescaled_gl_hpc[walk_num*elec_num*elec_num*4];
rc = qmckl_compute_ee_distance_rescaled_gl_hpc (context,
elec_num,
rescale_factor_ee,
walk_num,
&(elec_coord[0][0][0]),
&(ee_distance_rescaled_gl_hpc[0]));
assert(rc == QMCKL_SUCCESS);
for (int i = 0; i < walk_num*nucl_num*elec_num*4; i++) {
assert(fabs(ee_distance_rescaled_gl_doc[i] - ee_distance_rescaled_gl_hpc[i]) < 1.e-12);
} }
}
#+end_src #+end_src
@ -3100,8 +3182,6 @@ qmckl_exit_code qmckl_provide_jastrow_champ_factor_ee(qmckl_context context)
| ~asymp_jasb~ | ~double[2]~ | in | Asymptotic value of the Jastrow | | ~asymp_jasb~ | ~double[2]~ | in | Asymptotic value of the Jastrow |
| ~factor_ee~ | ~double[walk_num]~ | out | $f_{ee}$ | | ~factor_ee~ | ~double[walk_num]~ | out | $f_{ee}$ |
# #+CALL: generate_c_interface(table=qmckl_factor_ee_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
#+begin_src f90 :comments org :tangle (eval f) :noweb yes #+begin_src f90 :comments org :tangle (eval f) :noweb yes
function qmckl_compute_jastrow_champ_factor_ee_doc(context, & function qmckl_compute_jastrow_champ_factor_ee_doc(context, &
walk_num, elec_num, up_num, bord_num, b_vector, & walk_num, elec_num, up_num, bord_num, b_vector, &
@ -3367,29 +3447,94 @@ for i in range(0,elec_num):
/ (1.0 + b_vector[1] * ee_distance_rescaled[i][j]) \ / (1.0 + b_vector[1] * ee_distance_rescaled[i][j]) \
- asymp_jasb[ipar] + pow_ser - asymp_jasb[ipar] + pow_ser
print("factor_ee :",factor_ee) print("factor_ee :",factor_ee)
print("ee_distance_rescaled :",ee_distance_rescaled)
#+end_src #+end_src
#+RESULTS: #+RESULTS:
: asym_one : 0.6634291325000664 #+begin_example
: asymp_jasb[0] : 0.7115733522582638 asym_one : 0.6634291325000664
: asymp_jasb[1] : 1.043287918508297 asymp_jasb[0] : 0.7115733522582638
: factor_ee : -16.83886184243964 asymp_jasb[1] : 1.043287918508297
factor_ee : -16.83886184243964
ee_distance_rescaled : [[0. 0.63475074 1.29816415 1.23147027 1.51933127 0.54402406
0.51452479 0.96538731 1.25878564 1.3722995 ]
[0.63475074 0. 1.35148664 1.13524156 1.48940503 0.4582292
0.62758076 1.06560856 1.179133 1.30763703]
[1.29816415 1.35148664 0. 1.50021375 1.59200788 1.23488312
1.20844259 1.0355537 1.52064535 1.53049239]
[1.23147027 1.13524156 1.50021375 0. 1.12016142 1.19158954
1.29762585 1.24824277 0.25292267 0.58609336]
[1.51933127 1.48940503 1.59200788 1.12016142 0. 1.50217017
1.54012828 1.48753895 1.10441805 0.84504381]
[0.54402406 0.4582292 1.23488312 1.19158954 1.50217017 0.
0.39417354 0.87009603 1.23838502 1.33419121]
[0.51452479 0.62758076 1.20844259 1.29762585 1.54012828 0.39417354
0. 0.95118809 1.33068934 1.41097406]
[0.96538731 1.06560856 1.0355537 1.24824277 1.48753895 0.87009603
0.95118809 0. 1.29422213 1.33222493]
[1.25878564 1.179133 1.52064535 0.25292267 1.10441805 1.23838502
1.33068934 1.29422213 0. 0.62196802]
[1.3722995 1.30763703 1.53049239 0.58609336 0.84504381 1.33419121
1.41097406 1.33222493 0.62196802 0. ]]
#+end_example
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
/* Check if Jastrow is properly initialized */ /* Check if Jastrow is properly initialized */
assert(qmckl_jastrow_champ_provided(context)); assert(qmckl_jastrow_champ_provided(context));
{
printf("factor_ee\n");
double factor_ee[walk_num]; double factor_ee[walk_num];
rc = qmckl_check(context, rc = qmckl_check(context,
qmckl_get_jastrow_champ_factor_ee(context, factor_ee, walk_num) qmckl_get_jastrow_champ_factor_ee(context, &(factor_ee[0]), walk_num)
); );
// calculate factor_ee // calculate factor_ee
printf("%e\n%e\n\n",factor_ee[0],-16.83886184243964); printf("%20.15f\n%20.15f\n",factor_ee[0],-16.83886184243964);
assert(fabs(factor_ee[0]+16.83886184243964) < 1.e-12); assert(fabs(factor_ee[0]+16.83886184243964) < 1.e-12);
printf("factor_ee_hpc\n");
double ee_distance_rescaled[walk_num*elec_num*elec_num];
rc = qmckl_get_jastrow_champ_ee_distance_rescaled(context,
&(ee_distance_rescaled[0]),
walk_num*elec_num*elec_num);
assert(rc == QMCKL_SUCCESS);
int64_t up_num;
rc = qmckl_get_electron_up_num(context, &up_num);
assert(rc == QMCKL_SUCCESS);
double factor_ee_doc[walk_num];
rc = qmckl_compute_jastrow_champ_factor_ee_doc(context,
walk_num,
elec_num,
up_num,
bord_num,
b_vector,
&(ee_distance_rescaled[0]),
&(asymp_jasb[0]),
0,
&(factor_ee_doc[0]));
assert (rc == QMCKL_SUCCESS);
double factor_ee_hpc[walk_num];
rc = qmckl_compute_jastrow_champ_factor_ee_hpc(context,
walk_num,
elec_num,
up_num,
bord_num,
b_vector,
&(ee_distance_rescaled[0]),
&(asymp_jasb[0]),
0,
&(factor_ee_hpc[0]));
assert (rc == QMCKL_SUCCESS);
for (int64_t i = 0; i < walk_num; i++) {
assert(fabs(factor_ee_doc[i] - factor_ee_hpc[i]) < 1.e-12);
}
}
#+end_src #+end_src
*** Derivative *** Derivative
@ -4099,12 +4244,64 @@ assert(qmckl_jastrow_champ_provided(context));
int k=3; int k=3;
printf("%.10f\t", fd[nw][k][i]); printf("%.10f\t", fd[nw][k][i]);
printf("%.10f\n", factor_ee_gl[nw][k][i]); printf("%.10f\n", factor_ee_gl[nw][k][i]);
assert(fabs(fd[nw][k][i] - factor_ee_gl[nw][k][i]) < 1.e-5); assert(fabs(fd[nw][k][i] - factor_ee_gl[nw][k][i]) < 2.e-5);
} }
} }
printf("OK\n"); printf("OK\n");
} }
{
printf("factor_ee_gl_hpc\n");
int64_t up_num;
rc = qmckl_get_electron_up_num(context, &up_num);
assert(rc == QMCKL_SUCCESS);
double ee_distance_rescaled[walk_num*elec_num*elec_num];
rc = qmckl_get_jastrow_champ_ee_distance_rescaled(context,
&(ee_distance_rescaled[0]),
walk_num*elec_num*elec_num);
assert(rc == QMCKL_SUCCESS);
double ee_distance_rescaled_gl[4*walk_num*elec_num*elec_num];
rc = qmckl_get_jastrow_champ_ee_distance_rescaled_gl(context,
&(ee_distance_rescaled_gl[0]),
4*walk_num*elec_num*elec_num);
assert(rc == QMCKL_SUCCESS);
double factor_ee_gl_doc[walk_num*4*elec_num];
memset(&(factor_ee_gl_doc[0]), 0, sizeof(factor_ee_gl_doc));
rc = qmckl_compute_jastrow_champ_factor_ee_gl_doc(context,
walk_num,
elec_num,
up_num,
bord_num,
b_vector,
&(ee_distance_rescaled[0]),
&(ee_distance_rescaled_gl[0]),
0,
&(factor_ee_gl_doc[0]));
assert(rc == QMCKL_SUCCESS);
double factor_ee_gl_hpc[walk_num*4*elec_num];
memset(&(factor_ee_gl_hpc[0]), 0, sizeof(factor_ee_gl_hpc));
rc = qmckl_compute_jastrow_champ_factor_ee_gl_hpc(context,
walk_num,
elec_num,
up_num,
bord_num,
b_vector,
&(ee_distance_rescaled[0]),
&(ee_distance_rescaled_gl[0]),
0,
&(factor_ee_gl_hpc[0]));
assert(rc == QMCKL_SUCCESS);
for (int64_t i = 0 ; i < walk_num*4*elec_num ; i++) {
printf("%ld %f %f\n", i, factor_ee_gl_hpc[i], factor_ee_gl_doc[i]);
assert(fabs(factor_ee_gl_hpc[i] - factor_ee_gl_doc[i]) < 1.e-12);
}
}
#+end_src #+end_src
** Electron-nucleus component ** Electron-nucleus component
@ -4741,7 +4938,7 @@ print ( "[0][6] : ", (1.0 - np.exp(-kappa * np.linalg.norm(elec_6_w1-nucl_1)) )/
: [0][6] : 0.4726452953409436 : [0][6] : 0.4726452953409436
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
{
assert(qmckl_electron_provided(context)); assert(qmckl_electron_provided(context));
assert(qmckl_nucleus_provided(context)); assert(qmckl_nucleus_provided(context));
@ -4768,7 +4965,29 @@ assert(fabs(en_distance_rescaled[0][1][5] - 1.2091967687767369) < 1.e-12);
// (2,1,2) // (2,1,2)
assert(fabs(en_distance_rescaled[0][0][6] - 0.4726452953409436) < 1.e-12); assert(fabs(en_distance_rescaled[0][0][6] - 0.4726452953409436) < 1.e-12);
}
{
printf("en_distance_rescaled_hpc\n");
double en_distance_rescaled_doc[walk_num*nucl_num*elec_num];
memset(&(en_distance_rescaled_doc[0]), 0, walk_num*nucl_num*elec_num*sizeof(double));
rc = qmckl_compute_en_distance_rescaled_doc(context, elec_num, nucl_num, type_nucl_num,
type_nucl_vector, rescale_factor_en, walk_num,
elec_coord, nucl_coord, en_distance_rescaled_doc);
assert(rc == QMCKL_SUCCESS);
double en_distance_rescaled_hpc[walk_num*nucl_num*elec_num];
memset(&(en_distance_rescaled_hpc[0]), 0, walk_num*nucl_num*elec_num*sizeof(double));
rc = qmckl_compute_en_distance_rescaled_hpc(context, elec_num, nucl_num, type_nucl_num,
type_nucl_vector, rescale_factor_en, walk_num,
elec_coord, nucl_coord, en_distance_rescaled_hpc);
assert(rc == QMCKL_SUCCESS);
for (int64_t i=0 ; i<walk_num*nucl_num*elec_num ; ++i) {
assert(fabs(en_distance_rescaled_doc[i] - en_distance_rescaled_hpc[i]) < 1.e-12);
}
}
#+end_src #+end_src
*** Electron-electron rescaled distance gradients and Laplacian with respect to electron coordinates *** Electron-electron rescaled distance gradients and Laplacian with respect to electron coordinates
@ -5259,6 +5478,27 @@ assert(qmckl_electron_provided(context));
printf("OK\n"); printf("OK\n");
} }
{
printf("en_distance_rescaled_gl_hpc\n");
double en_distance_rescaled_gl_doc[walk_num*nucl_num*elec_num*4];
rc = qmckl_compute_en_distance_rescaled_gl_doc (context,
elec_num, nucl_num, type_nucl_num, type_nucl_vector, rescale_factor_en,
walk_num, elec_coord, nucl_coord,
&(en_distance_rescaled_gl_doc[0]));
assert(rc == QMCKL_SUCCESS);
double en_distance_rescaled_gl_hpc[walk_num*nucl_num*elec_num*4];
rc = qmckl_compute_en_distance_rescaled_gl_hpc (context,
elec_num, nucl_num, type_nucl_num, type_nucl_vector, rescale_factor_en,
walk_num, elec_coord, nucl_coord,
&(en_distance_rescaled_gl_hpc[0]));
assert(rc == QMCKL_SUCCESS);
for (int i = 0; i < walk_num*nucl_num*elec_num*4; i++) {
assert(fabs(en_distance_rescaled_gl_doc[i] - en_distance_rescaled_gl_hpc[i]) < 1.e-12);
}
}
#+end_src #+end_src
*** Electron-nucleus component *** Electron-nucleus component
@ -5696,6 +5936,37 @@ rc = qmckl_get_jastrow_champ_factor_en(context, factor_en,walk_num);
printf("%f %f\n", factor_en[0], 22.781375792083587); printf("%f %f\n", factor_en[0], 22.781375792083587);
assert(fabs(22.781375792083587 - factor_en[0]) < 1.e-12); assert(fabs(22.781375792083587 - factor_en[0]) < 1.e-12);
{
printf("factor_en_hpc\n");
double asymp_jasa[type_nucl_num];
rc = qmckl_get_jastrow_champ_asymp_jasa(context, asymp_jasa, type_nucl_num);
assert(rc == QMCKL_SUCCESS);
double en_distance_rescaled[walk_num*nucl_num*elec_num];
rc = qmckl_get_jastrow_champ_en_distance_rescaled(context,
en_distance_rescaled,
walk_num*nucl_num*elec_num);
assert(rc == QMCKL_SUCCESS);
double factor_en_doc[walk_num];
memset(&(factor_en_doc[0]), 0, sizeof(factor_en_doc));
rc = qmckl_compute_jastrow_champ_factor_en_doc (context,
walk_num, elec_num, nucl_num, type_nucl_num, type_nucl_vector,
aord_num, a_vector,
en_distance_rescaled, asymp_jasa, factor_en_doc);
assert(rc == QMCKL_SUCCESS);
double factor_en_hpc[walk_num];
rc = qmckl_compute_jastrow_champ_factor_en_hpc (context,
walk_num, elec_num, nucl_num, type_nucl_num, type_nucl_vector,
aord_num, a_vector,
en_distance_rescaled, asymp_jasa, factor_en_hpc);
assert(rc == QMCKL_SUCCESS);
for (int64_t i = 0; i < walk_num; i++) {
assert(fabs(factor_en_doc[i] - factor_en_hpc[i]) < 1.e-12);
}
}
#+end_src #+end_src
*** Derivative *** Derivative
@ -6351,6 +6622,39 @@ assert(qmckl_jastrow_champ_provided(context));
printf("OK\n"); printf("OK\n");
} }
{
printf("factor_en_gl_hpc\n");
double en_distance_rescaled[walk_num][nucl_num][elec_num];
rc = qmckl_get_jastrow_champ_en_distance_rescaled(context,
&(en_distance_rescaled[0][0][0]),
walk_num*nucl_num*elec_num);
assert(rc == QMCKL_SUCCESS);
double en_distance_rescaled_gl[walk_num][4][elec_num][nucl_num];
rc = qmckl_get_jastrow_champ_en_distance_rescaled_gl(context,
&(en_distance_rescaled_gl[0][0][0][0]),
walk_num*4*elec_num*nucl_num);
assert(rc == QMCKL_SUCCESS);
double factor_en_gl_doc[walk_num*4*elec_num];
memset(&(factor_en_gl_doc[0]), 0, sizeof(factor_en_gl_doc));
rc = qmckl_compute_jastrow_champ_factor_en_gl_doc(context, walk_num, elec_num,
nucl_num, type_nucl_num, type_nucl_vector, aord_num, &(a_vector[0]),
&(en_distance_rescaled[0][0][0]), &(en_distance_rescaled_gl[0][0][0][0]), &(factor_en_gl_doc[0]));
assert(rc == QMCKL_SUCCESS);
double factor_en_gl_hpc[walk_num*4*elec_num];
memset(&(factor_en_gl_hpc[0]), 0, sizeof(factor_en_gl_hpc));
rc = qmckl_compute_jastrow_champ_factor_en_gl_hpc(context, walk_num, elec_num,
nucl_num, type_nucl_num, type_nucl_vector, aord_num, &(a_vector[0]),
&(en_distance_rescaled[0][0][0]), &(en_distance_rescaled_gl[0][0][0][0]), &(factor_en_gl_hpc[0]));
assert(rc == QMCKL_SUCCESS);
for (int64_t i = 0; i < walk_num*4*elec_num; i++) {
assert(fabs(factor_en_gl_doc[i] - factor_en_gl_hpc[i]) < 1.e-8);
}
}
#+end_src #+end_src
** Electron-electron-nucleus component ** Electron-electron-nucleus component
@ -6369,14 +6673,14 @@ assert(qmckl_jastrow_champ_provided(context));
#+begin_src c :comments org :tangle (eval h_func) :noweb yes #+begin_src c :comments org :tangle (eval h_func) :noweb yes
qmckl_exit_code qmckl_exit_code
qmckl_get_jastrow_champ_een_rescaled_e(qmckl_context context, qmckl_get_jastrow_champ_een_distance_rescaled_e(qmckl_context context,
double* const een_rescaled_e, double* const een_rescaled_e,
const int64_t size_max); const int64_t size_max);
#+end_src #+end_src
#+begin_src c :comments org :tangle (eval c) :noweb yes :exports none #+begin_src c :comments org :tangle (eval c) :noweb yes :exports none
qmckl_exit_code qmckl_exit_code
qmckl_get_jastrow_champ_een_rescaled_e(qmckl_context context, qmckl_get_jastrow_champ_een_distance_rescaled_e(qmckl_context context,
double* const een_rescaled_e, double* const een_rescaled_e,
const int64_t size_max) const int64_t size_max)
{ {
@ -6395,7 +6699,7 @@ qmckl_get_jastrow_champ_een_rescaled_e(qmckl_context context,
if (een_rescaled_e == NULL) { if (een_rescaled_e == NULL) {
return qmckl_failwith( context, return qmckl_failwith( context,
QMCKL_INVALID_ARG_2, QMCKL_INVALID_ARG_2,
"qmckl_get_jastrow_champ_een_rescaled_e", "qmckl_get_jastrow_champ_een_distance_rescaled_e",
"Null pointer"); "Null pointer");
} }
@ -6404,7 +6708,7 @@ qmckl_get_jastrow_champ_een_rescaled_e(qmckl_context context,
if (size_max < sze) { if (size_max < sze) {
return qmckl_failwith( context, return qmckl_failwith( context,
QMCKL_INVALID_ARG_3, QMCKL_INVALID_ARG_3,
"qmckl_get_jastrow_champ_een_rescaled_e", "qmckl_get_jastrow_champ_een_distance_rescaled_e",
"Array too small. Expected elec_num*elec_num*walk_num*(cord_num + 1)"); "Array too small. Expected elec_num*elec_num*walk_num*(cord_num + 1)");
} }
@ -6632,8 +6936,7 @@ end function qmckl_compute_een_rescaled_e_doc_f
#+end_src #+end_src
#+begin_src c :comments org :tangle (eval c) :noweb yes #+begin_src c :comments org :tangle (eval c) :noweb yes
qmckl_exit_code qmckl_compute_een_rescaled_e_hpc ( qmckl_exit_code qmckl_compute_een_rescaled_e_hpc (const qmckl_context context,
const qmckl_context context,
const int64_t walk_num, const int64_t walk_num,
const int64_t elec_num, const int64_t elec_num,
const int64_t cord_num, const int64_t cord_num,
@ -6883,7 +7186,7 @@ assert(qmckl_electron_provided(context));
double een_rescaled_e[walk_num][(cord_num + 1)][elec_num][elec_num]; double een_rescaled_e[walk_num][(cord_num + 1)][elec_num][elec_num];
rc = qmckl_get_jastrow_champ_een_rescaled_e(context, &(een_rescaled_e[0][0][0][0]),elec_num*elec_num*(cord_num+1)*walk_num); rc = qmckl_get_jastrow_champ_een_distance_rescaled_e(context, &(een_rescaled_e[0][0][0][0]),elec_num*elec_num*(cord_num+1)*walk_num);
// value of (0,2,1) // value of (0,2,1)
assert(fabs(een_rescaled_e[0][1][0][2]- 0.2211015082992776 ) < 1.e-12); assert(fabs(een_rescaled_e[0][1][0][2]- 0.2211015082992776 ) < 1.e-12);
@ -6909,14 +7212,14 @@ assert(fabs(een_rescaled_e[0][2][1][5]- 0.5257156022077619 ) < 1.e-12);
#+begin_src c :comments org :tangle (eval h_func) :noweb yes #+begin_src c :comments org :tangle (eval h_func) :noweb yes
qmckl_exit_code qmckl_exit_code
qmckl_get_jastrow_champ_een_rescaled_e_gl(qmckl_context context, qmckl_get_jastrow_champ_een_distance_rescaled_e_gl(qmckl_context context,
double* const een_rescaled_e_gl, double* const een_rescaled_e_gl,
const int64_t size_max); const int64_t size_max);
#+end_src #+end_src
#+begin_src c :comments org :tangle (eval c) :noweb yes :exports none #+begin_src c :comments org :tangle (eval c) :noweb yes :exports none
qmckl_exit_code qmckl_exit_code
qmckl_get_jastrow_champ_een_rescaled_e_gl(qmckl_context context, qmckl_get_jastrow_champ_een_distance_rescaled_e_gl(qmckl_context context,
double* const een_rescaled_e_gl, double* const een_rescaled_e_gl,
const int64_t size_max) const int64_t size_max)
{ {
@ -6935,7 +7238,7 @@ qmckl_get_jastrow_champ_een_rescaled_e_gl(qmckl_context context,
if (een_rescaled_e_gl == NULL) { if (een_rescaled_e_gl == NULL) {
return qmckl_failwith( context, return qmckl_failwith( context,
QMCKL_INVALID_ARG_2, QMCKL_INVALID_ARG_2,
"qmckl_get_jastrow_champ_een_rescaled_e_gl", "qmckl_get_jastrow_champ_een_distance_rescaled_e_gl",
"Null pointer"); "Null pointer");
} }
@ -6944,7 +7247,7 @@ qmckl_get_jastrow_champ_een_rescaled_e_gl(qmckl_context context,
if (size_max < sze) { if (size_max < sze) {
return qmckl_failwith( context, return qmckl_failwith( context,
QMCKL_INVALID_ARG_3, QMCKL_INVALID_ARG_3,
"qmckl_get_jastrow_champ_een_rescaled_e_gl", "qmckl_get_jastrow_champ_een_distance_rescaled_e_gl",
"Array too small. Expected elec_num*4*elec_num*walk_num*(cord_num + 1)"); "Array too small. Expected elec_num*4*elec_num*walk_num*(cord_num + 1)");
} }
@ -7036,7 +7339,7 @@ qmckl_exit_code qmckl_provide_een_rescaled_e_gl(qmckl_context context)
#+NAME: qmckl_factor_een_rescaled_e_gl_args #+NAME: qmckl_factor_een_rescaled_e_gl_args
| Variable | Type | In/Out | Description | | Variable | Type | In/Out | Description |
|--------------------------+-------------------------------------------------------+--------+--------------------------------------| |---------------------+-------------------------------------------------------+--------+--------------------------------------|
| ~context~ | ~qmckl_context~ | in | Global state | | ~context~ | ~qmckl_context~ | in | Global state |
| ~walk_num~ | ~int64_t~ | in | Number of walkers | | ~walk_num~ | ~int64_t~ | in | Number of walkers |
| ~elec_num~ | ~int64_t~ | in | Number of electrons | | ~elec_num~ | ~int64_t~ | in | Number of electrons |
@ -7063,6 +7366,7 @@ integer function qmckl_compute_jastrow_champ_factor_een_rescaled_e_gl_f( &
double precision , intent(in) :: ee_distance(elec_num,elec_num,walk_num) double precision , intent(in) :: ee_distance(elec_num,elec_num,walk_num)
double precision , intent(in) :: een_rescaled_e(elec_num,elec_num,0:cord_num,walk_num) double precision , intent(in) :: een_rescaled_e(elec_num,elec_num,0:cord_num,walk_num)
double precision , intent(out) :: een_rescaled_e_gl(elec_num,4,elec_num,0:cord_num,walk_num) double precision , intent(out) :: een_rescaled_e_gl(elec_num,4,elec_num,0:cord_num,walk_num)
double precision,dimension(:,:,:),allocatable :: elec_dist_gl double precision,dimension(:,:,:),allocatable :: elec_dist_gl
double precision :: x, rij_inv, kappa_l double precision :: x, rij_inv, kappa_l
integer*8 :: i, j, k, l, nw, ii integer*8 :: i, j, k, l, nw, ii
@ -7114,7 +7418,7 @@ integer function qmckl_compute_jastrow_champ_factor_een_rescaled_e_gl_f( &
end do end do
! Not necessary: should be set to zero by qmckl_malloc ! Not necessary: should be set to zero by qmckl_malloc
! een_rescaled_e_gl(:,:,:,0,nw) = 0.d0 een_rescaled_e_gl(:,:,:,0,nw) = 0.d0
do l = 1, cord_num do l = 1, cord_num
kappa_l = - dble(l) * rescale_factor_ee kappa_l = - dble(l) * rescale_factor_ee
@ -7364,6 +7668,7 @@ qmckl_exit_code qmckl_compute_jastrow_champ_factor_een_rescaled_e_gl (
coord_ee, ee_distance, een_rescaled_e, een_rescaled_e_gl ); coord_ee, ee_distance, een_rescaled_e, een_rescaled_e_gl );
} }
#+end_src #+end_src
**** Test **** Test
#+name: een_e_gl #+name: een_e_gl
#+begin_src python :results output :exports none :noweb yes #+begin_src python :results output :exports none :noweb yes
@ -7440,7 +7745,7 @@ print(" een_rescaled_e_gl[2, 1, 6, 2] = ",een_rescaled_e_gl[1, 0, 5, 2])
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
double een_rescaled_e_gl[walk_num][(cord_num + 1)][elec_num][4][elec_num]; double een_rescaled_e_gl[walk_num][(cord_num + 1)][elec_num][4][elec_num];
size_max=walk_num*(cord_num + 1)*elec_num*4*elec_num; size_max=walk_num*(cord_num + 1)*elec_num*4*elec_num;
rc = qmckl_get_jastrow_champ_een_rescaled_e_gl(context, rc = qmckl_get_jastrow_champ_een_distance_rescaled_e_gl(context,
&(een_rescaled_e_gl[0][0][0][0][0]),size_max); &(een_rescaled_e_gl[0][0][0][0][0]),size_max);
assert(fabs(een_rescaled_e_gl[0][1][0][0][2] + 0.09831391870751387 ) < 1.e-12); assert(fabs(een_rescaled_e_gl[0][1][0][0][2] + 0.09831391870751387 ) < 1.e-12);
@ -7451,6 +7756,142 @@ assert(fabs(een_rescaled_e_gl[0][2][1][0][4] + 0.004922634822943517 ) < 1.e-12
assert(fabs(een_rescaled_e_gl[0][2][1][0][5] + 0.5416751547830984 ) < 1.e-12); assert(fabs(een_rescaled_e_gl[0][2][1][0][5] + 0.5416751547830984 ) < 1.e-12);
#+end_src #+end_src
#+begin_src c :tangle (eval c_test)
assert(qmckl_electron_provided(context));
{
printf("een_distance_rescaled_e_gl\n");
double fd[walk_num][cord_num+1][elec_num][4][elec_num];
double delta_x = 0.0001;
// Finite difference coefficients for gradients
double coef[9] = { 1.0/280.0, -4.0/105.0, 1.0/5.0, -4.0/5.0, 0.0, 4.0/5.0, -1.0/5.0, 4.0/105.0, -1.0/280.0 };
// Finite difference coefficients for Laplacian
double coef2[9]= {-1.0/560.0, 8.0/315.0, -1.0/5.0, 8.0/5.0, -205.0/72.0, 8.0/5.0, -1.0/5.0, 8.0/315.0, -1.0/560.0 };
qmckl_exit_code rc;
int64_t walk_num;
rc = qmckl_get_electron_walk_num(context, &walk_num);
if (rc != QMCKL_SUCCESS) {
return rc;
}
int64_t elec_num;
rc = qmckl_get_electron_num(context, &elec_num);
if (rc != QMCKL_SUCCESS) {
return rc;
}
double elec_coord[walk_num][elec_num][3];
rc = qmckl_get_electron_coord (context, 'N', &(elec_coord[0][0][0]), 3*walk_num*elec_num);
double temp_coord[walk_num][elec_num][3];
memcpy(&(temp_coord[0][0][0]), &(elec_coord[0][0][0]), sizeof(temp_coord));
double function_values[walk_num][cord_num+1][elec_num][elec_num];
memset(&(fd[0][0][0][0]), 0, sizeof(fd));
printf("%lu %lu\n", sizeof(function_values)/sizeof(double), walk_num*(cord_num+1)*elec_num*elec_num);
for (int64_t k = 0; k < 3; k++) {
for (int64_t i = 0; i < elec_num; i++) {
for (int64_t m = -4; m <= 4; m++) { // Apply finite difference displacement
for (int64_t nw=0 ; nw<walk_num ; nw++) {
temp_coord[nw][i][k] = elec_coord[nw][i][k] + (double) m * delta_x;
}
// Update coordinates in the context
rc = qmckl_set_electron_coord (context, 'N', walk_num,
&(temp_coord[0][0][0]),
walk_num*3*elec_num);
assert(rc == QMCKL_SUCCESS);
// Call the provided function
rc = qmckl_get_jastrow_champ_een_distance_rescaled_e(context,
&(function_values[0][0][0][0]),
sizeof(function_values)/sizeof(double));
assert(rc == QMCKL_SUCCESS);
// Accumulate derivative using finite-difference coefficients
for (int64_t c = 0; c < cord_num+1 ; c++) {
for (int64_t nw=0 ; nw<walk_num ; nw++) {
for (int64_t j = 0; j < elec_num; j++) {
fd[nw][c][j][k][i] += coef [m + 4] * function_values[nw][c][j][i];
fd[nw][c][j][3][i] += coef2[m + 4] * function_values[nw][c][j][i];
}
}
}
for (int64_t nw=0 ; nw<walk_num ; nw++) {
temp_coord[nw][i][k] = elec_coord[nw][i][k];
}
}
}
}
// Reset coordinates in the context
rc = qmckl_set_electron_coord (context, 'N', walk_num,
&(elec_coord[0][0][0]),
walk_num*3*elec_num);
assert(rc == QMCKL_SUCCESS);
// Normalize by the step size
for (int64_t nw=0 ; nw<walk_num ; nw++) {
for (int64_t c = 0; c < cord_num+1 ; c++) {
for (int64_t i = 0; i < elec_num; i++) {
for (int64_t k = 0; k < 4; k++) {
for (int64_t j = 0; j < elec_num; j++) {
fd[nw][c][i][k][j] /= delta_x;
}
}
for (int64_t j = 0; j < elec_num; j++) {
fd[nw][c][i][3][j] /= delta_x;
}
}
}
}
double een_distance_rescaled_e_gl[walk_num][cord_num+1][elec_num][4][elec_num];
rc = qmckl_check(context,
qmckl_get_jastrow_champ_een_distance_rescaled_e_gl(context,
&(een_distance_rescaled_e_gl[0][0][0][0][0]),
sizeof(een_distance_rescaled_e_gl)/sizeof(double))
);
assert(rc == QMCKL_SUCCESS);
for (int nw = 0; nw < walk_num; nw++){
for (int c = 0; c < cord_num+1 ; c++) {
for (int i = 0; i < elec_num; i++) {
for (int j = 0; j < elec_num; j++) {
for (int k = 0; k < 3; k++){
printf("%2d %2d %2d %2d %2d\t", nw, c, i, k, j);
printf("%.10e\t", fd[nw][c][i][k][j]);
printf("%.10e\n", een_distance_rescaled_e_gl[nw][c][i][k][j]);
// assert(fabs(fd[nw][c][i][k][j] - een_distance_rescaled_e_gl[nw][c][i][k][j]) < 1.e-8);
}
int k=3;
if (i != j) {
printf("%2d %2d %2d %2d %2d\t", nw, c, i, k, j);
printf("%.10e\t", fd[nw][c][i][k][j]);
printf("%.10e\n", een_distance_rescaled_e_gl[nw][c][i][k][j]);
// assert(fabs(fd[nw][c][i][k][j] - een_distance_rescaled_e_gl[nw][c][i][k][j]) < 1.e-6);
}
}
}
}
}
assert(0);
printf("OK\n");
}
#+end_src
*** Electron-nucleus rescaled distances in $J_\text{eeN}$ *** Electron-nucleus rescaled distances in $J_\text{eeN}$
~een_rescaled_n~ stores the table of the rescaled distances between ~een_rescaled_n~ stores the table of the rescaled distances between
@ -11527,16 +11968,21 @@ printf("Total Jastrow value\n");
/* Check if Jastrow is properly initialized */ /* Check if Jastrow is properly initialized */
assert(qmckl_jastrow_champ_provided(context)); assert(qmckl_jastrow_champ_provided(context));
{
double factor_ee[walk_num];
rc = qmckl_check(context, rc = qmckl_check(context,
qmckl_get_jastrow_champ_factor_ee(context, &(factor_ee[0]), walk_num) qmckl_get_jastrow_champ_factor_ee(context, &(factor_ee[0]), walk_num)
); );
assert(rc == QMCKL_SUCCESS); assert(rc == QMCKL_SUCCESS);
double factor_en[walk_num];
rc = qmckl_check(context, rc = qmckl_check(context,
qmckl_get_jastrow_champ_factor_en(context, &(factor_en[0]), walk_num) qmckl_get_jastrow_champ_factor_en(context, &(factor_en[0]), walk_num)
); );
assert(rc == QMCKL_SUCCESS); assert(rc == QMCKL_SUCCESS);
double factor_een[walk_num];
rc = qmckl_check(context, rc = qmckl_check(context,
qmckl_get_jastrow_champ_factor_een(context, &(factor_een[0]), walk_num) qmckl_get_jastrow_champ_factor_een(context, &(factor_een[0]), walk_num)
); );
@ -11552,6 +11998,7 @@ assert(rc == QMCKL_SUCCESS);
for (int64_t i=0 ; i< walk_num ; ++i) { for (int64_t i=0 ; i< walk_num ; ++i) {
assert (total_j[i] - exp(factor_ee[i] + factor_en[i] + factor_een[i]) < 1.e-12); assert (total_j[i] - exp(factor_ee[i] + factor_en[i] + factor_een[i]) < 1.e-12);
} }
}
#+end_src #+end_src
@ -11931,7 +12378,6 @@ qmckl_exit_code qmckl_compute_jastrow_champ_gl (
**** Test **** Test
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
printf("Total Jastrow derivatives\n"); printf("Total Jastrow derivatives\n");
/* Check if Jastrow is properly initialized */ /* Check if Jastrow is properly initialized */