1
0
mirror of https://github.com/TREX-CoE/qmckl.git synced 2025-01-05 11:00:36 +01:00

Correct tests and put C(2,2) in distance probes

Since we don't need to place probs on all matrices, a simple solution
seems to monitor one element of the matrix. A solution could be to
compute a matrix norm / residual but this would make the tests more
complex.
This commit is contained in:
Aurélien Delval 2021-07-23 15:19:12 +02:00
parent cbf1bd8de8
commit ce24885979
2 changed files with 14 additions and 80 deletions

View File

@ -65,10 +65,6 @@ gradients and Laplacian of the atomic basis functions.
int main() { int main() {
qmckl_context context; qmckl_context context;
context = qmckl_context_create(); context = qmckl_context_create();
#ifdef VFC_CI
vfc_probes probes = vfc_init_probes();
#endif
#+end_src #+end_src
#+begin_src c :tangle (eval c) #+begin_src c :tangle (eval c)
@ -1742,11 +1738,8 @@ end function qmckl_ao_gaussian_vgl
# Test # Test
#+begin_src f90 :tangle (eval f_test) #+begin_src f90 :tangle (eval f_test)
#ifdef VFC_CI
integer(c_int32_t) function test_qmckl_ao_gaussian_vgl(context, probes) bind(C)
#else
integer(c_int32_t) function test_qmckl_ao_gaussian_vgl(context) bind(C) integer(c_int32_t) function test_qmckl_ao_gaussian_vgl(context) bind(C)
#endif
use qmckl use qmckl
use qmckl_probes_f use qmckl_probes_f
@ -1755,11 +1748,6 @@ integer(c_int32_t) function test_qmckl_ao_gaussian_vgl(context) bind(C)
integer(c_int64_t), intent(in), value :: context integer(c_int64_t), intent(in), value :: context
logical(C_BOOL) :: vfc_err logical(C_BOOL) :: vfc_err
#ifdef VFC_CI
type(vfc_probes) :: probes
integer(C_INT) :: vfc_err
#endif
integer*8 :: n, ldv, j, i integer*8 :: n, ldv, j, i
double precision :: X(3), R(3), Y(3), r2 double precision :: X(3), R(3), Y(3), r2
double precision, allocatable :: VGL(:,:), A(:) double precision, allocatable :: VGL(:,:), A(:)
@ -1788,7 +1776,6 @@ integer(c_int32_t) function test_qmckl_ao_gaussian_vgl(context) bind(C)
DBLE(test_qmckl_ao_gaussian_vgl)) DBLE(test_qmckl_ao_gaussian_vgl))
if (test_qmckl_ao_gaussian_vgl /= 0) return if (test_qmckl_ao_gaussian_vgl /= 0) return
#endif
test_qmckl_ao_gaussian_vgl = -1 test_qmckl_ao_gaussian_vgl = -1
@ -1828,13 +1815,8 @@ end function test_qmckl_ao_gaussian_vgl
#+end_src #+end_src
#+begin_src c :tangle (eval c_test) :exports none #+begin_src c :tangle (eval c_test) :exports none
#ifdef VFC_CI
int test_qmckl_ao_gaussian_vgl(qmckl_context context, vfc_probes * probes);
assert(0 == test_qmckl_ao_gaussian_vgl(context, &probes));
#else
int test_qmckl_ao_gaussian_vgl(qmckl_context context); int test_qmckl_ao_gaussian_vgl(qmckl_context context);
assert(0 == test_qmckl_ao_gaussian_vgl(context)); assert(0 == test_qmckl_ao_gaussian_vgl(context));
#endif
#+end_src #+end_src
** TODO General functions for Slater basis functions ** TODO General functions for Slater basis functions
@ -2821,9 +2803,6 @@ end function qmckl_ao_power_f
*** Test *** Test
#+begin_src f90 :tangle (eval f_test) #+begin_src f90 :tangle (eval f_test)
#ifdef VFC_CI
integer(c_int32_t) function test_qmckl_ao_power(context, probes) bind(C)
#else
integer(c_int32_t) function test_qmckl_ao_power(context) bind(C) integer(c_int32_t) function test_qmckl_ao_power(context) bind(C)
use qmckl use qmckl
@ -2833,7 +2812,6 @@ integer(c_int32_t) function test_qmckl_ao_power(context) bind(C)
logical(C_BOOL) :: vfc_err logical(C_BOOL) :: vfc_err
integer(qmckl_context), intent(in), value :: context integer(qmckl_context), intent(in), value :: context
integer*8 :: n, LDP integer*8 :: n, LDP
@ -2860,7 +2838,6 @@ integer(c_int32_t) function test_qmckl_ao_power(context) bind(C)
DBLE(test_qmckl_ao_power)) DBLE(test_qmckl_ao_power))
if (test_qmckl_ao_power /= QMCKL_SUCCESS) return if (test_qmckl_ao_power /= QMCKL_SUCCESS) return
#endif
test_qmckl_ao_power = QMCKL_FAILURE test_qmckl_ao_power = QMCKL_FAILURE
@ -2880,13 +2857,8 @@ end function test_qmckl_ao_power
#+end_src #+end_src
#+begin_src c :tangle (eval c_test) :exports none #+begin_src c :tangle (eval c_test) :exports none
#ifdef VFC_CI
int test_qmckl_ao_power(qmckl_context context, vfc_probes * probes);
assert(0 == test_qmckl_ao_power(context, &probes));
#else
int test_qmckl_ao_power(qmckl_context context); int test_qmckl_ao_power(qmckl_context context);
assert(0 == test_qmckl_ao_power(context)); assert(0 == test_qmckl_ao_power(context));
#endif
#+end_src #+end_src
** General functions for Value, Gradient and Laplacian of a polynomial ** General functions for Value, Gradient and Laplacian of a polynomial
@ -3168,11 +3140,7 @@ end function qmckl_ao_polynomial_vgl_f
*** Test *** Test
#+begin_src f90 :tangle (eval f_test) #+begin_src f90 :tangle (eval f_test)
#ifdef VFC_CI
integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context, probes) bind(C)
#else
integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C) integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C)
#endif
use qmckl use qmckl
use qmckl_probes_f use qmckl_probes_f
@ -3181,11 +3149,6 @@ integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C)
integer(c_int64_t), intent(in), value :: context integer(c_int64_t), intent(in), value :: context
logical(C_BOOL) :: vfc_err logical(C_BOOL) :: vfc_err
#ifdef VFC_CI
type(vfc_probes) :: probes
integer(C_INT) :: vfc_err
#endif
integer :: lmax, d, i integer :: lmax, d, i
integer, allocatable :: L(:,:) integer, allocatable :: L(:,:)
integer*8 :: n, ldl, ldv, j integer*8 :: n, ldl, ldv, j
@ -3216,7 +3179,6 @@ integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C)
if (test_qmckl_ao_polynomial_vgl /= QMCKL_SUCCESS) return if (test_qmckl_ao_polynomial_vgl /= QMCKL_SUCCESS) return
if (n /= d) return if (n /= d) return
#endif
#ifdef VFC_CI #ifdef VFC_CI
do j=1,n do j=1,n
@ -3278,13 +3240,8 @@ end function test_qmckl_ao_polynomial_vgl
#+end_src #+end_src
#+begin_src c :tangle (eval c_test) #+begin_src c :tangle (eval c_test)
#ifdef VFC_CI
int test_qmckl_ao_polynomial_vgl(qmckl_context context, vfc_probes * probes);
assert(0 == test_qmckl_ao_polynomial_vgl(context, &probes));
#else
int test_qmckl_ao_polynomial_vgl(qmckl_context context); int test_qmckl_ao_polynomial_vgl(qmckl_context context);
assert(0 == test_qmckl_ao_polynomial_vgl(context)); assert(0 == test_qmckl_ao_polynomial_vgl(context));
#endif
#+end_src #+end_src
* Combining radial and polynomial parts * Combining radial and polynomial parts
@ -3801,10 +3758,6 @@ assert( fabs(ao_vgl[1][0][26][224] - ( -3.843864637762753e-09)) < 1.e-14 );
rc = qmckl_context_destroy(context); rc = qmckl_context_destroy(context);
assert (rc == QMCKL_SUCCESS); assert (rc == QMCKL_SUCCESS);
#ifdef VFC_CI
vfc_dump_probes(&probes);
#endif
return 0; return 0;
} }
#+end_src #+end_src

View File

@ -16,16 +16,10 @@ Functions for the computation of distances between particles.
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
#ifdef VFC_CI
#include <vfc_probes.h>
#endif
int main() { int main() {
qmckl_context context; qmckl_context context;
context = qmckl_context_create(); context = qmckl_context_create();
#ifdef VFC_CI
vfc_probes probes = vfc_init_probes();
#endif
#+end_src #+end_src
@ -302,12 +296,6 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
integer(qmckl_context), intent(in), value :: context integer(qmckl_context), intent(in), value :: context
logical(C_BOOL) :: vfc_err logical(C_BOOL) :: vfc_err
#ifdef VFC_CI
type(vfc_probes) :: probes
integer(C_INT) :: vfc_err
#endif
double precision, allocatable :: A(:,:), B(:,:), C(:,:) double precision, allocatable :: A(:,:), B(:,:), C(:,:)
integer*8 :: m, n, LDA, LDB, LDC integer*8 :: m, n, LDA, LDB, LDC
double precision :: x double precision :: x
@ -319,8 +307,6 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
LDB = n LDB = n
LDC = 5 LDC = 5
print *, "Entering test 1"
allocate( A(LDA,m), B(LDB,n), C(LDC,n) ) allocate( A(LDA,m), B(LDB,n), C(LDC,n) )
do j=1,m do j=1,m
@ -337,25 +323,22 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 'X', 't', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 'X', 't', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_Xt", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_Xt", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
#endif
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 't', 'X', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 't', 'X', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_tX", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_tX", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
#endif
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 'T', 't', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 'T', 't', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_Tt", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_Tt", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
@ -376,7 +359,7 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 'n', 'T', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 'n', 'T', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_nT", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_nT", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
@ -397,7 +380,7 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 'T', 'n', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 'T', 'n', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_Tn", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_Tn", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
@ -418,7 +401,7 @@ integer(qmckl_exit_code) function test_qmckl_distance_sq(context) bind(C)
test_qmckl_distance_sq = & test_qmckl_distance_sq = &
qmckl_distance_sq(context, 'n', 'N', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance_sq(context, 'n', 'N', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_sq_nN", DBLE(test_qmckl_distance_sq)) vfc_err = qmckl_probe("distance", "distance_sq_nN", DBLE(C(2,2)))
if (test_qmckl_distance_sq == 0) return if (test_qmckl_distance_sq == 0) return
@ -777,23 +760,21 @@ integer(qmckl_exit_code) function test_qmckl_dist(context) bind(C)
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 'X', 't', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 'X', 't', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_Xt", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_Xt", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return
#endif
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 't', 'X', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 't', 'X', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_tX", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_tX", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return
#endif
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 'T', 't', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 'T', 't', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_Tt", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_Tt", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return
@ -814,7 +795,7 @@ integer(qmckl_exit_code) function test_qmckl_dist(context) bind(C)
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 'n', 'T', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 'n', 'T', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_nT", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_nT", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return
@ -835,7 +816,7 @@ integer(qmckl_exit_code) function test_qmckl_dist(context) bind(C)
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 'T', 'n', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 'T', 'n', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_Tn", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_Tn", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return
@ -856,7 +837,7 @@ integer(qmckl_exit_code) function test_qmckl_dist(context) bind(C)
test_qmckl_dist = & test_qmckl_dist = &
qmckl_distance(context, 'n', 'N', m, n, A, LDA, B, LDB, C, LDC) qmckl_distance(context, 'n', 'N', m, n, A, LDA, B, LDB, C, LDC)
vfc_err = qmckl_probe("distance", "distance_nN", DBLE(test_qmckl_dist)) vfc_err = qmckl_probe("distance", "distance_nN", DBLE(C(2,2)))
if (test_qmckl_dist == 0) return if (test_qmckl_dist == 0) return