diff --git a/README.html b/README.html index 505a642..d26b2be 100644 --- a/README.html +++ b/README.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + QMCkl source code documentation @@ -352,7 +352,7 @@ and bug reports should be submitted at

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl.html b/qmckl.html index d3e3b50..0b2f7fb 100644 --- a/qmckl.html +++ b/qmckl.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Introduction @@ -333,30 +333,30 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Using QMCkl

+
+

1 Using QMCkl

The qmckl.h header file installed in the ${prefix}/include directory @@ -385,12 +385,12 @@ Both files are located in the include/ directory.

-
-

2 Developing in QMCkl

+
+

2 Developing in QMCkl

-
-

2.1 Literate programming

+
+

2.1 Literate programming

In a traditional source code, most of the lines of source files of a program @@ -435,8 +435,8 @@ interactively, in the same spirit as Jupyter notebooks.

-
-

2.2 Source code editing

+
+

2.2 Source code editing

For a tutorial on literate programming with org-mode, follow this link. @@ -467,8 +467,8 @@ org-mode.

-
-

2.3 Choice of the programming language

+
+

2.3 Choice of the programming language

Most of the codes of the TREX CoE are written in Fortran with some scripts in @@ -516,8 +516,8 @@ For more guidelines on using Fortran to generate a C interface, see

-
-

2.4 Coding rules

+
+

2.4 Coding rules

The authors should follow the recommendations of the C99 @@ -535,8 +535,8 @@ Compliance can be checked with cppcheck as:

-
-

2.5 Design of the library

+
+

2.5 Design of the library

The proposed API should allow the library to: deal with memory transfers @@ -547,8 +547,8 @@ functions (see below).

-
-

2.6 Naming conventions

+
+

2.6 Naming conventions

To avoid namespace collisions, we use qmckl_ as a prefix for all exported @@ -573,8 +573,8 @@ form is allowed.

-
-

2.7 Application programming interface

+
+

2.7 Application programming interface

In the C language, the number of bits used by the integer types can change @@ -606,15 +606,15 @@ bindings in other languages in other repositories.

-
-

2.8 Global state

+
+

2.8 Global state

Global variables should be avoided in the library, because it is possible that one single program needs to use multiple instances of the library. To solve this problem we propose to use a pointer to a context variable, built by the library with the -qmckl_context_create function. The =context= contains the global +qmckl_context_create function. The =context= contains the global state of the library, and is used as the first argument of many QMCkl functions.

@@ -628,8 +628,8 @@ the state is done by setters and getters, prefixed by
-
-

2.9 Headers

+
+

2.9 Headers

A single qmckl.h header to be distributed by the library @@ -717,8 +717,8 @@ and the types definitions should be written in the *fh_type.f90 fil

-
-

2.10 Low-level functions

+
+

2.10 Low-level functions

Low-level functions are very simple functions which are leaves of @@ -727,14 +727,14 @@ the function call tree (they don't call any other QMCkl function).

These functions are pure, and unaware of the QMCkl -context. They are not allowed to allocate/deallocate memory, and +context. They are not allowed to allocate/deallocate memory, and if they need temporary memory it should be provided in input.

-
-

2.11 High-level functions

+
+

2.11 High-level functions

High-level functions are at the top of the function call tree. @@ -747,27 +747,27 @@ temporary storage, to simplify the use of accelerators.

The high-level functions should be pure, unless the introduction of non-purity is justified. All the side effects should be made in -the context variable. +the context variable.

-
-

2.12 Numerical precision

+
+

2.12 Numerical precision

The number of bits of precision required for a function should be given as an input of low-level computational functions. This input will be used to define the values of the different thresholds that might be used to avoid computing unnecessary noise. High-level -functions will use the precision specified in the context +functions will use the precision specified in the context variable.

-
-

2.13 Algorithms

+
+

2.13 Algorithms

Reducing the scaling of an algorithm usually implies also reducing @@ -783,7 +783,7 @@ implemented adapted to different problem sizes.

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_ao.html b/qmckl_ao.html index 9d74044..e995529 100644 --- a/qmckl_ao.html +++ b/qmckl_ao.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Atomic Orbitals @@ -333,52 +333,60 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Context

+
+

1 Context

The following arrays are stored in the context: @@ -387,6 +395,88 @@ The following arrays are stored in the context: +++ ++ ++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
type Gaussian ('G') or Slater ('S')
shell_num Number of shells
prim_num Total number of primitives
nucleus_index[nucl_num]Index of the first shell of each nucleus
shell_ang_mom[shell_num]Angular momentum of each shell
shell_prim_num[shell_num]Number of primitives in each shell
shell_prim_index[shell_num]Address of the first primitive of each shell in the EXPONENT array
shell_factor[shell_num]Normalization factor for each shell
exponent[prim_num]Array of exponents
coefficient[prim_num]Array of coefficients
prim_factor[prim_num]Normalization factors of the primtives
+ +

+Computed data +

+ + + @@ -396,69 +486,21 @@ The following arrays are stored in the context: - - - - - - - - - - - - - - - - - - - + - + - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + @@ -547,8 +589,8 @@ prim_factor = [ 1.0006253235944540e+01, 2.4169531573445120e+00, 7.96109248497664 -
-

1.1 Data structure

+
+

1.1 Data structure

typedef struct qmckl_ao_basis_struct {
@@ -559,11 +601,14 @@ prim_factor = [ 1.0006253235944540e+01, 2.4169531573445120e+00, 7.96109248497664
   int64_t * nucleus_shell_num;
   int32_t * shell_ang_mom;
   int64_t * shell_prim_num;
+  int64_t * nucleus_prim_index;
   int64_t * shell_prim_index;
   double  * shell_factor;
   double  * exponent    ;
   double  * coefficient ;
   double  * prim_factor ;
+  double  * primitive_vgl;
+  int64_t   primitive_vgl_date;
   bool      provided;
   char      type;
 } qmckl_ao_basis_struct;
@@ -572,15 +617,44 @@ prim_factor = [ 1.0006253235944540e+01, 2.4169531573445120e+00, 7.96109248497664
 
 

The uninitialized integer contains one bit set to one for each -initialization function which has not bee called. It becomes equal +initialization function which has not been called. It becomes equal to zero after all initialization functions have been called. The struct is then initialized and provided == true. +Some values are initialized by default, and are not concerned by +this mechanism.

+ +
+
qmckl_exit_code qmckl_init_ao_basis(qmckl_context context);
+
+
+ +
+
qmckl_exit_code qmckl_init_ao_basis(qmckl_context context) {
+
+  if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
+    return false;
+  }
+
+  qmckl_context_struct* const ctx = (qmckl_context_struct* const) context;
+  assert (ctx != NULL);
+
+  ctx->ao_basis.uninitialized = (1 << 12) - 1;
+
+  /* Default values */
+  /* ctx->ao_basis.
+     */
+
+  return QMCKL_SUCCESS;
+}
+
+
-
-

1.2 Access functions

+ +
+

1.2 Access functions

When all the data for the AOs have been provided, the following @@ -594,8 +668,8 @@ function returns true.

-
-

1.3 Initialization functions

+
+

1.3 Initialization functions

To set the basis set, all the following functions need to be @@ -630,655 +704,19 @@ the context.

-
-

1.4 TODO Fortran interfaces

+
+

1.4 TODO Fortran interfaces

-
-

2 Polynomial part

+
+

2 Radial part

-
-

2.1 Powers of \(x-X_i\)

+
+

2.1 General functions for Gaussian basis functions

-The qmckl_ao_power function computes all the powers of the n -input data up to the given maximum value given in input for each of -the \(n\) points: -

- -

-\[ P_{ik} = X_i^k \] -

- -
type Gaussian ('G') or Slater ('S')
shell_num Number of shells
prim_num Total number of primitives
nucleus_indexnucleus_prim_index [nucl_num]Index of the first shell of each nucleusIndex of the first primitive for each nucleus
shell_ang_mom[shell_num]Angular momentum of each shellprimitive_vgl[prim_num][5][walk_num][elec_num]Value, gradients, Laplacian of the primitives at electron positions
shell_prim_num[shell_num]Number of primitives in each shell
shell_prim_index[shell_num]Address of the first primitive of each shell in the EXPONENT array
shell_factor[shell_num]Normalization factor for each shell
exponent[prim_num]Array of exponents
coefficient[prim_num]Array of coefficients
prim_factor[prim_num]Normalization factors of the primtivesprimitive_vgl_dateuint64_tLate modification date of Value, gradients, Laplacian of the primitives at electron positions
- - --- -- -- -- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
qmcklcontextcontextinGlobal state
int64tninNumber of values
doubleX[n]inArray containing the input values
int32tLMAX[n]inArray containing the maximum power for each value
doubleP[n][ldp]outArray containing all the powers of X
int64tldpinLeading dimension of array P
-
- -
-

2.1.1 Requirements

-
-
    -
  • context is not QMCKL_NULL_CONTEXT
  • -
  • n > 0
  • -
  • X is allocated with at least \(n \times 8\) bytes
  • -
  • LMAX is allocated with at least \(n \times 4\) bytes
  • -
  • P is allocated with at least \(n \times \max_i \text{LMAX}_i \times 8\) bytes
  • -
  • LDP >= \(\max_i\) LMAX[i]
  • -
-
-
- -
-

2.1.2 C Header

-
-
-
qmckl_exit_code qmckl_ao_power (
-              const qmckl_context context,
-      const int64_t n,
-      const double* X,
-      const int32_t* LMAX,
-      double* const P,
-      const int64_t ldp ); 
-
-
-
-
- -
-

2.1.3 Source

-
-
-
integer function qmckl_ao_power_f(context, n, X, LMAX, P, ldp) result(info)
-  use qmckl
-  implicit none
-  integer*8 , intent(in)  :: context
-  integer*8 , intent(in)  :: n
-  real*8    , intent(in)  :: X(n)
-  integer   , intent(in)  :: LMAX(n)
-  real*8    , intent(out) :: P(ldp,n)
-  integer*8 , intent(in)  :: ldp
-
-  integer*8  :: i,k
-
-  info = QMCKL_SUCCESS
-
-  if (context == QMCKL_NULL_CONTEXT) then
-     info = QMCKL_INVALID_CONTEXT
-     return
-  endif
-
-  if (n <= ldp) then
-     info = QMCKL_INVALID_ARG_2
-     return
-  endif
-
-  k = MAXVAL(LMAX)
-  if (LDP < k) then
-     info = QMCKL_INVALID_ARG_6
-     return
-  endif
-
-  if (k <= 0) then
-     info = QMCKL_INVALID_ARG_4
-     return
-  endif
-
-  do i=1,n
-     P(1,i) = X(i)
-     do k=2,LMAX(i)
-        P(k,i) = P(k-1,i) * X(i)
-     end do
-  end do
-
-end function qmckl_ao_power_f
-
-
-
-
- -
-

2.1.4 C interface

-
-
-

2.1.5 Fortran interface

-
- -
-

2.1.6 Test

-
-
-
integer(c_int32_t) function test_qmckl_ao_power(context) bind(C)
-  use qmckl
-  implicit none
-
-  integer(qmckl_context), intent(in), value :: context
-
-  integer*8                     :: n, LDP
-  integer, allocatable          :: LMAX(:)
-  double precision, allocatable :: X(:), P(:,:)
-  integer*8                     :: i,j
-  double precision              :: epsilon
-
-  epsilon = qmckl_get_numprec_epsilon(context)
-
-  n = 100;
-  LDP = 10;
-
-  allocate(X(n), P(LDP,n), LMAX(n))
-
-  do j=1,n
-     X(j) = -5.d0 + 0.1d0 * dble(j)
-     LMAX(j) = 1 + int(mod(j, 5),4)
-  end do
-
-  test_qmckl_ao_power = qmckl_ao_power(context, n, X, LMAX, P, LDP)
-  if (test_qmckl_ao_power /= QMCKL_SUCCESS) return
-
-  test_qmckl_ao_power = QMCKL_FAILURE
-
-  do j=1,n
-     do i=1,LMAX(j)
-        if ( X(j)**i == 0.d0 ) then
-           if ( P(i,j) /= 0.d0) return
-        else
-           if ( dabs(1.d0 - P(i,j) / (X(j)**i)) > epsilon ) return
-        end if
-     end do
-  end do
-
-  test_qmckl_ao_power = QMCKL_SUCCESS
-  deallocate(X,P,LMAX)
-end function test_qmckl_ao_power
-
-
-
-
-
- -
-

2.2 Value, Gradient and Laplacian of a polynomial

-
-

-A polynomial is centered on a nucleus \(\mathbf{R}_i\) -

- -

-\[ - P_l(\mathbf{r},\mathbf{R}_i) = (x-X_i)^a (y-Y_i)^b (z-Z_i)^c - \] -

- -

-The gradients with respect to electron coordinates are -

- -\begin{eqnarray*} -\frac{\partial }{\partial x} P_l\left(\mathbf{r},\mathbf{R}_i \right) & - = & a (x-X_i)^{a-1} (y-Y_i)^b (z-Z_i)^c \\ -\frac{\partial }{\partial y} P_l\left(\mathbf{r},\mathbf{R}_i \right) & - = & b (x-X_i)^a (y-Y_i)^{b-1} (z-Z_i)^c \\ -\frac{\partial }{\partial z} P_l\left(\mathbf{r},\mathbf{R}_i \right) & - = & c (x-X_i)^a (y-Y_i)^b (z-Z_i)^{c-1} \\ -\end{eqnarray*} - -

-and the Laplacian is -

- -\begin{eqnarray*} -\left( \frac{\partial }{\partial x^2} + - \frac{\partial }{\partial y^2} + - \frac{\partial }{\partial z^2} \right) P_l - \left(\mathbf{r},\mathbf{R}_i \right) & = & - a(a-1) (x-X_i)^{a-2} (y-Y_i)^b (z-Z_i)^c + \\ - && b(b-1) (x-X_i)^a (y-Y_i)^{b-1} (z-Z_i)^c + \\ - && c(c-1) (x-X_i)^a (y-Y_i)^b (z-Z_i)^{c-1}. -\end{eqnarray*} - -

-qmckl_ao_polynomial_vgl computes the values, gradients and -Laplacians at a given point in space, of all polynomials with an -angular momentum up to lmax. -

- - - - --- -- -- -- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
qmcklcontextcontextinGlobal state
doubleX[3]inArray containing the coordinates of the points
doubleR[3]inArray containing the x,y,z coordinates of the center
int32tlmaxinMaximum angular momentum
int64tninoutNumber of computed polynomials
int32tL[n][ldl]outContains a,b,c for all n results
int64tldlinLeading dimension of L
doubleVGL[n][ldv]outValue, gradients and Laplacian of the polynomials
int64tldvinLeading dimension of array VGL
-
- -
-

2.2.1 Requirements

-
-
    -
  • context is not QMCKL_NULL_CONTEXT
  • -
  • n > 0
  • -
  • lmax >= 0
  • -
  • ldl >= 3
  • -
  • ldv >= 5
  • -
  • X is allocated with at least \(3 \times 8\) bytes
  • -
  • R is allocated with at least \(3 \times 8\) bytes
  • -
  • n >= (lmax+1)(lmax+2)(lmax+3)/6
  • -
  • L is allocated with at least \(3 \times n \times 4\) bytes
  • -
  • VGL is allocated with at least \(5 \times n \times 8\) bytes
  • -
  • On output, n should be equal to (lmax+1)(lmax+2)(lmax+3)/6
  • -
  • On output, the powers are given in the following order (l=a+b+c): -
      -
    • Increasing values of l
    • -
    • Within a given value of l, alphabetical order of the -string made by a*"x" + b*"y" + c*"z" (in Python notation). -For example, with a=0, b=2 and c=1 the string is "yyz"
    • -
  • -
-
-
- -
-

2.2.2 C Header

-
-
-
qmckl_exit_code qmckl_ao_polynomial_vgl (
-              const qmckl_context context,
-      const double* X,
-      const double* R,
-      const int32_t lmax,
-      int64_t* n,
-      int32_t* const L,
-      const int64_t ldl,
-      double* const VGL,
-      const int64_t ldv ); 
-
-
-
-
- -
-

2.2.3 Source

-
-
-
integer function qmckl_ao_polynomial_vgl_f(context, X, R, lmax, n, L, ldl, VGL, ldv) result(info)
-  use qmckl
-  implicit none
-  integer*8 , intent(in)  :: context
-  real*8    , intent(in)  :: X(3), R(3)
-  integer   , intent(in)  :: lmax
-  integer*8 , intent(out) :: n
-  integer   , intent(out) :: L(ldl,(lmax+1)*(lmax+2)*(lmax+3)/6)
-  integer*8 , intent(in)  :: ldl
-  real*8    , intent(out) :: VGL(ldv,(lmax+1)*(lmax+2)*(lmax+3)/6)
-  integer*8 , intent(in)  :: ldv
-
-  integer*8         :: i,j
-  integer           :: a,b,c,d
-  real*8            :: Y(3)
-  integer           :: lmax_array(3)
-  real*8            :: pows(-2:lmax,3)
-  integer, external :: qmckl_ao_power_f
-  double precision  :: xy, yz, xz
-  double precision  :: da, db, dc, dd
-
-  info = 0
-
-  if (context == QMCKL_NULL_CONTEXT) then
-     info = QMCKL_INVALID_CONTEXT
-     return
-  endif
-
-  if (lmax < 0) then
-     info = QMCKL_INVALID_ARG_4
-     return
-  endif
-
-  if (ldl < 3) then
-     info = QMCKL_INVALID_ARG_7
-     return
-  endif
-
-  if (ldv < 5) then
-     info = QMCKL_INVALID_ARG_9
-     return
-  endif
-
-
-  do i=1,3
-     Y(i) = X(i) - R(i)
-  end do
-
-  lmax_array(1:3) = lmax
-  if (lmax == 0) then
-     VGL(1,1) = 1.d0
-     vgL(2:5,1) = 0.d0
-     l(1:3,1) = 0
-     n=1
-  else if (lmax > 0) then
-     pows(-2:0,1:3) = 1.d0
-     do i=1,lmax
-        pows(i,1) = pows(i-1,1) * Y(1)
-        pows(i,2) = pows(i-1,2) * Y(2)
-        pows(i,3) = pows(i-1,3) * Y(3)
-     end do
-
-     VGL(1:5,1:4) = 0.d0
-     l  (1:3,1:4) = 0
-
-     VGL(1  ,1  ) = 1.d0
-     vgl(1:5,2:4) = 0.d0
-
-     l  (1,2) = 1
-     vgl(1,2) = pows(1,1)
-     vgL(2,2) = 1.d0
-
-     l  (2,3) = 1
-     vgl(1,3) = pows(1,2)
-     vgL(3,3) = 1.d0
-
-     l  (3,4) = 1
-     vgl(1,4) = pows(1,3)
-     vgL(4,4) = 1.d0
-
-     n=4
-  endif
-
-  ! l>=2
-  dd = 2.d0
-  do d=2,lmax
-     da = dd
-     do a=d,0,-1
-        db = dd-da
-        do b=d-a,0,-1
-           c  = d  - a  - b
-           dc = dd - da - db
-           n = n+1
-
-           l(1,n) = a
-           l(2,n) = b
-           l(3,n) = c
-
-           xy = pows(a,1) * pows(b,2)
-           yz = pows(b,2) * pows(c,3)
-           xz = pows(a,1) * pows(c,3)
-
-           vgl(1,n) = xy * pows(c,3)
-
-           xy = dc * xy
-           xz = db * xz
-           yz = da * yz
-
-           vgl(2,n) = pows(a-1,1) * yz
-           vgl(3,n) = pows(b-1,2) * xz
-           vgl(4,n) = pows(c-1,3) * xy
-
-           vgl(5,n) = &
-                (da-1.d0) * pows(a-2,1) * yz + &
-                (db-1.d0) * pows(b-2,2) * xz + &
-                (dc-1.d0) * pows(c-2,3) * xy
-
-           db = db - 1.d0
-        end do
-        da = da - 1.d0
-     end do
-     dd = dd + 1.d0
-  end do
-
-  info = QMCKL_SUCCESS
-
-end function qmckl_ao_polynomial_vgl_f
-
-
-
-
- -
-

2.2.4 C interface

-
- -
-

2.2.5 Fortran interface

-
- -
-

2.2.6 Test

-
-
-
integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C)
-  use qmckl
-  implicit none
-
-  integer(c_int64_t), intent(in), value :: context
-
-  integer                       :: lmax, d, i
-  integer, allocatable          :: L(:,:)
-  integer*8                     :: n, ldl, ldv, j
-  double precision              :: X(3), R(3), Y(3)
-  double precision, allocatable :: VGL(:,:)
-  double precision              :: w
-  double precision              :: epsilon
-
-  epsilon = qmckl_get_numprec_epsilon(context)
-
-  X = (/ 1.1 , 2.2 ,  3.3 /)
-  R = (/ 0.1 , 1.2 , -2.3 /)
-  Y(:) = X(:) - R(:)
-
-  lmax = 4;
-  ldl = 3;
-  ldv = 100;
-
-  d = (lmax+1)*(lmax+2)*(lmax+3)/6
-
-  allocate (L(ldl,d), VGL(ldv,d))
-
-  test_qmckl_ao_polynomial_vgl = &
-       qmckl_ao_polynomial_vgl(context, X, R, lmax, n, L, ldl, VGL, ldv)
-
-  if (test_qmckl_ao_polynomial_vgl /= QMCKL_SUCCESS) return
-  if (n /= d) return
-
-  do j=1,n
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     do i=1,3
-        if (L(i,j) < 0) return
-     end do
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     if (dabs(1.d0 - VGL(1,j) / (&
-          Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**L(3,j)  &
-          )) > epsilon ) return
-
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     if (L(1,j) < 1) then
-        if (VGL(2,j) /= 0.d0) return
-     else
-        if (dabs(1.d0 - VGL(2,j) / (&
-             L(1,j) * Y(1)**(L(1,j)-1) * Y(2)**L(2,j) * Y(3)**L(3,j) &
-             )) > epsilon ) return
-     end if
-
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     if (L(2,j) < 1) then
-        if (VGL(3,j) /= 0.d0) return
-     else
-        if (dabs(1.d0 - VGL(3,j) / (&
-             L(2,j) * Y(1)**L(1,j) * Y(2)**(L(2,j)-1) * Y(3)**L(3,j) &
-             )) > epsilon ) return
-     end if
-
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     if (L(3,j) < 1) then
-        if (VGL(4,j) /= 0.d0) return
-     else
-        if (dabs(1.d0 - VGL(4,j) / (&
-             L(3,j) * Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**(L(3,j)-1) &
-             )) > epsilon ) return
-     end if
-
-     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
-     w = 0.d0
-     if (L(1,j) > 1) then
-        w = w + L(1,j) * (L(1,j)-1) * Y(1)**(L(1,j)-2) * Y(2)**L(2,j) * Y(3)**L(3,j)
-     end if
-     if (L(2,j) > 1) then
-        w = w + L(2,j) * (L(2,j)-1) * Y(1)**L(1,j) * Y(2)**(L(2,j)-2) * Y(3)**L(3,j)
-     end if
-     if (L(3,j) > 1) then
-        w = w + L(3,j) * (L(3,j)-1) * Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**(L(3,j)-2)
-     end if
-     if (dabs(1.d0 - VGL(5,j) / w) > epsilon ) return
-  end do
-
-  test_qmckl_ao_polynomial_vgl = QMCKL_SUCCESS
-
-  deallocate(L,VGL)
-end function test_qmckl_ao_polynomial_vgl
-
-
- -
-
int  test_qmckl_ao_polynomial_vgl(qmckl_context context);
-assert(0 == test_qmckl_ao_polynomial_vgl(context));
-
-
-
-
-
-
- -
-

3 Radial part

-
-
-
-

3.1 Gaussian basis functions

-
-

qmckl_ao_gaussian_vgl computes the values, gradients and Laplacians at a given point of n Gaussian functions centered at the same point: @@ -1508,20 +946,892 @@ Requirements

-
-

3.2 TODO Slater basis functions

+
+

2.2 TODO General functions for Slater basis functions

-
-

3.3 TODO Radial functions on a grid

+
+

2.3 TODO General functions for Radial functions on a grid

+
+
+

2.4 Computation of primitives

+
+
+
+

2.4.1 Get

+
+
+
qmckl_exit_code qmckl_get_ao_basis_primitive_vgl(qmckl_context context, double* const primitive_vgl);
+
-
-

4 Combining radial and polynomial parts

+
+ +
+

2.4.2 Provide

+
+ +
+

2.4.3 Compute

+
+ + + +++ ++ ++ ++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
qmcklcontextcontextinGlobal state
int64tprimnuminNumber of primitives
int64telecnuminNumber of electrons
int64tnuclnuminNumber of nuclei
int64twalknuminNumber of walkers
int64tnucleusprimindex[nuclnum]inIndex of the 1st primitive of each nucleus
doubleeleccoord[walknum][3][elecnum]inElectron coordinates
doublenuclcoord[3][elecnum]inNuclear coordinates
doubleexpo[primnum]inExponents of the primitives
doubleprimitivevgl[primnum][5][walknum][elecnum]outValue, gradients and Laplacian of the primitives
+ +
+
integer function qmckl_compute_ao_basis_primitive_gaussian_vgl_f(context, &
+     prim_num, elec_num, nucl_num, walk_num, &
+     nucleus_prim_index, elec_coord, nucl_coord, expo, primitive_vgl) &
+     result(info)
+  use qmckl
+  implicit none
+  integer(qmckl_context), intent(in)  :: context
+  integer*8             , intent(in)  :: prim_num
+  integer*8             , intent(in)  :: nucl_num
+  integer*8             , intent(in)  :: elec_num
+  integer*8             , intent(in)  :: walk_num
+  integer*8             , intent(in)  :: nucleus_prim_index(nucl_num+1)
+  double precision      , intent(in)  :: elec_coord(elec_num,3,walk_num)
+  double precision      , intent(in)  :: nucl_coord(nucl_num,3)
+  double precision      , intent(in)  :: expo(prim_num)
+  double precision      , intent(out) :: primitive_vgl(elec_num,walk_num,5,prim_num)
+
+  integer*8 :: inucl, iprim, iwalk, ielec
+  double precision :: x, y, z, two_a, ar2, r2, v
+  double precision :: r2_cut(elec_num,walk_num)
+
+  info = QMCKL_SUCCESS
+
+  if (context == QMCKL_NULL_CONTEXT) then
+     info = QMCKL_INVALID_CONTEXT
+     return
+  endif
+
+  if (prim_num <= 0) then
+     info = QMCKL_INVALID_ARG_2
+     return
+  endif
+
+  if (elec_num <= 0) then
+     info = QMCKL_INVALID_ARG_4
+     return
+  endif
+
+  if (nucl_num <= 0) then
+     info = QMCKL_INVALID_ARG_5
+     return
+  endif
+
+  if (walk_num <= 0) then
+     info = QMCKL_INVALID_ARG_6
+     return
+  endif
+
+  do inucl=1,nucl_num
+     ! C is zero-based, so shift bounds by one
+     do iprim = nucleus_prim_index(inucl)+1, nucleus_prim_index(inucl+1)
+        do iwalk = 1, walk_num
+           do ielec = 1, elec_num
+              x = elec_coord(ielec,1,iwalk) - nucl_coord(inucl,1) 
+              y = elec_coord(ielec,2,iwalk) - nucl_coord(inucl,2) 
+              z = elec_coord(ielec,3,iwalk) - nucl_coord(inucl,3) 
+
+              r2 = x*x + y*y + z*z
+              ar2 = expo(iprim)*r2
+              v = dexp(-ar2)
+              two_a = -2.d0 * expo(iprim) * v
+
+              primitive_vgl(ielec, iwalk, 1, iprim) = v
+              primitive_vgl(ielec, iwalk, 2, iprim) = two_a * x 
+              primitive_vgl(ielec, iwalk, 3, iprim) = two_a * y
+              primitive_vgl(ielec, iwalk, 4, iprim) = two_a * z
+              primitive_vgl(ielec, iwalk, 5, iprim) = two_a * (3.d0 - 2.d0*ar2)
+
+           end do
+        end do
+     end do
+  end do
+
+end function qmckl_compute_ao_basis_primitive_gaussian_vgl_f
+
+
+
+
+ +
+

2.4.4 Test

+
+
+
#define walk_num chbrclf_walk_num
+#define elec_num chbrclf_elec_num
+#define prim_num chbrclf_prim_num
+
+int64_t elec_up_num   = chbrclf_elec_up_num;
+int64_t elec_dn_num   = chbrclf_elec_dn_num;
+double* elec_coord    = &(chbrclf_elec_coord[0][0][0]);
+
+rc = qmckl_set_electron_num (context, elec_up_num, elec_dn_num);  
+assert (rc == QMCKL_SUCCESS);
+
+rc = qmckl_set_electron_walk_num (context, walk_num);
+assert (rc == QMCKL_SUCCESS);
+
+assert(qmckl_electron_provided(context));
+
+rc = qmckl_set_electron_coord (context, 'N', elec_coord);                                     
+assert(rc == QMCKL_SUCCESS);
+
+
+
+double prim_vgl[prim_num][5][walk_num][elec_num];
+
+rc = qmckl_get_ao_basis_primitive_vgl(context, &(prim_vgl[0][0][0][0]));
+assert (rc == QMCKL_SUCCESS);
+
+assert( fabs(prim_vgl[7][0][0][26] - ( 1.0501570432064878E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[7][1][0][26] - (-7.5014974095310560E-004)) < 1.e-14 );
+assert( fabs(prim_vgl[7][2][0][26] - (-3.8250692897610380E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[7][3][0][26] - ( 3.4950559194080275E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[7][4][0][26] - ( 2.0392163767356572E-002)) < 1.e-14 );
+
+assert( fabs(prim_vgl[39][0][1][15] - ( 1.0825844173157661E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[39][1][1][15] - ( 2.3774237611651531E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[39][2][1][15] - ( 2.1423191526963063E-003)) < 1.e-14 );
+assert( fabs(prim_vgl[39][3][1][15] - ( 4.3312003523048492E-004)) < 1.e-14 );
+assert( fabs(prim_vgl[39][4][1][15] - ( 7.5174404780004771E-003)) < 1.e-14 );
+
+
+
+
+
+
+
+
+
+
+
+

3 Polynomial part

+
+
+
+

3.1 General functions for Powers of \(x-X_i\)

+
+

+The qmckl_ao_power function computes all the powers of the n +input data up to the given maximum value given in input for each of +the \(n\) points: +

+ +

+\[ P_{ik} = X_i^k \] +

+ + + + +++ ++ ++ ++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
qmcklcontextcontextinGlobal state
int64tninNumber of values
doubleX[n]inArray containing the input values
int32tLMAX[n]inArray containing the maximum power for each value
doubleP[n][ldp]outArray containing all the powers of X
int64tldpinLeading dimension of array P
+
+ +
+

3.1.1 Requirements

+
+
    +
  • context is not QMCKL_NULL_CONTEXT
  • +
  • n > 0
  • +
  • X is allocated with at least \(n \times 8\) bytes
  • +
  • LMAX is allocated with at least \(n \times 4\) bytes
  • +
  • P is allocated with at least \(n \times \max_i \text{LMAX}_i \times 8\) bytes
  • +
  • LDP >= \(\max_i\) LMAX[i]
  • +
+
+
+ +
+

3.1.2 C Header

+
+
+
qmckl_exit_code qmckl_ao_power (
+              const qmckl_context context,
+      const int64_t n,
+      const double* X,
+      const int32_t* LMAX,
+      double* const P,
+      const int64_t ldp ); 
+
+
+
+
+ +
+

3.1.3 Source

+
+
+
integer function qmckl_ao_power_f(context, n, X, LMAX, P, ldp) result(info)
+  use qmckl
+  implicit none
+  integer*8 , intent(in)  :: context
+  integer*8 , intent(in)  :: n
+  real*8    , intent(in)  :: X(n)
+  integer   , intent(in)  :: LMAX(n)
+  real*8    , intent(out) :: P(ldp,n)
+  integer*8 , intent(in)  :: ldp
+
+  integer*8  :: i,k
+
+  info = QMCKL_SUCCESS
+
+  if (context == QMCKL_NULL_CONTEXT) then
+     info = QMCKL_INVALID_CONTEXT
+     return
+  endif
+
+  if (n <= ldp) then
+     info = QMCKL_INVALID_ARG_2
+     return
+  endif
+
+  k = MAXVAL(LMAX)
+  if (LDP < k) then
+     info = QMCKL_INVALID_ARG_6
+     return
+  endif
+
+  if (k <= 0) then
+     info = QMCKL_INVALID_ARG_4
+     return
+  endif
+
+  do i=1,n
+     P(1,i) = X(i)
+     do k=2,LMAX(i)
+        P(k,i) = P(k-1,i) * X(i)
+     end do
+  end do
+
+end function qmckl_ao_power_f
+
+
+
+
+ +
+

3.1.4 C interface

+
+
+

3.1.5 Fortran interface

+
+ +
+

3.1.6 Test

+
+
+
integer(c_int32_t) function test_qmckl_ao_power(context) bind(C)
+  use qmckl
+  implicit none
+
+  integer(qmckl_context), intent(in), value :: context
+
+  integer*8                     :: n, LDP
+  integer, allocatable          :: LMAX(:)
+  double precision, allocatable :: X(:), P(:,:)
+  integer*8                     :: i,j
+  double precision              :: epsilon
+
+  epsilon = qmckl_get_numprec_epsilon(context)
+
+  n = 100;
+  LDP = 10;
+
+  allocate(X(n), P(LDP,n), LMAX(n))
+
+  do j=1,n
+     X(j) = -5.d0 + 0.1d0 * dble(j)
+     LMAX(j) = 1 + int(mod(j, 5),4)
+  end do
+
+  test_qmckl_ao_power = qmckl_ao_power(context, n, X, LMAX, P, LDP)
+  if (test_qmckl_ao_power /= QMCKL_SUCCESS) return
+
+  test_qmckl_ao_power = QMCKL_FAILURE
+
+  do j=1,n
+     do i=1,LMAX(j)
+        if ( X(j)**i == 0.d0 ) then
+           if ( P(i,j) /= 0.d0) return
+        else
+           if ( dabs(1.d0 - P(i,j) / (X(j)**i)) > epsilon ) return
+        end if
+     end do
+  end do
+
+  test_qmckl_ao_power = QMCKL_SUCCESS
+  deallocate(X,P,LMAX)
+end function test_qmckl_ao_power
+
+
+
+
+
+ +
+

3.2 General functions for Value, Gradient and Laplacian of a polynomial

+
+

+A polynomial is centered on a nucleus \(\mathbf{R}_i\) +

+ +

+\[ + P_l(\mathbf{r},\mathbf{R}_i) = (x-X_i)^a (y-Y_i)^b (z-Z_i)^c + \] +

+ +

+The gradients with respect to electron coordinates are +

+ +\begin{eqnarray*} +\frac{\partial }{\partial x} P_l\left(\mathbf{r},\mathbf{R}_i \right) & + = & a (x-X_i)^{a-1} (y-Y_i)^b (z-Z_i)^c \\ +\frac{\partial }{\partial y} P_l\left(\mathbf{r},\mathbf{R}_i \right) & + = & b (x-X_i)^a (y-Y_i)^{b-1} (z-Z_i)^c \\ +\frac{\partial }{\partial z} P_l\left(\mathbf{r},\mathbf{R}_i \right) & + = & c (x-X_i)^a (y-Y_i)^b (z-Z_i)^{c-1} \\ +\end{eqnarray*} + +

+and the Laplacian is +

+ +\begin{eqnarray*} +\left( \frac{\partial }{\partial x^2} + + \frac{\partial }{\partial y^2} + + \frac{\partial }{\partial z^2} \right) P_l + \left(\mathbf{r},\mathbf{R}_i \right) & = & + a(a-1) (x-X_i)^{a-2} (y-Y_i)^b (z-Z_i)^c + \\ + && b(b-1) (x-X_i)^a (y-Y_i)^{b-1} (z-Z_i)^c + \\ + && c(c-1) (x-X_i)^a (y-Y_i)^b (z-Z_i)^{c-1}. +\end{eqnarray*} + +

+qmckl_ao_polynomial_vgl computes the values, gradients and +Laplacians at a given point in space, of all polynomials with an +angular momentum up to lmax. +

+ + + + +++ ++ ++ ++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
qmcklcontextcontextinGlobal state
doubleX[3]inArray containing the coordinates of the points
doubleR[3]inArray containing the x,y,z coordinates of the center
int32tlmaxinMaximum angular momentum
int64tninoutNumber of computed polynomials
int32tL[n][ldl]outContains a,b,c for all n results
int64tldlinLeading dimension of L
doubleVGL[n][ldv]outValue, gradients and Laplacian of the polynomials
int64tldvinLeading dimension of array VGL
+
+ +
+

3.2.1 Requirements

+
+
    +
  • context is not QMCKL_NULL_CONTEXT
  • +
  • n > 0
  • +
  • lmax >= 0
  • +
  • ldl >= 3
  • +
  • ldv >= 5
  • +
  • X is allocated with at least \(3 \times 8\) bytes
  • +
  • R is allocated with at least \(3 \times 8\) bytes
  • +
  • n >= (lmax+1)(lmax+2)(lmax+3)/6
  • +
  • L is allocated with at least \(3 \times n \times 4\) bytes
  • +
  • VGL is allocated with at least \(5 \times n \times 8\) bytes
  • +
  • On output, n should be equal to (lmax+1)(lmax+2)(lmax+3)/6
  • +
  • On output, the powers are given in the following order (l=a+b+c): +
      +
    • Increasing values of l
    • +
    • Within a given value of l, alphabetical order of the +string made by a*"x" + b*"y" + c*"z" (in Python notation). +For example, with a=0, b=2 and c=1 the string is "yyz"
    • +
  • +
+
+
+ +
+

3.2.2 C Header

+
+
+
qmckl_exit_code qmckl_ao_polynomial_vgl (
+              const qmckl_context context,
+      const double* X,
+      const double* R,
+      const int32_t lmax,
+      int64_t* n,
+      int32_t* const L,
+      const int64_t ldl,
+      double* const VGL,
+      const int64_t ldv ); 
+
+
+
+
+ +
+

3.2.3 Source

+
+
+
integer function qmckl_ao_polynomial_vgl_f(context, X, R, lmax, n, L, ldl, VGL, ldv) result(info)
+  use qmckl
+  implicit none
+  integer*8 , intent(in)  :: context
+  real*8    , intent(in)  :: X(3), R(3)
+  integer   , intent(in)  :: lmax
+  integer*8 , intent(out) :: n
+  integer   , intent(out) :: L(ldl,(lmax+1)*(lmax+2)*(lmax+3)/6)
+  integer*8 , intent(in)  :: ldl
+  real*8    , intent(out) :: VGL(ldv,(lmax+1)*(lmax+2)*(lmax+3)/6)
+  integer*8 , intent(in)  :: ldv
+
+  integer*8         :: i,j
+  integer           :: a,b,c,d
+  real*8            :: Y(3)
+  integer           :: lmax_array(3)
+  real*8            :: pows(-2:lmax,3)
+  integer, external :: qmckl_ao_power_f
+  double precision  :: xy, yz, xz
+  double precision  :: da, db, dc, dd
+
+  info = 0
+
+  if (context == QMCKL_NULL_CONTEXT) then
+     info = QMCKL_INVALID_CONTEXT
+     return
+  endif
+
+  if (lmax < 0) then
+     info = QMCKL_INVALID_ARG_4
+     return
+  endif
+
+  if (ldl < 3) then
+     info = QMCKL_INVALID_ARG_7
+     return
+  endif
+
+  if (ldv < 5) then
+     info = QMCKL_INVALID_ARG_9
+     return
+  endif
+
+
+  do i=1,3
+     Y(i) = X(i) - R(i)
+  end do
+
+  lmax_array(1:3) = lmax
+  if (lmax == 0) then
+     VGL(1,1) = 1.d0
+     vgL(2:5,1) = 0.d0
+     l(1:3,1) = 0
+     n=1
+  else if (lmax > 0) then
+     pows(-2:0,1:3) = 1.d0
+     do i=1,lmax
+        pows(i,1) = pows(i-1,1) * Y(1)
+        pows(i,2) = pows(i-1,2) * Y(2)
+        pows(i,3) = pows(i-1,3) * Y(3)
+     end do
+
+     VGL(1:5,1:4) = 0.d0
+     l  (1:3,1:4) = 0
+
+     VGL(1  ,1  ) = 1.d0
+     vgl(1:5,2:4) = 0.d0
+
+     l  (1,2) = 1
+     vgl(1,2) = pows(1,1)
+     vgL(2,2) = 1.d0
+
+     l  (2,3) = 1
+     vgl(1,3) = pows(1,2)
+     vgL(3,3) = 1.d0
+
+     l  (3,4) = 1
+     vgl(1,4) = pows(1,3)
+     vgL(4,4) = 1.d0
+
+     n=4
+  endif
+
+  ! l>=2
+  dd = 2.d0
+  do d=2,lmax
+     da = dd
+     do a=d,0,-1
+        db = dd-da
+        do b=d-a,0,-1
+           c  = d  - a  - b
+           dc = dd - da - db
+           n = n+1
+
+           l(1,n) = a
+           l(2,n) = b
+           l(3,n) = c
+
+           xy = pows(a,1) * pows(b,2)
+           yz = pows(b,2) * pows(c,3)
+           xz = pows(a,1) * pows(c,3)
+
+           vgl(1,n) = xy * pows(c,3)
+
+           xy = dc * xy
+           xz = db * xz
+           yz = da * yz
+
+           vgl(2,n) = pows(a-1,1) * yz
+           vgl(3,n) = pows(b-1,2) * xz
+           vgl(4,n) = pows(c-1,3) * xy
+
+           vgl(5,n) = &
+                (da-1.d0) * pows(a-2,1) * yz + &
+                (db-1.d0) * pows(b-2,2) * xz + &
+                (dc-1.d0) * pows(c-2,3) * xy
+
+           db = db - 1.d0
+        end do
+        da = da - 1.d0
+     end do
+     dd = dd + 1.d0
+  end do
+
+  info = QMCKL_SUCCESS
+
+end function qmckl_ao_polynomial_vgl_f
+
+
+
+
+ +
+

3.2.4 C interface

+
+ +
+

3.2.5 Fortran interface

+
+ +
+

3.2.6 Test

+
+
+
integer(c_int32_t) function test_qmckl_ao_polynomial_vgl(context) bind(C)
+  use qmckl
+  implicit none
+
+  integer(c_int64_t), intent(in), value :: context
+
+  integer                       :: lmax, d, i
+  integer, allocatable          :: L(:,:)
+  integer*8                     :: n, ldl, ldv, j
+  double precision              :: X(3), R(3), Y(3)
+  double precision, allocatable :: VGL(:,:)
+  double precision              :: w
+  double precision              :: epsilon
+
+  epsilon = qmckl_get_numprec_epsilon(context)
+
+  X = (/ 1.1 , 2.2 ,  3.3 /)
+  R = (/ 0.1 , 1.2 , -2.3 /)
+  Y(:) = X(:) - R(:)
+
+  lmax = 4;
+  ldl = 3;
+  ldv = 100;
+
+  d = (lmax+1)*(lmax+2)*(lmax+3)/6
+
+  allocate (L(ldl,d), VGL(ldv,d))
+
+  test_qmckl_ao_polynomial_vgl = &
+       qmckl_ao_polynomial_vgl(context, X, R, lmax, n, L, ldl, VGL, ldv)
+
+  if (test_qmckl_ao_polynomial_vgl /= QMCKL_SUCCESS) return
+  if (n /= d) return
+
+  do j=1,n
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     do i=1,3
+        if (L(i,j) < 0) return
+     end do
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     if (dabs(1.d0 - VGL(1,j) / (&
+          Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**L(3,j)  &
+          )) > epsilon ) return
+
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     if (L(1,j) < 1) then
+        if (VGL(2,j) /= 0.d0) return
+     else
+        if (dabs(1.d0 - VGL(2,j) / (&
+             L(1,j) * Y(1)**(L(1,j)-1) * Y(2)**L(2,j) * Y(3)**L(3,j) &
+             )) > epsilon ) return
+     end if
+
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     if (L(2,j) < 1) then
+        if (VGL(3,j) /= 0.d0) return
+     else
+        if (dabs(1.d0 - VGL(3,j) / (&
+             L(2,j) * Y(1)**L(1,j) * Y(2)**(L(2,j)-1) * Y(3)**L(3,j) &
+             )) > epsilon ) return
+     end if
+
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     if (L(3,j) < 1) then
+        if (VGL(4,j) /= 0.d0) return
+     else
+        if (dabs(1.d0 - VGL(4,j) / (&
+             L(3,j) * Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**(L(3,j)-1) &
+             )) > epsilon ) return
+     end if
+
+     test_qmckl_ao_polynomial_vgl = QMCKL_FAILURE
+     w = 0.d0
+     if (L(1,j) > 1) then
+        w = w + L(1,j) * (L(1,j)-1) * Y(1)**(L(1,j)-2) * Y(2)**L(2,j) * Y(3)**L(3,j)
+     end if
+     if (L(2,j) > 1) then
+        w = w + L(2,j) * (L(2,j)-1) * Y(1)**L(1,j) * Y(2)**(L(2,j)-2) * Y(3)**L(3,j)
+     end if
+     if (L(3,j) > 1) then
+        w = w + L(3,j) * (L(3,j)-1) * Y(1)**L(1,j) * Y(2)**L(2,j) * Y(3)**(L(3,j)-2)
+     end if
+     if (dabs(1.d0 - VGL(5,j) / w) > epsilon ) return
+  end do
+
+  test_qmckl_ao_polynomial_vgl = QMCKL_SUCCESS
+
+  deallocate(L,VGL)
+end function test_qmckl_ao_polynomial_vgl
+
+
+ +
+
int  test_qmckl_ao_polynomial_vgl(qmckl_context context);
+assert(0 == test_qmckl_ao_polynomial_vgl(context));
+
+
+
+
+
+
+ +
+

4 Combining radial and polynomial parts

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_context.html b/qmckl_context.html index f7f278d..17284ca 100644 --- a/qmckl_context.html +++ b/qmckl_context.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Context @@ -311,21 +311,21 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Context handling

+
+

1 Context handling

The context variable is a handle for the state of the library, @@ -338,7 +338,7 @@ A value of QMCKL_NULL_CONTEXT for the context is equivalent to a

-
typedef int64_t qmckl_context ;
+
typedef int64_t qmckl_context ;
 #define QMCKL_NULL_CONTEXT (qmckl_context) 0
 
@@ -356,8 +356,8 @@ and ctx is a qmckl_context_struct* pointer.

-
-

1.1 Data structure

+
+

1.1 Data structure

The context keeps a ``date'' that allows to check which data needs @@ -367,7 +367,7 @@ coordinates are updated.

When a new element is added to the context, the functions -qmcklcontextcreate, qmcklcontextdestroy and qmcklcontextcopy +qmcklcontextcreate, qmcklcontextdestroy and qmcklcontextcopy should be updated inorder to make deep copies.

@@ -416,8 +416,8 @@ if the context is valid, QMCKL_NULL_CONTEXT otherwise.
-
-

1.2 Creation

+
+

1.2 Creation

To create a new context, qmckl_context_create() should be used. @@ -460,17 +460,26 @@ To create a new context, qmckl_context_create() should be used. } /* Initialize data */ - ctx->tag = VALID_TAG; + { + ctx->tag = VALID_TAG; - const qmckl_context context = (const qmckl_context) ctx; - assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT ); + const qmckl_context context = (const qmckl_context) ctx; + assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT ); - ctx->numprec.precision = QMCKL_DEFAULT_PRECISION; - ctx->numprec.range = QMCKL_DEFAULT_RANGE; + qmckl_exit_code rc; - ctx->ao_basis.uninitialized = (1 << 12) - 1; - ctx->nucleus.uninitialized = (1 << 4) - 1; - ctx->electron.uninitialized = (1 << 3) - 1; + ctx->numprec.precision = QMCKL_DEFAULT_PRECISION; + ctx->numprec.range = QMCKL_DEFAULT_RANGE; + + rc = qmckl_init_electron(context); + assert (rc == QMCKL_SUCCESS); + + rc = qmckl_init_nucleus(context); + assert (rc == QMCKL_SUCCESS); + + rc = qmckl_init_ao_basis(context); + assert (rc == QMCKL_SUCCESS); + } /* Allocate qmckl_memory_struct */ { @@ -493,8 +502,8 @@ To create a new context, qmckl_context_create() should be used.

-
-

1.3 Locking

+
+

1.3 Locking

For thread safety, the context may be locked/unlocked. The lock is @@ -539,8 +548,8 @@ number of times the thread has locked it is saved in the

-
-

1.4 TODO Copy

+
+

1.4 TODO Copy

qmckl_context_copy makes a deep copy of a context. It returns @@ -588,8 +597,8 @@ number of times the thread has locked it is saved in the

-
-

1.5 Destroy

+
+

1.5 Destroy

The context is destroyed with qmckl_context_destroy, leaving the ancestors untouched. @@ -643,7 +652,7 @@ It frees the context, and returns the previous context.

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_distance.html b/qmckl_distance.html index 303fa49..bd9a14f 100644 --- a/qmckl_distance.html +++ b/qmckl_distance.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Inter-particle distances @@ -333,38 +333,38 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Squared distance

+
+

1 Squared distance

-
-

1.1 qmckl_distance_sq

+
+

1.1 qmckl_distance_sq

qmckl_distance_sq computes the matrix of the squared distances @@ -391,7 +391,7 @@ between all pairs of points in two sets, one point within each set: \]

- +
@@ -484,8 +484,8 @@ between all pairs of points in two sets, one point within each set:
-
-

1.1.1 Requirements

+
+

1.1.1 Requirements

  • context is not QMCKL_NULL_CONTEXT
  • @@ -503,8 +503,8 @@ between all pairs of points in two sets, one point within each set:
-
-

1.1.2 C header

+
+

1.1.2 C header

qmckl_exit_code qmckl_distance_rescaled (
@@ -524,8 +524,8 @@ between all pairs of points in two sets, one point within each set:
 
-
-

1.1.3 Source

+
+

1.1.3 Source

integer function qmckl_distance_sq_f(context, transa, transb, m, n, &
@@ -660,8 +660,8 @@ between all pairs of points in two sets, one point within each set:
 
-
-

1.1.4 Performance

+
+

1.1.4 Performance

This function is more efficient when A and B are @@ -671,12 +671,12 @@ transposed.

-
-

2 Distance

+
+

2 Distance

-
-

2.1 qmckl_distance

+
+

2.1 qmckl_distance

qmckl_distance computes the matrix of the distances between all @@ -694,7 +694,7 @@ If the input array is normal ('N'), the xyz coordinates are in the leading dimension: [n][3] in C and (3,n) in Fortran.

- +
@@ -787,8 +787,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
-
-

2.1.1 Requirements

+
+

2.1.1 Requirements

  • context is not QMCKL_NULL_CONTEXT
  • @@ -806,8 +806,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
-
-

2.1.2 C header

+
+

2.1.2 C header

qmckl_exit_code qmckl_distance_rescaled (
@@ -827,8 +827,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
 
-
-

2.1.3 Source

+
+

2.1.3 Source

integer function qmckl_distance_f(context, transa, transb, m, n, &
@@ -995,8 +995,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
 
-
-

2.1.4 Performance

+
+

2.1.4 Performance

This function is more efficient when A and B are transposed. @@ -1006,12 +1006,12 @@ This function is more efficient when A and B are trans

-
-

3 Rescaled Distance

+
+

3 Rescaled Distance

-
-

3.1 qmckl_distance_rescaled

+
+

3.1 qmckl_distance_rescaled

qmckl_distance_rescaled computes the matrix of the rescaled distances between all @@ -1029,7 +1029,7 @@ If the input array is normal ('N'), the xyz coordinates are in the leading dimension: [n][3] in C and (3,n) in Fortran.

- +
@@ -1129,8 +1129,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
-
-

3.1.1 Requirements

+
+

3.1.1 Requirements

  • context is not QMCKL_NULL_CONTEXT
  • @@ -1148,8 +1148,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
-
-

3.1.2 C header

+
+

3.1.2 C header

qmckl_exit_code qmckl_distance_rescaled (
@@ -1170,8 +1170,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
 
-
-

3.1.3 Source

+
+

3.1.3 Source

integer function qmckl_distance_rescaled_f(context, transa, transb, m, n, &
@@ -1341,8 +1341,8 @@ the leading dimension: [n][3] in C and (3,n) in Fortra
 
-
-

3.1.4 Performance

+
+

3.1.4 Performance

This function is more efficient when A and B are transposed. @@ -1354,7 +1354,7 @@ This function is more efficient when A and B are trans

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_electron.html b/qmckl_electron.html index c6b6ae5..de05361 100644 --- a/qmckl_electron.html +++ b/qmckl_electron.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Electrons @@ -311,49 +311,49 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Context

+
+

1 Context

The following data stored in the context: @@ -382,123 +382,123 @@ The following data stored in the context: uninitialized -int32t +int32_t Keeps bit set for uninitialized data num -int64t +int64_t Total number of electrons up_num -int64t +int64_t Number of up-spin electrons down_num -int64t +int64_t Number of down-spin electrons walk_num -int64t +int64_t Number of walkers rescale_factor_kappa_ee -double +double The distance scaling factor rescale_factor_kappa_en -double +double The distance scaling factor provided -bool +bool If true, electron is valid coord_new -double[walknum][3][num] +double[walk_num][3][num] New set of electron coordinates coord_old -double[walknum][3][num] +double[walk_num][3][num] Old set of electron coordinates coord_new_date -uint64t +uint64_t Last modification date of the coordinates ee_distance -double[walknum][num][num] +double[walk_num][num][num] Electron-electron distances ee_distance_date -uint64t +uint64_t Last modification date of the electron-electron distances en_distance -double[walknum][nuclnum][num] +double[walk_num][nucl_num][num] Electron-nucleus distances en_distance_date -uint64t +uint64_t Last modification date of the electron-electron distances ee_distance_rescaled -double[walknum][num][num] +double[walk_num][num][num] Electron-electron distances ee_distance_rescaled_date -uint64t +uint64_t Last modification date of the electron-electron distances en_distance_rescaled -double[walknum][nuclnum][num] +double[walk_num][nucl_num][num] Electron-nucleus distances en_distance_rescaled_date -uint64t +uint64_t Last modification date of the electron-electron distances

-
-

1.1 Data structure

+
+

1.1 Data structure

typedef struct qmckl_electron_struct {
@@ -522,20 +522,45 @@ The following data stored in the context:
   int32_t   uninitialized;
   bool      provided;
 } qmckl_electron_struct;
+
 

The uninitialized integer contains one bit set to one for each -initialization function which has not bee called. It becomes equal +initialization function which has not been called. It becomes equal to zero after all initialization functions have been called. The struct is then initialized and provided == true. +Some values are initialized by default, and are not concerned by +this mechanism.

-

-When all the data relative to electrons have been set, the -following function returns true. -

+
+
qmckl_exit_code qmckl_init_electron(qmckl_context context);
+
+
+ +
+
qmckl_exit_code qmckl_init_electron(qmckl_context context) {
+
+  if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
+    return false;
+  }
+
+  qmckl_context_struct* const ctx = (qmckl_context_struct* const) context;
+  assert (ctx != NULL);
+
+  ctx->electron.uninitialized = (1 << 2) - 1;
+
+  /* Default values */
+  ctx->electron.rescale_factor_kappa_ee = 1.0;
+  ctx->electron.rescale_factor_kappa_en = 1.0;
+
+  return QMCKL_SUCCESS;
+}
+
+
+
bool qmckl_electron_provided (const qmckl_context context);
@@ -544,8 +569,8 @@ following function returns true.
 
-
-

1.2 Access functions

+
+

1.2 Access functions

Access functions return QMCKL_SUCCESS when the data has been @@ -557,12 +582,12 @@ contains the requested data. Otherwise, this variable is untouched.

-
-

1.2.1 Number of electrons

+
+

1.2.1 Number of electrons

-
-

1.2.2 Number of walkers

+
+

1.2.2 Number of walkers

A walker is a set of electron coordinates that are arguments of @@ -571,12 +596,12 @@ the wave function. walk_num is the number of walkers.

-
-

1.2.3 Scaling factors Kappa

+
+

1.2.3 Scaling factors Kappa

-
-

1.2.4 Electron coordinates

+
+

1.2.4 Electron coordinates

Returns the current electron coordinates. The pointer is assumed @@ -620,8 +645,8 @@ The order of the indices is:

-
-

1.3 Initialization functions

+
+

1.3 Initialization functions

To set the data relative to the electrons in the context, the @@ -631,10 +656,12 @@ both allocated.

-
qmckl_exit_code  qmckl_set_electron_num        (qmckl_context context, const int64_t up_num, const int64_t down_num);
-qmckl_exit_code  qmckl_set_kappa               (qmckl_context context, const double rescale_factor_kappa_ee, const double rescale_factor_kappa_en);
-qmckl_exit_code  qmckl_set_electron_walk_num   (qmckl_context context, const int64_t walk_num);
-qmckl_exit_code  qmckl_set_electron_coord      (qmckl_context context, const char transp, const double* coord);
+
qmckl_exit_code qmckl_set_electron_num      (qmckl_context context, const int64_t up_num, const int64_t down_num);
+qmckl_exit_code qmckl_set_electron_walk_num (qmckl_context context, const int64_t walk_num);
+qmckl_exit_code qmckl_set_electron_coord    (qmckl_context context, const char transp, const double* coord);
+
+qmckl_exit_code qmckl_set_electron_rescale_factor_ee (qmckl_context context, const double kappa_ee);
+qmckl_exit_code qmckl_set_electron_rescale_factor_en (qmckl_context context, const double kappa_en);
 
@@ -666,8 +693,8 @@ in the context.
-
-

1.4 Test

+
+

1.4 Test

/* Reference input data */
@@ -675,14 +702,13 @@ in the context.
 int64_t elec_num      = chbrclf_elec_num;
 int64_t elec_up_num   = chbrclf_elec_up_num;
 int64_t elec_dn_num   = chbrclf_elec_dn_num;
-double  rescale_factor_kappa_ee      = 1.0; // TODO Get rescale_factor_kappa_ee from chbrclf
-double  rescale_factor_kappa_en      = 1.0; // TODO Get rescale_factor_kappa_en from chbrclf
+double  rescale_factor_kappa_ee = 2.0;
+double  rescale_factor_kappa_en = 3.0;
 double* elec_coord    = &(chbrclf_elec_coord[0][0][0]);
 
 int64_t  nucl_num      = chbrclf_nucl_num;
 double*  charge        = chbrclf_charge;
 double*  nucl_coord    = &(chbrclf_nucl_coord[0][0]);
-double   nucl_rescale_factor_kappa    = 1.0; // TODO Change get rescale_factor_kappa from chbrclf example
 
 /* --- */
 
@@ -717,23 +743,27 @@ rc = qmckl_get_electron_num (context, &n);
 assert(rc == QMCKL_SUCCESS);
 assert(n == elec_num);
 
-double k_ee;
-double k_en;
-rc = qmckl_get_kappa_ee (context, &k_ee);
-assert(rc == QMCKL_NOT_PROVIDED);
-
-rc = qmckl_get_kappa_en (context, &k_en);
-assert(rc == QMCKL_NOT_PROVIDED);
-
-rc = qmckl_set_kappa (context, rescale_factor_kappa_ee, rescale_factor_kappa_en);
+double k_ee = 0.;
+double k_en = 0.;
+rc = qmckl_get_electron_rescale_factor_ee (context, &k_ee);
 assert(rc == QMCKL_SUCCESS);
-assert(!qmckl_electron_provided(context));
+assert(k_ee == 1.0);
 
-rc = qmckl_get_kappa_ee (context, &k_ee);
+rc = qmckl_get_electron_rescale_factor_en (context, &k_en);
+assert(rc == QMCKL_SUCCESS);
+assert(k_en == 1.0);
+
+rc = qmckl_set_electron_rescale_factor_en(context, rescale_factor_kappa_en);
+assert(rc == QMCKL_SUCCESS);
+
+rc = qmckl_set_electron_rescale_factor_ee(context, rescale_factor_kappa_ee);
+assert(rc == QMCKL_SUCCESS);
+
+rc = qmckl_get_electron_rescale_factor_ee (context, &k_ee);
 assert(rc == QMCKL_SUCCESS);
 assert(k_ee == rescale_factor_kappa_ee);
 
-rc = qmckl_get_kappa_en (context, &k_en);
+rc = qmckl_get_electron_rescale_factor_en (context, &k_en);
 assert(rc == QMCKL_SUCCESS);
 assert(k_en == rescale_factor_kappa_en);
 
@@ -769,8 +799,8 @@ rc = qmckl_get_electron_coord (context, 'N'
 
-
-

2 Computation

+
+

2 Computation

The computed data is stored in the context so that it can be reused @@ -783,12 +813,12 @@ current date is stored.

-
-

2.1 Electron-electron distances

+
+

2.1 Electron-electron distances

-
-

2.1.1 Get

+
+

2.1.1 Get

qmckl_exit_code qmckl_get_electron_ee_distance(qmckl_context context, double* const distance);
@@ -797,10 +827,10 @@ current date is stored.
 
-
-

2.1.2 Compute

+
+

2.1.2 Compute

- +
@@ -896,8 +926,8 @@ current date is stored. -
-

2.1.3 Test

+
+

2.1.3 Test

assert(qmckl_electron_provided(context));
@@ -931,12 +961,12 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance);
 
-
-

2.2 Electron-electron rescaled distances

+
+

2.2 Electron-electron rescaled distances

-
-

2.2.1 Get

+
+

2.2.1 Get

qmckl_exit_code qmckl_get_electron_ee_distance_rescaled(qmckl_context context, double* const distance_rescaled);
@@ -945,10 +975,10 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance);
 
-
-

2.2.2 Compute

+
+

2.2.2 Compute

-
+
@@ -1053,8 +1083,8 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance); -
-

2.2.3 Test

+
+

2.2.3 Test

assert(qmckl_electron_provided(context));
@@ -1089,12 +1119,12 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled);
 
-
-

2.3 Electron-nucleus distances

+
+

2.3 Electron-nucleus distances

-
-

2.3.1 Get

+
+

2.3.1 Get

qmckl_exit_code qmckl_get_electron_en_distance(qmckl_context context, double* distance);
@@ -1103,10 +1133,10 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled);
 
-
-

2.3.2 Compute

+
+

2.3.2 Compute

-
+
@@ -1223,8 +1253,8 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled); -
-

2.3.3 Test

+
+

2.3.3 Test

@@ -1234,9 +1264,6 @@ assert(!qmckl_nucleus_provided(context));
 rc = qmckl_set_nucleus_num (context, nucl_num);
 assert(rc == QMCKL_SUCCESS);
 
-rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
-assert(rc == QMCKL_SUCCESS);
-
 rc = qmckl_set_nucleus_charge (context, charge);
 assert (rc == QMCKL_SUCCESS);
 
@@ -1275,12 +1302,12 @@ rc = qmckl_get_electron_en_distance(context, &(en_distance[0][0][0]));
 
-
-

2.4 Electron-nucleus rescaled distances

+
+

2.4 Electron-nucleus rescaled distances

-
-

2.4.1 Get

+
+

2.4.1 Get

qmckl_exit_code qmckl_get_electron_en_distance_rescaled(qmckl_context context, double* distance_rescaled);
@@ -1289,10 +1316,10 @@ rc = qmckl_get_electron_en_distance(context, &(en_distance[0][0][0]));
 
-
-

2.4.2 Compute

+
+

2.4.2 Compute

-
+
@@ -1424,8 +1451,8 @@ rc = qmckl_get_electron_en_distance(context, &(en_distance[0][0][0])); -
-

2.4.3 Test

+
+

2.4.3 Test

@@ -1434,9 +1461,6 @@ rc = qmckl_get_electron_en_distance(context, &(en_distance[0][0][0]));
 rc = qmckl_set_nucleus_num (context, nucl_num);
 assert(rc == QMCKL_SUCCESS);
 
-rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
-assert(rc == QMCKL_SUCCESS);
-
 rc = qmckl_set_nucleus_charge (context, charge);
 assert (rc == QMCKL_SUCCESS);
 
@@ -1479,7 +1503,7 @@ rc = qmckl_get_electron_en_distance_rescaled(context, &(en_distance_rescaled
 

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_error.html b/qmckl_error.html index 9ca6129..38b5016 100644 --- a/qmckl_error.html +++ b/qmckl_error.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Error handling @@ -311,17 +311,17 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Decoding errors

+
+

1 Decoding errors

To decode the error messages, qmckl_string_of_error converts an @@ -451,8 +451,8 @@ The text strings are extracted from the previous table.

-
-

2 Data structure in context

+
+

2 Data structure in context

The strings are declared with a maximum fixed size to avoid @@ -475,8 +475,8 @@ dynamic memory allocation.

-
-

3 Updating errors in the context

+
+

3 Updating errors in the context

The error is updated in the context using qmckl_set_error. @@ -522,8 +522,8 @@ explaining the error. The exit code can't be QMCKL_SUCCESS.

-
-

4 Get the error

+
+

4 Get the error

Upon error, the error type and message can be obtained from the @@ -564,8 +564,8 @@ function name and message is mandatory.

-
-

5 Failing

+
+

5 Failing

To make a function fail, the qmckl_failwith function should be @@ -628,7 +628,7 @@ For example, this function can be used as

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_memory.html b/qmckl_memory.html index feafad1..af41e82 100644 --- a/qmckl_memory.html +++ b/qmckl_memory.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Memory management @@ -311,15 +311,15 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Memory data structure for the context

+
+

1 Memory data structure for the context

Every time a new block of memory is allocated, the information @@ -361,8 +361,8 @@ array, and the number of allocated blocks.

-
-

2 Passing info to allocation routines

+
+

2 Passing info to allocation routines

Passing information to the allocation routine should be done by @@ -371,8 +371,8 @@ passing an instance of a qmckl_memory_info_struct.

-
-

3 Allocation/deallocation functions

+
+

3 Allocation/deallocation functions

Memory allocation inside the library should be done with @@ -535,7 +535,7 @@ allocation and needs to be updated.

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_nucleus.html b/qmckl_nucleus.html index 8c7631d..a99e608 100644 --- a/qmckl_nucleus.html +++ b/qmckl_nucleus.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Nucleus @@ -333,35 +333,35 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Context

+
+

1 Context

The following data stored in the context: @@ -463,8 +463,8 @@ The following data stored in the context:

-
-

1.1 Data structure

+
+

1.1 Data structure

typedef struct qmckl_nucleus_struct {
@@ -481,6 +481,7 @@ The following data stored in the context:
   int32_t   uninitialized;
   bool      provided;
 } qmckl_nucleus_struct;
+
 
@@ -489,12 +490,41 @@ The uninitialized integer contains one bit set to one for each initialization function which has not been called. It becomes equal to zero after all initialization functions have been called. The struct is then initialized and provided == true. +Some values are initialized by default, and are not concerned by +this mechanism.

+ +
+
qmckl_exit_code qmckl_init_nucleus(qmckl_context context);
+
+
+ +
+
qmckl_exit_code qmckl_init_nucleus(qmckl_context context) {
+
+  if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
+    return false;
+  }
+
+  qmckl_context_struct* const ctx = (qmckl_context_struct* const) context;
+  assert (ctx != NULL);
+
+  ctx->nucleus.uninitialized = (1 << 3) - 1;
+
+  /* Default values */
+  ctx->nucleus.rescale_factor_kappa = 1.0;
+
+  return QMCKL_SUCCESS;
+}
+
+
-
-

1.2 Access functions

+ + +
+

1.2 Access functions

When all the data relative to nuclei have been set, the following @@ -508,8 +538,8 @@ function returns true.

-
-

1.3 Initialization functions

+
+

1.3 Initialization functions

To set the data relative to the nuclei in the context, the @@ -519,8 +549,9 @@ following functions need to be called.

qmckl_exit_code  qmckl_set_nucleus_num    (qmckl_context context, const int64_t num);
 qmckl_exit_code  qmckl_set_nucleus_charge (qmckl_context context, const double* charge);
-qmckl_exit_code  qmckl_set_nucleus_kappa  (qmckl_context context, const double rescale_factor_kappa);
 qmckl_exit_code  qmckl_set_nucleus_coord  (qmckl_context context, const char transp, const double* coord);
+
+qmckl_exit_code  qmckl_set_nucleus_rescale_factor (qmckl_context context, const double rescale_factor_kappa);
 
@@ -543,14 +574,14 @@ atoms. The coordinates should be given in atomic units.
-
-

1.4 Test

+
+

1.4 Test

const int64_t   nucl_num      = chbrclf_nucl_num;
 const double*   nucl_charge   = chbrclf_charge;
 const double*   nucl_coord    = &(chbrclf_nucl_coord[0][0]);
-const double    nucl_rescale_factor_kappa    = 1.0; // TODO Change get rescale_factor_kappa from chbrclf example
+const double    nucl_rescale_factor_kappa = 2.0; 
 
 /* --- */
 
@@ -572,15 +603,15 @@ rc = qmckl_get_nucleus_num (context, &n);
 assert(n == nucl_num);
 
 double k;
-rc = qmckl_get_nucleus_kappa (context, &k);
-assert(rc == QMCKL_NOT_PROVIDED);
-
-
-rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
+rc = qmckl_get_nucleus_rescale_factor (context, &k);
 assert(rc == QMCKL_SUCCESS);
-assert(!qmckl_nucleus_provided(context));
+assert(k == 1.0);
 
-rc = qmckl_get_nucleus_kappa (context, &k);
+
+rc = qmckl_set_nucleus_rescale_factor (context, nucl_rescale_factor_kappa);
+assert(rc == QMCKL_SUCCESS);
+
+rc = qmckl_get_nucleus_rescale_factor (context, &k);
 assert(rc == QMCKL_SUCCESS);
 assert(k == nucl_rescale_factor_kappa);
 
@@ -628,8 +659,8 @@ rc = qmckl_get_nucleus_charge(context, nucl_charge2);
 
-
-

2 Computation

+
+

2 Computation

The computed data is stored in the context so that it can be reused @@ -642,12 +673,12 @@ current date is stored.

-
-

2.1 Nucleus-nucleus distances

+
+

2.1 Nucleus-nucleus distances

-
-

2.1.1 Get

+
+

2.1.1 Get

qmckl_exit_code qmckl_get_nucleus_nn_distance(qmckl_context context, double* distance);
@@ -656,10 +687,10 @@ current date is stored.
 
-
-

2.1.2 Compute

+
+

2.1.2 Compute

- +
@@ -737,8 +768,8 @@ current date is stored. -
-

2.1.3 Test

+
+

2.1.3 Test

/* Reference input data */
@@ -758,12 +789,12 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
 
-
-

2.2 Nucleus-nucleus rescaled distances

+
+

2.2 Nucleus-nucleus rescaled distances

-
-

2.2.1 Get

+
+

2.2.1 Get

qmckl_exit_code qmckl_get_nucleus_nn_distance_rescaled(qmckl_context context, double* distance_rescaled);
@@ -772,10 +803,10 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
 
-
-

2.2.2 Compute

+
+

2.2.2 Compute

-
+
@@ -854,8 +885,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance); -
-

2.2.3 Test

+
+

2.2.3 Test

/* Reference input data */
@@ -875,8 +906,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
 
-
-

2.3 Nuclear repulsion energy

+
+

2.3 Nuclear repulsion energy

\[ @@ -885,8 +916,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);

-
-

2.3.1 Get

+
+

2.3.1 Get

qmckl_exit_code qmckl_get_nucleus_repulsion(qmckl_context context, double* energy);
@@ -895,10 +926,10 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
 
-
-

2.3.2 Compute

+
+

2.3.2 Compute

-
+
@@ -986,8 +1017,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance); -
-

2.3.3 Test

+
+

2.3.3 Test

/* Reference input data */
@@ -1007,7 +1038,7 @@ rc = qmckl_get_nucleus_repulsion(context, &rep);
 

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_numprec.html b/qmckl_numprec.html index 595a034..f3f51ec 100644 --- a/qmckl_numprec.html +++ b/qmckl_numprec.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Numerical precision @@ -333,16 +333,16 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Control of the numerical precision

+
+

1 Control of the numerical precision

Controlling numerical precision enables optimizations. Here, the @@ -353,7 +353,7 @@ Arithmetic (IEEE 754), refers to the number of exponent bits.

-
+
@@ -397,8 +397,8 @@ integer. The update functions return QMCKL_SUCCESS or -
-

2 Precision

+
+

2 Precision

qmckl_context_set_numprec_precision modifies the parameter for the @@ -485,8 +485,8 @@ numerical precision in the context.

-
-

3 Range

+
+

3 Range

qmckl_set_numprec_range modifies the parameter for the numerical @@ -561,8 +561,8 @@ range in a given context.

-
-

4 Helper functions

+
+

4 Helper functions

qmckl_get_numprec_epsilon returns \(\epsilon = 2^{1-n}\) where n is the precision. @@ -581,7 +581,7 @@ We need to remove the sign bit from the precision.

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_tests.html b/qmckl_tests.html index c676019..c0a5d4a 100644 --- a/qmckl_tests.html +++ b/qmckl_tests.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Data for Tests @@ -233,20 +233,20 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 CHBrClF

+
+

1 CHBrClF

This test is the all-electron Hartree-Fock wave function of CHClBr, @@ -330,8 +330,8 @@ and with a high maximum angular momentum.

-
-

1.1 XYZ coordinates

+
+

1.1 XYZ coordinates

   5
@@ -361,8 +361,8 @@ Nuclear coordinates are stored in atomic units in transposed format.
 
-
-

1.2 Atomic basis set

+
+

1.2 Atomic basis set

 HYDROGEN
@@ -1175,11 +1175,11 @@ F   1
 
-
-

1.3 TODO Molecular orbitals

+
+

1.3 TODO Molecular orbitals

-
-

1.4 Electron coordinates

+
+

1.4 Electron coordinates

Electron coordinates are stored in atomic units in normal format. @@ -1339,7 +1339,7 @@ Electron coordinates are stored in atomic units in normal format.

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate

diff --git a/qmckl_utils.html b/qmckl_utils.html index 091a6cf..52b54cb 100644 --- a/qmckl_utils.html +++ b/qmckl_utils.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Utility functions @@ -333,13 +333,13 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Matrix operations

+
+

1 Matrix operations

-
-

1.1 qmckl_transpose

+
+

1.1 qmckl_transpose

Transposes a matrix: \(B_{ji} = A_{ij}\)

-
+
@@ -424,8 +424,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
-
-

1.1.1 Requirements

+
+

1.1.1 Requirements

  • context is not QMCKL_NULL_CONTEXT
  • @@ -439,8 +439,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
-
-

1.1.2 C header

+
+

1.1.2 C header

qmckl_exit_code qmckl_transpose (
@@ -456,8 +456,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
 
-
-

1.1.3 Source

+
+

1.1.3 Source

integer function qmckl_transpose_f(context, m, n, A, LDA, B, LDB) &
@@ -516,7 +516,7 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
 

Author: TREX CoE

-

Created: 2021-06-09 Wed 22:11

+

Created: 2021-06-10 Thu 21:55

Validate