mirror of
https://github.com/TREX-CoE/qmckl.git
synced 2025-01-10 21:18:37 +01:00
Bug fix in tests. #25
This commit is contained in:
parent
11eee81f84
commit
081e27dd92
@ -326,12 +326,16 @@ const uint64_t Updates_index[2] = {0, 0};
|
|||||||
const double Updates[4] = {0.0, 0.0, 0.0, 0.0};
|
const double Updates[4] = {0.0, 0.0, 0.0, 0.0};
|
||||||
double Slater_inv[4] = {0.0, 0.0, 0.0, 0.0};
|
double Slater_inv[4] = {0.0, 0.0, 0.0, 0.0};
|
||||||
|
|
||||||
|
// [TODO : FMJC ] add realistic tests
|
||||||
|
|
||||||
rc = qmckl_sherman_morrison_c(context, Dim, N_updates, Updates, Updates_index, Slater_inv);
|
rc = qmckl_sherman_morrison_c(context, Dim, N_updates, Updates, Updates_index, Slater_inv);
|
||||||
assert(rc == QMCKL_SUCCESS);
|
assert(rc == QMCKL_SUCCESS);
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
* Woodbury 2x2
|
* Woodbury 2x2
|
||||||
|
|
||||||
|
[TODO: FMJC] Add main body intro.
|
||||||
|
|
||||||
** ~qmckl_woodbury_2~
|
** ~qmckl_woodbury_2~
|
||||||
:PROPERTIES:
|
:PROPERTIES:
|
||||||
@ -340,14 +344,18 @@ assert(rc == QMCKL_SUCCESS);
|
|||||||
:FRetType: qmckl_exit_code
|
:FRetType: qmckl_exit_code
|
||||||
:END:
|
:END:
|
||||||
|
|
||||||
This is the simplest of the available Sherman-Morrison-Woodbury kernels in QMCkl. It applies rank-1 updates one by one in the order that is given. It only checks if the denominator in the Sherman-Morrison formula is not too close to zero (and exit with an error if it does) during the application of an update.
|
This is the simplest of the available Sherman-Morrison-Woodbury
|
||||||
|
kernels in QMCkl. It applies rank-1 updates one by one in the order
|
||||||
|
that is given. It only checks if the denominator in the
|
||||||
|
Sherman-Morrison formula is not too close to zero (and exit with an
|
||||||
|
error if it does) during the application of an update.
|
||||||
|
|
||||||
#+NAME: qmckl_woodbury_2_args
|
#+NAME: qmckl_woodbury_2_args
|
||||||
| qmckl_context | context | in | Global state |
|
| qmckl_context | context | in | Global state |
|
||||||
| uint64_t | Dim | in | Leading dimension of Slater_inv |
|
| uint64_t | Dim | in | Leading dimension of Slater_inv |
|
||||||
| double | Updates[2*Dim] | in | Array containing the updates |
|
| double | Updates[2*Dim] | in | Array containing the updates |
|
||||||
| uint64_t | Updates_index[2] | in | Array containing the rank-1 updates |
|
| uint64_t | Updates_index[2] | in | Array containing the rank-1 updates |
|
||||||
| double | Slater_inv[Dim*Dim] | inout | Array containing the inverse of a Slater-matrix |
|
| double | Slater_inv[Dim*Dim] | inout | Array containing the inverse of a Slater-matrix |
|
||||||
|
|
||||||
*** Requirements
|
*** Requirements
|
||||||
|
|
||||||
@ -463,7 +471,7 @@ qmckl_exit_code qmckl_woodbury_2_c(const qmckl_context context,
|
|||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
*** Performance
|
*** Performance
|
||||||
|
|
||||||
** C interface :noexport:
|
** C interface :noexport:
|
||||||
@ -520,12 +528,14 @@ qmckl_exit_code qmckl_woodbury_2_c(const qmckl_context context,
|
|||||||
|
|
||||||
|
|
||||||
#+begin_src c :tangle (eval c_test)
|
#+begin_src c :tangle (eval c_test)
|
||||||
const uint64_t Dim2 = 2;
|
const uint64_t woodbury_Dim = 2;
|
||||||
const uint64_t Updates_index2[2] = {0, 0};
|
const uint64_t woodbury_Updates_index[2] = {1, 1};
|
||||||
const double Updates2[4] = {0.0, 0.0, 0.0, 0.0};
|
const double woodbury_Updates[4] = {1.0, 1.0, 1.0, 1.0};
|
||||||
double Slater_inv2[4] = {0.0, 0.0, 0.0, 0.0};
|
double woodbury_Slater_inv[4] = {1.0, 1.0, 1.0, 1.0};
|
||||||
|
|
||||||
rc = qmckl_woodbury_2_c(context, Dim, Updates, Updates_index, Slater_inv);
|
// [TODO : FMJC ] add realistic tests
|
||||||
|
|
||||||
|
rc = qmckl_woodbury_2_c(context, woodbury_Dim, woodbury_Updates, woodbury_Updates_index, woodbury_Slater_inv);
|
||||||
assert(rc == QMCKL_SUCCESS);
|
assert(rc == QMCKL_SUCCESS);
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user