1
0
mirror of https://github.com/TREX-CoE/qmckl.git synced 2025-01-03 18:16:28 +01:00

Renamed function prefixes.

This commit is contained in:
Francois Coppens 2023-02-20 18:51:20 +01:00
parent 5e5c15a09d
commit 8ba882675e

View File

@ -34,9 +34,9 @@ range(2, 3)
* Naïve Sherman-Morrison * Naïve Sherman-Morrison
** ~qmckl_sherman_morrison_naive~ ** ~qmckl_sm_naive~
:PROPERTIES: :PROPERTIES:
:Name: qmckl_sherman_morrison_naive :Name: qmckl_sm_naive
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
@ -75,7 +75,7 @@ If the determinant of the Slater-matrix is passed, it will be updated to the det
from applying the updates to the original matrix. from applying the updates to the original matrix.
*** API *** API
#+NAME: qmckl_sherman_morrison_naive_args #+NAME: qmckl_sm_naive_args
| Variable | Type | In/Out | Description | | Variable | Type | In/Out | Description |
|-----------------+-------------------------+--------+------------------------------------------------------| |-----------------+-------------------------+--------+------------------------------------------------------|
| ~context~ | ~qmckl_context~ | in | Global state | | ~context~ | ~qmckl_context~ | in | Global state |
@ -150,7 +150,7 @@ end subroutine copy_back
#+end_src #+end_src
#+begin_src f90 :tangle (eval f) #+begin_src f90 :tangle (eval f)
integer function qmckl_sherman_morrison_naive_doc_f(context, & integer function qmckl_sm_naive_doc_f(context, &
lds, dim, & lds, dim, &
nupdates, & nupdates, &
upds, & upds, &
@ -230,20 +230,20 @@ integer function qmckl_sherman_morrison_naive_doc_f(context, &
info = QMCKL_SUCCESS info = QMCKL_SUCCESS
end function qmckl_sherman_morrison_naive_doc_f end function qmckl_sm_naive_doc_f
#+end_src #+end_src
**** C interface to the pedagogical kernel (not directly exposed) **** C interface to the pedagogical kernel (not directly exposed)
The following Fortran function ~qmckl_sherman_morrison_naive_doc~ makes sure The following Fortran function ~qmckl_sm_naive_doc~ makes sure
that the pedagogical kernel ~qmckl_sherman_morrison_naive_doc_f~, written in that the pedagogical kernel ~qmckl_sm_naive_doc_f~, written in
Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function ~qmckl_sherman_morrison_naive_doc~ will be exposed in the header file 'qmckl.h' Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function ~qmckl_sm_naive_doc~ will be exposed in the header file 'qmckl.h'
for C users and in the module file 'qmckl_f.F90' for Fortran users. for C users and in the module file 'qmckl_f.F90' for Fortran users.
#+CALL: generate_c_interface(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_naive_doc") #+CALL: generate_c_interface(table=qmckl_sm_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sm_naive_doc")
#+RESULTS: #+RESULTS:
#+begin_src f90 :tangle (eval f) :comments org :exports none #+begin_src f90 :tangle (eval f) :comments org :exports none
integer(c_int32_t) function qmckl_sherman_morrison_naive_doc & integer(c_int32_t) function qmckl_sm_naive_doc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) result(info) bind(C) result(info)
@ -260,20 +260,20 @@ integer(c_int32_t) function qmckl_sherman_morrison_naive_doc &
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
integer(c_int32_t), external :: qmckl_sherman_morrison_naive_doc_f integer(c_int32_t), external :: qmckl_sm_naive_doc_f
info = qmckl_sherman_morrison_naive_doc_f & info = qmckl_sm_naive_doc_f &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant)
end function qmckl_sherman_morrison_naive_doc end function qmckl_sm_naive_doc
#+end_src #+end_src
*** C headers (exposed in qmckl.h) *** C headers (exposed in qmckl.h)
#+CALL: generate_c_header(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("CRetType"),fname=get_value("Name")) #+CALL: generate_c_header(table=qmckl_sm_naive_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) : comments org #+begin_src c :tangle (eval h_func) : comments org
qmckl_exit_code qmckl_sherman_morrison_naive ( qmckl_exit_code qmckl_sm_naive (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -285,11 +285,11 @@ qmckl_exit_code qmckl_sherman_morrison_naive (
double* determinant ); double* determinant );
#+end_src #+end_src
#+CALL: generate_c_header(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_naive_hpc") #+CALL: generate_c_header(table=qmckl_sm_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sm_naive_hpc")
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_private_func) :comments org #+begin_src c :tangle (eval h_private_func) :comments org
qmckl_exit_code qmckl_sherman_morrison_naive_hpc ( qmckl_exit_code qmckl_sm_naive_hpc (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -301,11 +301,11 @@ qmckl_exit_code qmckl_sherman_morrison_naive_hpc (
double* determinant ); double* determinant );
#+end_src #+end_src
#+CALL: generate_c_header(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_naive_doc") #+CALL: generate_c_header(table=qmckl_sm_naive_args,rettyp=get_value("CRetType"),fname="qmckl_sm_naive_doc")
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_sherman_morrison_naive_doc ( qmckl_exit_code qmckl_sm_naive_doc (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -344,8 +344,8 @@ Common includes and macros used by all the Sherman-Morrison-Woodbury kernels.
#endif #endif
#+end_src #+end_src
~qmckl_sherman_morrison_naive_hpc~ is a high performance variation of ~qmckl_sm_naive_hpc~ is a high performance variation of
~qmckl_sherman_morrison_naive~ written in C. It is used in cases when ~Dim~ is ~qmckl_sm_naive~ written in C. It is used in cases when ~Dim~ is
smaller than the leading dimension ~LDS~, irrespective of whetether ~LDS~ smaller than the leading dimension ~LDS~, irrespective of whetether ~LDS~
includes zero padding to benefit from SIMD instructions or not. Cases like this includes zero padding to benefit from SIMD instructions or not. Cases like this
include situations where one wants to apply updates to a square submatrix of the include situations where one wants to apply updates to a square submatrix of the
@ -354,7 +354,7 @@ It takes advantage of memory aligned data and assumes no data dependencies
inside the loops. The loops are fully vectorised whenever ~Dim~ is an integer inside the loops. The loops are fully vectorised whenever ~Dim~ is an integer
multiple of ~SIMD_LEGTH~. multiple of ~SIMD_LEGTH~.
#+begin_src c :tangle (eval c) :comments org #+begin_src c :tangle (eval c) :comments org
qmckl_exit_code qmckl_sherman_morrison_naive_hpc( qmckl_exit_code qmckl_sm_naive_hpc(
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -368,7 +368,7 @@ qmckl_exit_code qmckl_sherman_morrison_naive_hpc(
if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) { if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
return qmckl_failwith( context, return qmckl_failwith( context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_sherman_morrison_naive_hpc", "qmckl_sm_naive_hpc",
NULL); NULL);
} }
@ -423,10 +423,10 @@ qmckl_exit_code qmckl_sherman_morrison_naive_hpc(
} }
#+end_src #+end_src
~qmckl_exit_code qmckl_sherman_morrison_naive_{Dim}~ is a C function-template that is used to genereate instances of C fucntions based on the range given above. The advantage of this method is that for each of these instances all the dimensions and loop-bounds are known at compile time, allowing the compiler to optimize more aggressively. ~qmckl_exit_code qmckl_sm_naive_{Dim}~ is a C function-template that is used to genereate instances of C fucntions based on the range given above. The advantage of this method is that for each of these instances all the dimensions and loop-bounds are known at compile time, allowing the compiler to optimize more aggressively.
#+NAME:naive_template_code #+NAME:naive_template_code
#+begin_src c #+begin_src c
static inline qmckl_exit_code qmckl_sherman_morrison_naive_{Dim}( static inline qmckl_exit_code qmckl_sm_naive_{Dim}(
const qmckl_context context, const qmckl_context context,
const uint64_t N_updates, const uint64_t N_updates,
const double* __restrict Updates, const double* __restrict Updates,
@ -438,7 +438,7 @@ qmckl_exit_code qmckl_sherman_morrison_naive_hpc(
if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) { if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
return qmckl_failwith(context, return qmckl_failwith(context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_sherman_morrison_naive_{Dim}", "qmckl_sm_naive_{Dim}",
NULL); NULL);
} }
@ -516,7 +516,7 @@ Python script that generated C switch cases that call individual kernel instance
#+begin_src python :noweb yes #+begin_src python :noweb yes
text=""" text="""
case {Dim}: case {Dim}:
return qmckl_sherman_morrison_naive_{Dim}(context, return qmckl_sm_naive_{Dim}(context,
N_updates, N_updates,
Updates, Updates,
Updates_index, Updates_index,
@ -536,9 +536,9 @@ return '\n'.join(result)
<<naive_kernel_generator()>> <<naive_kernel_generator()>>
#+end_src #+end_src
~qmckl_sherman_morrison_naive~ is a generic function that contains decision making logic that calls the proper kernel based on the used library configuration (~--enable-doc~ and ~--enable-hpc~) and the passed array dimensions ~LDS~ and ~Dim~. ~qmckl_sm_naive~ is a generic function that contains decision making logic that calls the proper kernel based on the used library configuration (~--enable-doc~ and ~--enable-hpc~) and the passed array dimensions ~LDS~ and ~Dim~.
#+begin_src c :tangle (eval c) :comments org :noweb yes #+begin_src c :tangle (eval c) :comments org :noweb yes
qmckl_exit_code qmckl_sherman_morrison_naive(const qmckl_context context, qmckl_exit_code qmckl_sm_naive(const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
const uint64_t N_updates, const uint64_t N_updates,
@ -551,7 +551,7 @@ qmckl_exit_code qmckl_sherman_morrison_naive(const qmckl_context context,
if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) { if (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
return qmckl_failwith(context, return qmckl_failwith(context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_sherman_morrison_naive", "qmckl_sm_naive",
NULL); NULL);
} }
@ -562,7 +562,7 @@ qmckl_exit_code qmckl_sherman_morrison_naive(const qmckl_context context,
} }
} }
else { // Updating smaller sub-matrix else { // Updating smaller sub-matrix
return qmckl_sherman_morrison_naive_hpc(context, return qmckl_sm_naive_hpc(context,
LDS, LDS,
Dim, Dim,
N_updates, N_updates,
@ -573,7 +573,7 @@ qmckl_exit_code qmckl_sherman_morrison_naive(const qmckl_context context,
determinant); determinant);
} }
#else #else
return qmckl_sherman_morrison_naive_doc(context, return qmckl_sm_naive_doc(context,
LDS, LDS,
Dim, Dim,
N_updates, N_updates,
@ -590,17 +590,17 @@ qmckl_exit_code qmckl_sherman_morrison_naive(const qmckl_context context,
*** Fortran interfaces (exposed in qmckl_f.F90) *** Fortran interfaces (exposed in qmckl_f.F90)
:PROPERTIES: :PROPERTIES:
:Name: qmckl_sherman_morrison_naive :Name: qmckl_sm_naive
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_naive_hpc") #+CALL: generate_f_interface(table=qmckl_sm_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sm_naive_hpc")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_naive_hpc & integer(c_int32_t) function qmckl_sm_naive_hpc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -617,16 +617,16 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_naive_hpc end function qmckl_sm_naive_hpc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_naive_doc") #+CALL: generate_f_interface(table=qmckl_sm_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sm_naive_doc")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_naive_doc & integer(c_int32_t) function qmckl_sm_naive_doc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -643,16 +643,16 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_naive_doc end function qmckl_sm_naive_doc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_naive") #+CALL: generate_f_interface(table=qmckl_sm_naive_args,rettyp=get_value("FRetType"),fname="qmckl_sm_naive")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_naive & integer(c_int32_t) function qmckl_sm_naive &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -669,7 +669,7 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_naive end function qmckl_sm_naive
end interface end interface
#+end_src #+end_src
@ -701,7 +701,7 @@ assert(Slater_inv1 != NULL);
// original determinant of Slater1 (before applying updates) // original determinant of Slater1 (before applying updates)
double det = 3.407025646103221e-10; double det = 3.407025646103221e-10;
rc = qmckl_sherman_morrison_naive(context, rc = qmckl_sm_naive(context,
LDS, LDS,
Dim, Dim,
N_updates1, N_updates1,
@ -738,15 +738,15 @@ assert(rc == QMCKL_SUCCESS);
* Sherman-Morrison with Slagel Splitting (core) * Sherman-Morrison with Slagel Splitting (core)
** ~qmckl_slagel_splitting~ ** ~qmckl_sm_splitting_core~
:PROPERTIES: :PROPERTIES:
:Name: qmckl_slagel_splitting :Name: qmckl_sm_splitting_core
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
*** Introduction *** Introduction
~qmckl_slagel_splitting~ is the inner core part of 'Sherman-Morrison with update splitting' in the next section. ~qmckl_sm_splitting_core~ is the inner core part of 'Sherman-Morrison with update splitting' in the next section.
It is not normally used by itself but it is possible to use it nonetheless. It is not normally used by itself but it is possible to use it nonetheless.
It has three extra parameters in its API: It has three extra parameters in its API:
@ -754,14 +754,14 @@ It has three extra parameters in its API:
- ~later_index~ initially empty array that will contain the row/column numbers of the updates that were split during execution - ~later_index~ initially empty array that will contain the row/column numbers of the updates that were split during execution
- ~later~ initially zero integer that records the number of updates that were split during exection. - ~later~ initially zero integer that records the number of updates that were split during exection.
It is up to the user to decide what to do with these updates once the kernel returns. Normally ~qmckl_slagel_splitting~ is It is up to the user to decide what to do with these updates once the kernel returns. Normally ~qmckl_sm_splitting_core~ is
used as the core part of a recursive function, as is done in ~qmckl_sherman_morrison_splitting~ or as part of a more complex used as the core part of a recursive function, as is done in ~qmckl_sm_splitting~ or as part of a more complex
kernel like ~qmckl_sherman_morrison_smw32s~. kernel like ~qmckl_sherman_morrison_smw32s~.
If the determinant is passed it will only be partially updated if there were any update splits. If the determinant is passed it will only be partially updated if there were any update splits.
*** API *** API
#+NAME: qmckl_slagel_splitting_args #+NAME: qmckl_sm_splitting_core_args
| Variable | Type | In/Out | Description | | Variable | Type | In/Out | Description |
|-----------------+-------------------------+--------+---------------------------------------------------------------| |-----------------+-------------------------+--------+---------------------------------------------------------------|
| ~context~ | ~qmckl_context~ | in | Global state | | ~context~ | ~qmckl_context~ | in | Global state |
@ -795,7 +795,7 @@ able to do numerically correct computations, it does not do it in the most effic
not be used in real workloads. not be used in real workloads.
#+begin_src f90 :tangle (eval f) #+begin_src f90 :tangle (eval f)
integer function qmckl_slagel_splitting_doc_f( & integer function qmckl_sm_splitting_core_doc_f( &
context, & context, &
lds, dim, & lds, dim, &
nupdates, & nupdates, &
@ -843,21 +843,21 @@ integer function qmckl_slagel_splitting_doc_f( &
info = QMCKL_SUCCESS info = QMCKL_SUCCESS
end function qmckl_slagel_splitting_doc_f end function qmckl_sm_splitting_core_doc_f
#+end_src #+end_src
**** C interface to the pedagogical kernel (not directly exposed) **** C interface to the pedagogical kernel (not directly exposed)
The following Fortran function ~qmckl_slagel_splitting_doc~ makes sure The following Fortran function ~qmckl_sm_splitting_core_doc~ makes sure
that the pedagogical kernel ~qmckl_slagel_splitting_doc_f~, written in that the pedagogical kernel ~qmckl_sm_splitting_core_doc_f~, written in
Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function
~qmckl_slagel_splitting_doc~ will be exposed in the header file 'qmckl.h' ~qmckl_sm_splitting_core_doc~ will be exposed in the header file 'qmckl.h'
for C users and in the module file 'qmckl_f.F90' for Fortran users. for C users and in the module file 'qmckl_f.F90' for Fortran users.
#+CALL: generate_c_interface(table=qmckl_slagel_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_slagel_splitting_doc") #+CALL: generate_c_interface(table=qmckl_sm_splitting_core_args,rettyp=get_value("CRetType"),fname="qmckl_sm_splitting_core_doc")
#+RESULTS: #+RESULTS:
#+begin_src f90 :tangle (eval f) :comments org :exports none #+begin_src f90 :tangle (eval f) :comments org :exports none
integer(c_int32_t) function qmckl_slagel_splitting_doc & integer(c_int32_t) function qmckl_sm_splitting_core_doc &
(context, & (context, &
LDS, & LDS, &
Dim, & Dim, &
@ -888,8 +888,8 @@ integer(c_int32_t) function qmckl_slagel_splitting_doc &
integer (c_int64_t) , intent(inout) :: later integer (c_int64_t) , intent(inout) :: later
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
integer(c_int32_t), external :: qmckl_slagel_splitting_doc_f integer(c_int32_t), external :: qmckl_sm_splitting_core_doc_f
info = qmckl_slagel_splitting_doc_f & info = qmckl_sm_splitting_core_doc_f &
(context, & (context, &
LDS, & LDS, &
Dim, & Dim, &
@ -903,15 +903,15 @@ integer(c_int32_t) function qmckl_slagel_splitting_doc &
later, & later, &
determinant) determinant)
end function qmckl_slagel_splitting_doc end function qmckl_sm_splitting_core_doc
#+end_src #+end_src
*** C headers (exposed in qmckl.h) *** C headers (exposed in qmckl.h)
#+CALL: generate_c_header(table=qmckl_slagel_splitting_args,rettyp=get_value("CRetType"),fname=get_value("Name")) #+CALL: generate_c_header(table=qmckl_sm_splitting_core_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_slagel_splitting ( qmckl_exit_code qmckl_sm_splitting_core (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -926,11 +926,11 @@ qmckl_exit_code qmckl_slagel_splitting (
double* determinant ); double* determinant );
#+end_src #+end_src
#+CALL: generate_c_header(table=qmckl_slagel_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_slagel_splitting_doc") #+CALL: generate_c_header(table=qmckl_sm_splitting_core_args,rettyp=get_value("CRetType"),fname="qmckl_sm_splitting_core_doc")
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_slagel_splitting_doc ( qmckl_exit_code qmckl_sm_splitting_core_doc (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -947,7 +947,7 @@ qmckl_exit_code qmckl_slagel_splitting_doc (
*** C sources *** C sources
#+begin_src c :tangle (eval c) :comments org #+begin_src c :tangle (eval c) :comments org
qmckl_exit_code qmckl_slagel_splitting_hpc( qmckl_exit_code qmckl_sm_splitting_core_hpc(
const qmckl_context context, const qmckl_context context,
uint64_t LDS, uint64_t LDS,
uint64_t Dim, uint64_t Dim,
@ -965,7 +965,7 @@ qmckl_exit_code qmckl_slagel_splitting_hpc(
return qmckl_failwith( return qmckl_failwith(
context, context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_slagel_splitting_hpc", "qmckl_sm_splitting_core_hpc",
NULL); NULL);
} }
@ -1033,7 +1033,7 @@ qmckl_exit_code qmckl_slagel_splitting_hpc(
#+NAME:slagel_splitting_template_code #+NAME:slagel_splitting_template_code
#+begin_src c #+begin_src c
static inline qmckl_exit_code qmckl_slagel_splitting_{Dim}( static inline qmckl_exit_code qmckl_sm_splitting_core_{Dim}(
const qmckl_context context, const qmckl_context context,
uint64_t N_updates, uint64_t N_updates,
const double* __restrict Updates, const double* __restrict Updates,
@ -1049,7 +1049,7 @@ static inline qmckl_exit_code qmckl_slagel_splitting_{Dim}(
return qmckl_failwith( return qmckl_failwith(
context, context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_slagel_splitting_{Dim}", "qmckl_sm_splitting_core_{Dim}",
NULL); NULL);
} }
@ -1132,7 +1132,7 @@ return '\n'.join(result)
#+begin_src python :noweb yes #+begin_src python :noweb yes
text=""" text="""
case {Dim}: { case {Dim}: {
return qmckl_slagel_splitting_{Dim}( return qmckl_sm_splitting_core_{Dim}(
context, context,
N_updates, N_updates,
Updates, Updates,
@ -1159,7 +1159,7 @@ return '\n'.join(result)
#+end_src #+end_src
#+begin_src c :tangle (eval c) :comments org :noweb yes #+begin_src c :tangle (eval c) :comments org :noweb yes
qmckl_exit_code qmckl_slagel_splitting( qmckl_exit_code qmckl_sm_splitting_core(
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1184,7 +1184,7 @@ qmckl_exit_code qmckl_slagel_splitting(
} }
} }
else { // Updating smaller sub-matrix else { // Updating smaller sub-matrix
return qmckl_slagel_splitting_hpc( return qmckl_sm_splitting_core_hpc(
context, context,
LDS, LDS,
Dim, Dim,
@ -1199,7 +1199,7 @@ qmckl_exit_code qmckl_slagel_splitting(
determinant); determinant);
} }
#else #else
// return qmckl_slagel_splitting_doc( // return qmckl_sm_splitting_core_doc(
// context, // context,
// LDS, // LDS,
// Dim, // Dim,
@ -1212,7 +1212,7 @@ qmckl_exit_code qmckl_slagel_splitting(
// later_index, // later_index,
// later, // later,
// determinant); // determinant);
return qmckl_slagel_splitting_hpc( return qmckl_sm_splitting_core_hpc(
context, context,
LDS, LDS,
Dim, Dim,
@ -1233,17 +1233,17 @@ qmckl_exit_code qmckl_slagel_splitting(
*** Fortran interfaces (exposed in qmckl_f.F90) *** Fortran interfaces (exposed in qmckl_f.F90)
:PROPERTIES: :PROPERTIES:
:Name: qmckl_slagel_splitting :Name: qmckl_sm_splitting_core
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
#+CALL: generate_f_interface(table=qmckl_slagel_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_slagel_splitting_hpc") #+CALL: generate_f_interface(table=qmckl_sm_splitting_core_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting_core_hpc")
#+RESULTS: #+RESULTS:
#+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_slagel_splitting_hpc & integer(c_int32_t) function qmckl_sm_splitting_core_hpc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, &
Slater_inv, later_updates, later_index, later, determinant) & Slater_inv, later_updates, later_index, later, determinant) &
bind(C) bind(C)
@ -1264,16 +1264,16 @@ interface
integer (c_int64_t) , intent(inout) :: later integer (c_int64_t) , intent(inout) :: later
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_slagel_splitting_hpc end function qmckl_sm_splitting_core_hpc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_slagel_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_slagel_splitting_doc") #+CALL: generate_f_interface(table=qmckl_sm_splitting_core_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting_core_doc")
#+RESULTS: #+RESULTS:
#+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_slagel_splitting_doc & integer(c_int32_t) function qmckl_sm_splitting_core_doc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, &
Slater_inv, later_updates, later_index, later, determinant) & Slater_inv, later_updates, later_index, later, determinant) &
bind(C) bind(C)
@ -1294,16 +1294,16 @@ interface
integer (c_int64_t) , intent(inout) :: later integer (c_int64_t) , intent(inout) :: later
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_slagel_splitting_doc end function qmckl_sm_splitting_core_doc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_slagel_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_slagel_splitting") #+CALL: generate_f_interface(table=qmckl_sm_splitting_core_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting_core")
#+RESULTS: #+RESULTS:
#+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_slagel_splitting & integer(c_int32_t) function qmckl_sm_splitting_core &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, &
Slater_inv, later_updates, later_index, later, determinant) & Slater_inv, later_updates, later_index, later, determinant) &
bind(C) bind(C)
@ -1324,7 +1324,7 @@ interface
integer (c_int64_t) , intent(inout) :: later integer (c_int64_t) , intent(inout) :: later
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_slagel_splitting end function qmckl_sm_splitting_core
end interface end interface
#+end_src #+end_src
@ -1334,9 +1334,9 @@ with Sherman-Morrison and update splitting. Please look at the performance recco
* Sherman-Morrison with Slagel Splitting * Sherman-Morrison with Slagel Splitting
** ~qmckl_sherman_morrison_splitting~ ** ~qmckl_sm_splitting~
:PROPERTIES: :PROPERTIES:
:Name: qmckl_sherman_morrison_splitting :Name: qmckl_sm_splitting
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
@ -1357,7 +1357,7 @@ If the determinant of the Slater-matrix is passed, it will be updated to the det
from applying the updates to the original matrix. from applying the updates to the original matrix.
*** API *** API
#+NAME: qmckl_sherman_morrison_splitting_args #+NAME: qmckl_sm_splitting_args
| Variable | Type | In/Out | Description | | Variable | Type | In/Out | Description |
|---------------+-----------------------+--------+------------------------------------------------------| |---------------+-----------------------+--------+------------------------------------------------------|
| context | qmckl_context | in | Global state | | context | qmckl_context | in | Global state |
@ -1386,7 +1386,7 @@ able to do numerically correct computations, it does not do it in the most effic
not be used in real workloads. not be used in real workloads.
#+begin_src f90 :tangle (eval f) #+begin_src f90 :tangle (eval f)
integer function qmckl_sherman_morrison_splitting_doc_f(context, & integer function qmckl_sm_splitting_doc_f(context, &
lds, dim, & lds, dim, &
nupdates, & nupdates, &
upds, & upds, &
@ -1422,21 +1422,21 @@ integer function qmckl_sherman_morrison_splitting_doc_f(context, &
info = QMCKL_SUCCESS info = QMCKL_SUCCESS
end function qmckl_sherman_morrison_splitting_doc_f end function qmckl_sm_splitting_doc_f
#+end_src #+end_src
**** C interface to the pedagogical kernel (not directly exposed) **** C interface to the pedagogical kernel (not directly exposed)
The following Fortran function ~qmckl_slagel_splitting_doc~ makes sure The following Fortran function ~qmckl_sm_splitting_core_doc~ makes sure
that the pedagogical kernel ~qmckl_slagel_splitting_doc_f~, written in that the pedagogical kernel ~qmckl_sm_splitting_core_doc_f~, written in
Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function Fortran, can be called from C using the ~ISO_C_BINDING~. The Fortran function
~qmckl_slagel_splitting_doc~ will be exposed in the header file 'qmckl.h' ~qmckl_sm_splitting_core_doc~ will be exposed in the header file 'qmckl.h'
for C users and in the module file 'qmckl_f.F90' for Fortran users. for C users and in the module file 'qmckl_f.F90' for Fortran users.
#+CALL: generate_c_interface(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_splitting_doc") #+CALL: generate_c_interface(table=qmckl_sm_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sm_splitting_doc")
#+RESULTS: #+RESULTS:
#+begin_src f90 :tangle (eval f) :comments org :exports none #+begin_src f90 :tangle (eval f) :comments org :exports none
integer(c_int32_t) function qmckl_sherman_morrison_splitting_doc & integer(c_int32_t) function qmckl_sm_splitting_doc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) result(info) bind(C) result(info)
@ -1453,20 +1453,20 @@ integer(c_int32_t) function qmckl_sherman_morrison_splitting_doc &
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
integer(c_int32_t), external :: qmckl_sherman_morrison_splitting_doc_f integer(c_int32_t), external :: qmckl_sm_splitting_doc_f
info = qmckl_sherman_morrison_splitting_doc_f & info = qmckl_sm_splitting_doc_f &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant)
end function qmckl_sherman_morrison_splitting_doc end function qmckl_sm_splitting_doc
#+end_src #+end_src
*** C headers (exposed in qmckl.h) *** C headers (exposed in qmckl.h)
#+CALL: generate_c_header(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("CRetType"),fname=get_value("Name")) #+CALL: generate_c_header(table=qmckl_sm_splitting_args,rettyp=get_value("CRetType"),fname=get_value("Name"))
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_sherman_morrison_splitting ( qmckl_exit_code qmckl_sm_splitting (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1478,11 +1478,11 @@ qmckl_exit_code qmckl_sherman_morrison_splitting (
double* determinant ); double* determinant );
#+end_src #+end_src
#+CALL: generate_c_header(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_splitting_hpc") #+CALL: generate_c_header(table=qmckl_sm_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sm_splitting_hpc")
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_sherman_morrison_splitting_hpc ( qmckl_exit_code qmckl_sm_splitting_hpc (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1494,11 +1494,11 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_hpc (
double* determinant ); double* determinant );
#+end_src #+end_src
#+CALL: generate_c_header(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sherman_morrison_splitting_doc") #+CALL: generate_c_header(table=qmckl_sm_splitting_args,rettyp=get_value("CRetType"),fname="qmckl_sm_splitting_doc")
#+RESULTS: #+RESULTS:
#+begin_src c :tangle (eval h_func) :comments org #+begin_src c :tangle (eval h_func) :comments org
qmckl_exit_code qmckl_sherman_morrison_splitting_doc ( qmckl_exit_code qmckl_sm_splitting_doc (
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1515,7 +1515,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_doc (
#+begin_src python :noweb yes #+begin_src python :noweb yes
text=""" text="""
case {Dim}: { case {Dim}: {
rc = qmckl_slagel_splitting_{Dim}( rc = qmckl_sm_splitting_core_{Dim}(
context, context,
N_updates, N_updates,
Updates, Updates,
@ -1536,7 +1536,7 @@ return '\n'.join(result)
#+end_src #+end_src
#+begin_src c :tangle (eval c) :comments org :noweb yes #+begin_src c :tangle (eval c) :comments org :noweb yes
qmckl_exit_code qmckl_sherman_morrison_splitting_hpc( qmckl_exit_code qmckl_sm_splitting_hpc(
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1551,7 +1551,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_hpc(
return qmckl_failwith( return qmckl_failwith(
context, context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_sherman_morrison_splitting_hpc", "qmckl_sm_splitting_hpc",
NULL); NULL);
} }
@ -1569,7 +1569,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_hpc(
} }
} }
} else { } else {
rc = qmckl_slagel_splitting_hpc( rc = qmckl_sm_splitting_core_hpc(
context, LDS, Dim, N_updates, Updates, Updates_index, context, LDS, Dim, N_updates, Updates, Updates_index,
breakdown, Slater_inv, later_updates, breakdown, Slater_inv, later_updates,
later_index, &later, determinant); later_index, &later, determinant);
@ -1577,7 +1577,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_hpc(
if (rc != QMCKL_SUCCESS) return QMCKL_FAILURE; if (rc != QMCKL_SUCCESS) return QMCKL_FAILURE;
if (later > 0) { if (later > 0) {
qmckl_exit_code rc = qmckl_sherman_morrison_splitting_hpc( qmckl_exit_code rc = qmckl_sm_splitting_hpc(
context, LDS, Dim, later, context, LDS, Dim, later,
later_updates, later_index, later_updates, later_index,
breakdown, Slater_inv, determinant); breakdown, Slater_inv, determinant);
@ -1589,7 +1589,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting_hpc(
#+end_src #+end_src
#+begin_src c :tangle (eval c) :comment org #+begin_src c :tangle (eval c) :comment org
qmckl_exit_code qmckl_sherman_morrison_splitting( qmckl_exit_code qmckl_sm_splitting(
const qmckl_context context, const qmckl_context context,
const uint64_t LDS, const uint64_t LDS,
const uint64_t Dim, const uint64_t Dim,
@ -1604,11 +1604,11 @@ qmckl_exit_code qmckl_sherman_morrison_splitting(
return qmckl_failwith( return qmckl_failwith(
context, context,
QMCKL_NULL_CONTEXT, QMCKL_NULL_CONTEXT,
"qmckl_sherman_morrison_splitting", "qmckl_sm_splitting",
NULL); NULL);
} }
#ifdef HAS_HPC #ifdef HAS_HPC
return qmckl_sherman_morrison_splitting_hpc( return qmckl_sm_splitting_hpc(
context, context,
LDS, LDS,
Dim, Dim,
@ -1619,7 +1619,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting(
Slater_inv, Slater_inv,
determinant); determinant);
#else #else
// return qmckl_sherman_morrison_splitting_doc( // return qmckl_sm_splitting_doc(
// context, // context,
// LDS, // LDS,
// Dim, // Dim,
@ -1629,7 +1629,7 @@ qmckl_exit_code qmckl_sherman_morrison_splitting(
// breakdown, // breakdown,
// Slater_inv, // Slater_inv,
// determinant); // determinant);
return qmckl_sherman_morrison_splitting_hpc( return qmckl_sm_splitting_hpc(
context, context,
LDS, LDS,
Dim, Dim,
@ -1647,17 +1647,17 @@ qmckl_exit_code qmckl_sherman_morrison_splitting(
*** Fortran interfaces (exposed in qmckl_f.F90) *** Fortran interfaces (exposed in qmckl_f.F90)
:PROPERTIES: :PROPERTIES:
:Name: qmckl_sherman_morrison_naive :Name: qmckl_sm_naive
:CRetType: qmckl_exit_code :CRetType: qmckl_exit_code
:FRetType: qmckl_exit_code :FRetType: qmckl_exit_code
:END: :END:
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_splitting_hpc") #+CALL: generate_f_interface(table=qmckl_sm_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting_hpc")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_splitting_hpc & integer(c_int32_t) function qmckl_sm_splitting_hpc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -1674,16 +1674,16 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_splitting_hpc end function qmckl_sm_splitting_hpc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_splitting_doc") #+CALL: generate_f_interface(table=qmckl_sm_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting_doc")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_splitting_doc & integer(c_int32_t) function qmckl_sm_splitting_doc &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -1700,16 +1700,16 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_splitting_doc end function qmckl_sm_splitting_doc
end interface end interface
#+end_src #+end_src
#+CALL: generate_f_interface(table=qmckl_sherman_morrison_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sherman_morrison_splitting") #+CALL: generate_f_interface(table=qmckl_sm_splitting_args,rettyp=get_value("FRetType"),fname="qmckl_sm_splitting")
#+RESULTS: #+RESULTS:
#+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_sherman_morrison_splitting & integer(c_int32_t) function qmckl_sm_splitting &
(context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) & (context, LDS, Dim, N_updates, Updates, Updates_index, breakdown, Slater_inv, determinant) &
bind(C) bind(C)
use, intrinsic :: iso_c_binding use, intrinsic :: iso_c_binding
@ -1726,7 +1726,7 @@ interface
real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS) real (c_double ) , intent(inout) :: Slater_inv(Dim*LDS)
real (c_double ) , intent(inout) :: determinant real (c_double ) , intent(inout) :: determinant
end function qmckl_sherman_morrison_splitting end function qmckl_sm_splitting
end interface end interface
#+end_src #+end_src
@ -1739,7 +1739,7 @@ assert(Updates3 != NULL);
assert(Updates_index3 != NULL); assert(Updates_index3 != NULL);
assert(Slater_inv3_2 != NULL); assert(Slater_inv3_2 != NULL);
det = -1.23743195512859e-09; det = -1.23743195512859e-09;
rc = qmckl_sherman_morrison_splitting(context, LDS, Dim, N_updates3, Updates3, Updates_index3, breakdown, Slater_inv3_2, &det); rc = qmckl_sm_splitting(context, LDS, Dim, N_updates3, Updates3, Updates_index3, breakdown, Slater_inv3_2, &det);
assert(fabs(det - 1.602708950725074e-10) < 1e-15); assert(fabs(det - 1.602708950725074e-10) < 1e-15);
for (unsigned int i = 0; i < Dim; i++) { for (unsigned int i = 0; i < Dim; i++) {
for (unsigned int j = 0; j < Dim; j++) { for (unsigned int j = 0; j < Dim; j++) {