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

Deploying to gh-pages from @ TREX-CoE/qmckl@4bcb9b980c 🚀

This commit is contained in:
scemama 2021-06-10 21:56:00 +00:00
parent c6923a32f0
commit 50388bc809
12 changed files with 1538 additions and 1164 deletions

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>QMCkl source code documentation</title> <title>QMCkl source code documentation</title>
@ -352,7 +352,7 @@ and bug reports should be submitted at
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Introduction</title> <title>Introduction</title>
@ -333,30 +333,30 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#orgf3f82ce">1. Using QMCkl</a></li> <li><a href="#orgf7b3c85">1. Using QMCkl</a></li>
<li><a href="#orgeb146a2">2. Developing in QMCkl</a> <li><a href="#orgfa4a2d8">2. Developing in QMCkl</a>
<ul> <ul>
<li><a href="#org7939fce">2.1. Literate programming</a></li> <li><a href="#org53728c1">2.1. Literate programming</a></li>
<li><a href="#org8abf38d">2.2. Source code editing</a></li> <li><a href="#org8954f61">2.2. Source code editing</a></li>
<li><a href="#org87e271c">2.3. Choice of the programming language</a></li> <li><a href="#orga97e1dc">2.3. Choice of the programming language</a></li>
<li><a href="#orge97bd5d">2.4. Coding rules</a></li> <li><a href="#orgd9b526f">2.4. Coding rules</a></li>
<li><a href="#org1e921de">2.5. Design of the library</a></li> <li><a href="#org3138038">2.5. Design of the library</a></li>
<li><a href="#org6959be5">2.6. Naming conventions</a></li> <li><a href="#orge3b8c07">2.6. Naming conventions</a></li>
<li><a href="#orge848922">2.7. Application programming interface</a></li> <li><a href="#orge1fd5ee">2.7. Application programming interface</a></li>
<li><a href="#org83db4d5">2.8. Global state</a></li> <li><a href="#org14311bc">2.8. Global state</a></li>
<li><a href="#org5f633aa">2.9. Headers</a></li> <li><a href="#org260e02e">2.9. Headers</a></li>
<li><a href="#org9e7c8d4">2.10. Low-level functions</a></li> <li><a href="#org83fd155">2.10. Low-level functions</a></li>
<li><a href="#org1ce4d10">2.11. High-level functions</a></li> <li><a href="#org8a71b99">2.11. High-level functions</a></li>
<li><a href="#org2d77c75">2.12. Numerical precision</a></li> <li><a href="#orgc18bc7f">2.12. Numerical precision</a></li>
<li><a href="#org6739956">2.13. Algorithms</a></li> <li><a href="#orgd58f9d0">2.13. Algorithms</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-orgf3f82ce" class="outline-2"> <div id="outline-container-orgf7b3c85" class="outline-2">
<h2 id="orgf3f82ce"><span class="section-number-2">1</span> Using QMCkl</h2> <h2 id="orgf7b3c85"><span class="section-number-2">1</span> Using QMCkl</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
The <code>qmckl.h</code> header file installed in the <code>${prefix}/include</code> directory The <code>qmckl.h</code> header file installed in the <code>${prefix}/include</code> directory
@ -385,12 +385,12 @@ Both files are located in the <code>include/</code> directory.
</div> </div>
</div> </div>
<div id="outline-container-orgeb146a2" class="outline-2"> <div id="outline-container-orgfa4a2d8" class="outline-2">
<h2 id="orgeb146a2"><span class="section-number-2">2</span> Developing in QMCkl</h2> <h2 id="orgfa4a2d8"><span class="section-number-2">2</span> Developing in QMCkl</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
</div> </div>
<div id="outline-container-org7939fce" class="outline-3"> <div id="outline-container-org53728c1" class="outline-3">
<h3 id="org7939fce"><span class="section-number-3">2.1</span> Literate programming</h3> <h3 id="org53728c1"><span class="section-number-3">2.1</span> Literate programming</h3>
<div class="outline-text-3" id="text-2-1"> <div class="outline-text-3" id="text-2-1">
<p> <p>
In a traditional source code, most of the lines of source files of a program 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.
</div> </div>
</div> </div>
<div id="outline-container-org8abf38d" class="outline-3"> <div id="outline-container-org8954f61" class="outline-3">
<h3 id="org8abf38d"><span class="section-number-3">2.2</span> Source code editing</h3> <h3 id="org8954f61"><span class="section-number-3">2.2</span> Source code editing</h3>
<div class="outline-text-3" id="text-2-2"> <div class="outline-text-3" id="text-2-2">
<p> <p>
For a tutorial on literate programming with org-mode, follow <a href="http://www.howardism.org/Technical/Emacs/literate-programming-tutorial.html">this link</a>. For a tutorial on literate programming with org-mode, follow <a href="http://www.howardism.org/Technical/Emacs/literate-programming-tutorial.html">this link</a>.
@ -467,8 +467,8 @@ org-mode.
</div> </div>
</div> </div>
<div id="outline-container-org87e271c" class="outline-3"> <div id="outline-container-orga97e1dc" class="outline-3">
<h3 id="org87e271c"><span class="section-number-3">2.3</span> Choice of the programming language</h3> <h3 id="orga97e1dc"><span class="section-number-3">2.3</span> Choice of the programming language</h3>
<div class="outline-text-3" id="text-2-3"> <div class="outline-text-3" id="text-2-3">
<p> <p>
Most of the codes of the <a href="https://trex-coe.eu">TREX CoE</a> are written in Fortran with some scripts in Most of the codes of the <a href="https://trex-coe.eu">TREX CoE</a> are written in Fortran with some scripts in
@ -516,8 +516,8 @@ For more guidelines on using Fortran to generate a C interface, see
</div> </div>
</div> </div>
<div id="outline-container-orge97bd5d" class="outline-3"> <div id="outline-container-orgd9b526f" class="outline-3">
<h3 id="orge97bd5d"><span class="section-number-3">2.4</span> Coding rules</h3> <h3 id="orgd9b526f"><span class="section-number-3">2.4</span> Coding rules</h3>
<div class="outline-text-3" id="text-2-4"> <div class="outline-text-3" id="text-2-4">
<p> <p>
The authors should follow the recommendations of the C99 The authors should follow the recommendations of the C99
@ -535,8 +535,8 @@ Compliance can be checked with <code>cppcheck</code> as:
</div> </div>
</div> </div>
<div id="outline-container-org1e921de" class="outline-3"> <div id="outline-container-org3138038" class="outline-3">
<h3 id="org1e921de"><span class="section-number-3">2.5</span> Design of the library</h3> <h3 id="org3138038"><span class="section-number-3">2.5</span> Design of the library</h3>
<div class="outline-text-3" id="text-2-5"> <div class="outline-text-3" id="text-2-5">
<p> <p>
The proposed API should allow the library to: deal with memory transfers The proposed API should allow the library to: deal with memory transfers
@ -547,8 +547,8 @@ functions (see below).
</div> </div>
</div> </div>
<div id="outline-container-org6959be5" class="outline-3"> <div id="outline-container-orge3b8c07" class="outline-3">
<h3 id="org6959be5"><span class="section-number-3">2.6</span> Naming conventions</h3> <h3 id="orge3b8c07"><span class="section-number-3">2.6</span> Naming conventions</h3>
<div class="outline-text-3" id="text-2-6"> <div class="outline-text-3" id="text-2-6">
<p> <p>
To avoid namespace collisions, we use <code>qmckl_</code> as a prefix for all exported To avoid namespace collisions, we use <code>qmckl_</code> as a prefix for all exported
@ -573,8 +573,8 @@ form is allowed.
</div> </div>
</div> </div>
<div id="outline-container-orge848922" class="outline-3"> <div id="outline-container-orge1fd5ee" class="outline-3">
<h3 id="orge848922"><span class="section-number-3">2.7</span> Application programming interface</h3> <h3 id="orge1fd5ee"><span class="section-number-3">2.7</span> Application programming interface</h3>
<div class="outline-text-3" id="text-2-7"> <div class="outline-text-3" id="text-2-7">
<p> <p>
In the C language, the number of bits used by the integer types can change 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.
</div> </div>
</div> </div>
<div id="outline-container-org83db4d5" class="outline-3"> <div id="outline-container-org14311bc" class="outline-3">
<h3 id="org83db4d5"><span class="section-number-3">2.8</span> Global state</h3> <h3 id="org14311bc"><span class="section-number-3">2.8</span> Global state</h3>
<div class="outline-text-3" id="text-2-8"> <div class="outline-text-3" id="text-2-8">
<p> <p>
Global variables should be avoided in the library, because it is Global variables should be avoided in the library, because it is
possible that one single program needs to use multiple instances possible that one single program needs to use multiple instances
of the library. To solve this problem we propose to use a pointer of the library. To solve this problem we propose to use a pointer
to a <a href="./qmckl_context.html"><code>context</code></a> variable, built by the library with the to a <a href="./qmckl_context.html"><code>context</code></a> variable, built by the library with the
<code>qmckl_context_create</code> function. The <a id="orgad33dac">=context=</a> contains the global <code>qmckl_context_create</code> function. The <a id="org34e8b1f">=context=</a> contains the global
state of the library, and is used as the first argument of many state of the library, and is used as the first argument of many
QMCkl functions. QMCkl functions.
</p> </p>
@ -628,8 +628,8 @@ the state is done by setters and getters, prefixed by
</div> </div>
</div> </div>
<div id="outline-container-org5f633aa" class="outline-3"> <div id="outline-container-org260e02e" class="outline-3">
<h3 id="org5f633aa"><span class="section-number-3">2.9</span> Headers</h3> <h3 id="org260e02e"><span class="section-number-3">2.9</span> Headers</h3>
<div class="outline-text-3" id="text-2-9"> <div class="outline-text-3" id="text-2-9">
<p> <p>
A single <code>qmckl.h</code> header to be distributed by the library A single <code>qmckl.h</code> header to be distributed by the library
@ -717,8 +717,8 @@ and the types definitions should be written in the <code>*fh_type.f90</code> fil
</div> </div>
</div> </div>
<div id="outline-container-org9e7c8d4" class="outline-3"> <div id="outline-container-org83fd155" class="outline-3">
<h3 id="org9e7c8d4"><span class="section-number-3">2.10</span> Low-level functions</h3> <h3 id="org83fd155"><span class="section-number-3">2.10</span> Low-level functions</h3>
<div class="outline-text-3" id="text-2-10"> <div class="outline-text-3" id="text-2-10">
<p> <p>
Low-level functions are very simple functions which are leaves of 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).
<p> <p>
These functions are <i>pure</i>, and unaware of the QMCkl These functions are <i>pure</i>, and unaware of the QMCkl
<a href="#orgad33dac"><code>context</code></a>. They are not allowed to allocate/deallocate memory, and <a href="#org34e8b1f"><code>context</code></a>. They are not allowed to allocate/deallocate memory, and
if they need temporary memory it should be provided in input. if they need temporary memory it should be provided in input.
</p> </p>
</div> </div>
</div> </div>
<div id="outline-container-org1ce4d10" class="outline-3"> <div id="outline-container-org8a71b99" class="outline-3">
<h3 id="org1ce4d10"><span class="section-number-3">2.11</span> High-level functions</h3> <h3 id="org8a71b99"><span class="section-number-3">2.11</span> High-level functions</h3>
<div class="outline-text-3" id="text-2-11"> <div class="outline-text-3" id="text-2-11">
<p> <p>
High-level functions are at the top of the function call tree. High-level functions are at the top of the function call tree.
@ -747,27 +747,27 @@ temporary storage, to simplify the use of accelerators.
<p> <p>
The high-level functions should be pure, unless the introduction The high-level functions should be pure, unless the introduction
of non-purity is justified. All the side effects should be made in of non-purity is justified. All the side effects should be made in
the <a href="#orgad33dac"><code>context</code></a> variable. the <a href="#org34e8b1f"><code>context</code></a> variable.
</p> </p>
</div> </div>
</div> </div>
<div id="outline-container-org2d77c75" class="outline-3"> <div id="outline-container-orgc18bc7f" class="outline-3">
<h3 id="org2d77c75"><span class="section-number-3">2.12</span> Numerical precision</h3> <h3 id="orgc18bc7f"><span class="section-number-3">2.12</span> Numerical precision</h3>
<div class="outline-text-3" id="text-2-12"> <div class="outline-text-3" id="text-2-12">
<p> <p>
The number of bits of precision required for a function should be The number of bits of precision required for a function should be
given as an input of low-level computational functions. This input given as an input of low-level computational functions. This input
will be used to define the values of the different thresholds that will be used to define the values of the different thresholds that
might be used to avoid computing unnecessary noise. High-level might be used to avoid computing unnecessary noise. High-level
functions will use the precision specified in the <a href="#orgad33dac"><code>context</code></a> functions will use the precision specified in the <a href="#org34e8b1f"><code>context</code></a>
variable. variable.
</p> </p>
</div> </div>
</div> </div>
<div id="outline-container-org6739956" class="outline-3"> <div id="outline-container-orgd58f9d0" class="outline-3">
<h3 id="org6739956"><span class="section-number-3">2.13</span> Algorithms</h3> <h3 id="orgd58f9d0"><span class="section-number-3">2.13</span> Algorithms</h3>
<div class="outline-text-3" id="text-2-13"> <div class="outline-text-3" id="text-2-13">
<p> <p>
Reducing the scaling of an algorithm usually implies also reducing Reducing the scaling of an algorithm usually implies also reducing
@ -783,7 +783,7 @@ implemented adapted to different problem sizes.
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

File diff suppressed because it is too large Load Diff

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Context</title> <title>Context</title>
@ -311,21 +311,21 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org97495de">1. Context handling</a> <li><a href="#org3a492c0">1. Context handling</a>
<ul> <ul>
<li><a href="#org455023c">1.1. Data structure</a></li> <li><a href="#orge077fb7">1.1. Data structure</a></li>
<li><a href="#org439082a">1.2. Creation</a></li> <li><a href="#org2491980">1.2. Creation</a></li>
<li><a href="#org78e696c">1.3. Locking</a></li> <li><a href="#org026ae47">1.3. Locking</a></li>
<li><a href="#org82aaf26">1.4. <span class="todo TODO">TODO</span> Copy</a></li> <li><a href="#org4855d78">1.4. <span class="todo TODO">TODO</span> Copy</a></li>
<li><a href="#orgd2a1f42">1.5. Destroy</a></li> <li><a href="#org4695d6f">1.5. Destroy</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-org97495de" class="outline-2"> <div id="outline-container-org3a492c0" class="outline-2">
<h2 id="org97495de"><span class="section-number-2">1</span> Context handling</h2> <h2 id="org3a492c0"><span class="section-number-2">1</span> Context handling</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
The context variable is a handle for the state of the library, The context variable is a handle for the state of the library,
@ -338,7 +338,7 @@ A value of <code>QMCKL_NULL_CONTEXT</code> for the context is equivalent to a
</p> </p>
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c" id="org9f3c05a"><span style="color: #a020f0;">typedef</span> <span style="color: #228b22;">int64_t</span> <span style="color: #228b22;">qmckl_context</span> ; <pre class="src src-c" id="orgfd3497d"><span style="color: #a020f0;">typedef</span> <span style="color: #228b22;">int64_t</span> <span style="color: #228b22;">qmckl_context</span> ;
<span style="color: #483d8b;">#define</span> <span style="color: #a0522d;">QMCKL_NULL_CONTEXT</span> (qmckl_context) 0 <span style="color: #483d8b;">#define</span> <span style="color: #a0522d;">QMCKL_NULL_CONTEXT</span> (qmckl_context) 0
</pre> </pre>
</div> </div>
@ -356,8 +356,8 @@ and <code>ctx</code> is a <code>qmckl_context_struct*</code> pointer.
</p> </p>
</div> </div>
<div id="outline-container-org455023c" class="outline-3"> <div id="outline-container-orge077fb7" class="outline-3">
<h3 id="org455023c"><span class="section-number-3">1.1</span> Data structure</h3> <h3 id="orge077fb7"><span class="section-number-3">1.1</span> Data structure</h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<p> <p>
The context keeps a ``date'' that allows to check which data needs The context keeps a ``date'' that allows to check which data needs
@ -367,7 +367,7 @@ coordinates are updated.
<p> <p>
When a new element is added to the context, the functions When a new element is added to the context, the functions
<a href="#org439082a">qmckl<sub>context</sub><sub>create</sub></a>, <a href="#orgd2a1f42">qmckl<sub>context</sub><sub>destroy</sub></a> and <a href="#org82aaf26">qmckl<sub>context</sub><sub>copy</sub></a> <a href="#org2491980">qmckl<sub>context</sub><sub>create</sub></a>, <a href="#org4695d6f">qmckl<sub>context</sub><sub>destroy</sub></a> and <a href="#org4855d78">qmckl<sub>context</sub><sub>copy</sub></a>
should be updated inorder to make deep copies. should be updated inorder to make deep copies.
</p> </p>
@ -416,8 +416,8 @@ if the context is valid, <code>QMCKL_NULL_CONTEXT</code> otherwise.
</div> </div>
</div> </div>
<div id="outline-container-org439082a" class="outline-3"> <div id="outline-container-org2491980" class="outline-3">
<h3 id="org439082a"><span class="section-number-3">1.2</span> Creation</h3> <h3 id="org2491980"><span class="section-number-3">1.2</span> Creation</h3>
<div class="outline-text-3" id="text-1-2"> <div class="outline-text-3" id="text-1-2">
<p> <p>
To create a new context, <code>qmckl_context_create()</code> should be used. To create a new context, <code>qmckl_context_create()</code> should be used.
@ -460,17 +460,26 @@ To create a new context, <code>qmckl_context_create()</code> should be used.
} }
/* <span style="color: #b22222;">Initialize data </span>*/ /* <span style="color: #b22222;">Initialize data </span>*/
ctx-&gt;tag = VALID_TAG; {
ctx-&gt;tag = VALID_TAG;
<span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span> = (<span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span>) ctx; <span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span> = (<span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span>) ctx;
assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT ); assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT );
ctx-&gt;numprec.precision = QMCKL_DEFAULT_PRECISION; <span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #a0522d;">rc</span>;
ctx-&gt;numprec.range = QMCKL_DEFAULT_RANGE;
ctx-&gt;ao_basis.uninitialized = (1 &lt;&lt; 12) - 1; ctx-&gt;numprec.precision = QMCKL_DEFAULT_PRECISION;
ctx-&gt;nucleus.uninitialized = (1 &lt;&lt; 4) - 1; ctx-&gt;numprec.range = QMCKL_DEFAULT_RANGE;
ctx-&gt;electron.uninitialized = (1 &lt;&lt; 3) - 1;
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);
}
/* <span style="color: #b22222;">Allocate qmckl_memory_struct </span>*/ /* <span style="color: #b22222;">Allocate qmckl_memory_struct </span>*/
{ {
@ -493,8 +502,8 @@ To create a new context, <code>qmckl_context_create()</code> should be used.
</div> </div>
</div> </div>
</div> </div>
<div id="outline-container-org78e696c" class="outline-3"> <div id="outline-container-org026ae47" class="outline-3">
<h3 id="org78e696c"><span class="section-number-3">1.3</span> Locking</h3> <h3 id="org026ae47"><span class="section-number-3">1.3</span> Locking</h3>
<div class="outline-text-3" id="text-1-3"> <div class="outline-text-3" id="text-1-3">
<p> <p>
For thread safety, the context may be locked/unlocked. The lock is 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
</div> </div>
</div> </div>
<div id="outline-container-org82aaf26" class="outline-3"> <div id="outline-container-org4855d78" class="outline-3">
<h3 id="org82aaf26"><span class="section-number-3">1.4</span> <span class="todo TODO">TODO</span> Copy</h3> <h3 id="org4855d78"><span class="section-number-3">1.4</span> <span class="todo TODO">TODO</span> Copy</h3>
<div class="outline-text-3" id="text-1-4"> <div class="outline-text-3" id="text-1-4">
<p> <p>
<code>qmckl_context_copy</code> makes a deep copy of a context. It returns <code>qmckl_context_copy</code> 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
</div> </div>
</div> </div>
</div> </div>
<div id="outline-container-orgd2a1f42" class="outline-3"> <div id="outline-container-org4695d6f" class="outline-3">
<h3 id="orgd2a1f42"><span class="section-number-3">1.5</span> Destroy</h3> <h3 id="org4695d6f"><span class="section-number-3">1.5</span> Destroy</h3>
<div class="outline-text-3" id="text-1-5"> <div class="outline-text-3" id="text-1-5">
<p> <p>
The context is destroyed with <code>qmckl_context_destroy</code>, leaving the ancestors untouched. The context is destroyed with <code>qmckl_context_destroy</code>, leaving the ancestors untouched.
@ -643,7 +652,7 @@ It frees the context, and returns the previous context.
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Inter-particle distances</title> <title>Inter-particle distances</title>
@ -333,38 +333,38 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org972f6d4">1. Squared distance</a> <li><a href="#org048c5ad">1. Squared distance</a>
<ul> <ul>
<li><a href="#org694e0a7">1.1. <code>qmckl_distance_sq</code></a> <li><a href="#org9071f89">1.1. <code>qmckl_distance_sq</code></a>
<ul> <ul>
<li><a href="#org92c790b">1.1.1. Requirements</a></li> <li><a href="#orgfad67c4">1.1.1. Requirements</a></li>
<li><a href="#org606708e">1.1.2. C header</a></li> <li><a href="#org2699fbd">1.1.2. C header</a></li>
<li><a href="#org5b84cf3">1.1.3. Source</a></li> <li><a href="#org2a04b55">1.1.3. Source</a></li>
<li><a href="#orgb51e9a3">1.1.4. Performance</a></li> <li><a href="#org5a622d1">1.1.4. Performance</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
</li> </li>
<li><a href="#org0c8d0bc">2. Distance</a> <li><a href="#org9c99ff6">2. Distance</a>
<ul> <ul>
<li><a href="#orgae24a6f">2.1. <code>qmckl_distance</code></a> <li><a href="#orgca2baf3">2.1. <code>qmckl_distance</code></a>
<ul> <ul>
<li><a href="#orgbe15271">2.1.1. Requirements</a></li> <li><a href="#orgc1e6335">2.1.1. Requirements</a></li>
<li><a href="#org40c8dc0">2.1.2. C header</a></li> <li><a href="#org3518060">2.1.2. C header</a></li>
<li><a href="#orga142758">2.1.3. Source</a></li> <li><a href="#orgb3c76d6">2.1.3. Source</a></li>
<li><a href="#org5ffbe51">2.1.4. Performance</a></li> <li><a href="#orgb6f1ba2">2.1.4. Performance</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
</li> </li>
<li><a href="#org5d428dc">3. Rescaled Distance</a> <li><a href="#org9fd338b">3. Rescaled Distance</a>
<ul> <ul>
<li><a href="#org5c77e26">3.1. <code>qmckl_distance_rescaled</code></a> <li><a href="#org8cf1bcd">3.1. <code>qmckl_distance_rescaled</code></a>
<ul> <ul>
<li><a href="#org84ca003">3.1.1. Requirements</a></li> <li><a href="#org3f5c230">3.1.1. Requirements</a></li>
<li><a href="#org1804a4c">3.1.2. C header</a></li> <li><a href="#org3d1ce14">3.1.2. C header</a></li>
<li><a href="#org924e8e9">3.1.3. Source</a></li> <li><a href="#orgde25a61">3.1.3. Source</a></li>
<li><a href="#org3ff818c">3.1.4. Performance</a></li> <li><a href="#orgab9df15">3.1.4. Performance</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
@ -373,12 +373,12 @@ for the JavaScript code in this tag.
</div> </div>
</div> </div>
<div id="outline-container-org972f6d4" class="outline-2"> <div id="outline-container-org048c5ad" class="outline-2">
<h2 id="org972f6d4"><span class="section-number-2">1</span> Squared distance</h2> <h2 id="org048c5ad"><span class="section-number-2">1</span> Squared distance</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
</div> </div>
<div id="outline-container-org694e0a7" class="outline-3"> <div id="outline-container-org9071f89" class="outline-3">
<h3 id="org694e0a7"><span class="section-number-3">1.1</span> <code>qmckl_distance_sq</code></h3> <h3 id="org9071f89"><span class="section-number-3">1.1</span> <code>qmckl_distance_sq</code></h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<p> <p>
<code>qmckl_distance_sq</code> computes the matrix of the squared distances <code>qmckl_distance_sq</code> computes the matrix of the squared distances
@ -391,7 +391,7 @@ between all pairs of points in two sets, one point within each set:
\] \]
</p> </p>
<table id="org34fd2b8" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org45b1651" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -484,8 +484,8 @@ between all pairs of points in two sets, one point within each set:
</table> </table>
</div> </div>
<div id="outline-container-org92c790b" class="outline-4"> <div id="outline-container-orgfad67c4" class="outline-4">
<h4 id="org92c790b"><span class="section-number-4">1.1.1</span> Requirements</h4> <h4 id="orgfad67c4"><span class="section-number-4">1.1.1</span> Requirements</h4>
<div class="outline-text-4" id="text-1-1-1"> <div class="outline-text-4" id="text-1-1-1">
<ul class="org-ul"> <ul class="org-ul">
<li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li> <li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li>
@ -503,8 +503,8 @@ between all pairs of points in two sets, one point within each set:
</div> </div>
</div> </div>
<div id="outline-container-org606708e" class="outline-4"> <div id="outline-container-org2699fbd" class="outline-4">
<h4 id="org606708e"><span class="section-number-4">1.1.2</span> C header</h4> <h4 id="org2699fbd"><span class="section-number-4">1.1.2</span> C header</h4>
<div class="outline-text-4" id="text-1-1-2"> <div class="outline-text-4" id="text-1-1-2">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> ( <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> (
@ -524,8 +524,8 @@ between all pairs of points in two sets, one point within each set:
</div> </div>
</div> </div>
<div id="outline-container-org5b84cf3" class="outline-4"> <div id="outline-container-org2a04b55" class="outline-4">
<h4 id="org5b84cf3"><span class="section-number-4">1.1.3</span> Source</h4> <h4 id="org2a04b55"><span class="section-number-4">1.1.3</span> Source</h4>
<div class="outline-text-4" id="text-1-1-3"> <div class="outline-text-4" id="text-1-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_sq_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span> <pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_sq_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span>
@ -660,8 +660,8 @@ between all pairs of points in two sets, one point within each set:
</div> </div>
</div> </div>
<div id="outline-container-orgb51e9a3" class="outline-4"> <div id="outline-container-org5a622d1" class="outline-4">
<h4 id="orgb51e9a3"><span class="section-number-4">1.1.4</span> Performance</h4> <h4 id="org5a622d1"><span class="section-number-4">1.1.4</span> Performance</h4>
<div class="outline-text-4" id="text-1-1-4"> <div class="outline-text-4" id="text-1-1-4">
<p> <p>
This function is more efficient when <code>A</code> and <code>B</code> are This function is more efficient when <code>A</code> and <code>B</code> are
@ -671,12 +671,12 @@ transposed.
</div> </div>
</div> </div>
</div> </div>
<div id="outline-container-org0c8d0bc" class="outline-2"> <div id="outline-container-org9c99ff6" class="outline-2">
<h2 id="org0c8d0bc"><span class="section-number-2">2</span> Distance</h2> <h2 id="org9c99ff6"><span class="section-number-2">2</span> Distance</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
</div> </div>
<div id="outline-container-orgae24a6f" class="outline-3"> <div id="outline-container-orgca2baf3" class="outline-3">
<h3 id="orgae24a6f"><span class="section-number-3">2.1</span> <code>qmckl_distance</code></h3> <h3 id="orgca2baf3"><span class="section-number-3">2.1</span> <code>qmckl_distance</code></h3>
<div class="outline-text-3" id="text-2-1"> <div class="outline-text-3" id="text-2-1">
<p> <p>
<code>qmckl_distance</code> computes the matrix of the distances between all <code>qmckl_distance</code> computes the matrix of the distances between all
@ -694,7 +694,7 @@ If the input array is normal (<code>'N'</code>), the xyz coordinates are in
the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortran. the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortran.
</p> </p>
<table id="orgbb278b5" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org4e0e964" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -787,8 +787,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</table> </table>
</div> </div>
<div id="outline-container-orgbe15271" class="outline-4"> <div id="outline-container-orgc1e6335" class="outline-4">
<h4 id="orgbe15271"><span class="section-number-4">2.1.1</span> Requirements</h4> <h4 id="orgc1e6335"><span class="section-number-4">2.1.1</span> Requirements</h4>
<div class="outline-text-4" id="text-2-1-1"> <div class="outline-text-4" id="text-2-1-1">
<ul class="org-ul"> <ul class="org-ul">
<li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li> <li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li>
@ -806,8 +806,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-org40c8dc0" class="outline-4"> <div id="outline-container-org3518060" class="outline-4">
<h4 id="org40c8dc0"><span class="section-number-4">2.1.2</span> C header</h4> <h4 id="org3518060"><span class="section-number-4">2.1.2</span> C header</h4>
<div class="outline-text-4" id="text-2-1-2"> <div class="outline-text-4" id="text-2-1-2">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> ( <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> (
@ -827,8 +827,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-orga142758" class="outline-4"> <div id="outline-container-orgb3c76d6" class="outline-4">
<h4 id="orga142758"><span class="section-number-4">2.1.3</span> Source</h4> <h4 id="orgb3c76d6"><span class="section-number-4">2.1.3</span> Source</h4>
<div class="outline-text-4" id="text-2-1-3"> <div class="outline-text-4" id="text-2-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span> <pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span>
@ -995,8 +995,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-org5ffbe51" class="outline-4"> <div id="outline-container-orgb6f1ba2" class="outline-4">
<h4 id="org5ffbe51"><span class="section-number-4">2.1.4</span> Performance</h4> <h4 id="orgb6f1ba2"><span class="section-number-4">2.1.4</span> Performance</h4>
<div class="outline-text-4" id="text-2-1-4"> <div class="outline-text-4" id="text-2-1-4">
<p> <p>
This function is more efficient when <code>A</code> and <code>B</code> are transposed. This function is more efficient when <code>A</code> and <code>B</code> are transposed.
@ -1006,12 +1006,12 @@ This function is more efficient when <code>A</code> and <code>B</code> are trans
</div> </div>
</div> </div>
<div id="outline-container-org5d428dc" class="outline-2"> <div id="outline-container-org9fd338b" class="outline-2">
<h2 id="org5d428dc"><span class="section-number-2">3</span> Rescaled Distance</h2> <h2 id="org9fd338b"><span class="section-number-2">3</span> Rescaled Distance</h2>
<div class="outline-text-2" id="text-3"> <div class="outline-text-2" id="text-3">
</div> </div>
<div id="outline-container-org5c77e26" class="outline-3"> <div id="outline-container-org8cf1bcd" class="outline-3">
<h3 id="org5c77e26"><span class="section-number-3">3.1</span> <code>qmckl_distance_rescaled</code></h3> <h3 id="org8cf1bcd"><span class="section-number-3">3.1</span> <code>qmckl_distance_rescaled</code></h3>
<div class="outline-text-3" id="text-3-1"> <div class="outline-text-3" id="text-3-1">
<p> <p>
<code>qmckl_distance_rescaled</code> computes the matrix of the rescaled distances between all <code>qmckl_distance_rescaled</code> computes the matrix of the rescaled distances between all
@ -1029,7 +1029,7 @@ If the input array is normal (<code>'N'</code>), the xyz coordinates are in
the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortran. the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortran.
</p> </p>
<table id="orgdba0e7d" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org2ae9219" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -1129,8 +1129,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</table> </table>
</div> </div>
<div id="outline-container-org84ca003" class="outline-4"> <div id="outline-container-org3f5c230" class="outline-4">
<h4 id="org84ca003"><span class="section-number-4">3.1.1</span> Requirements</h4> <h4 id="org3f5c230"><span class="section-number-4">3.1.1</span> Requirements</h4>
<div class="outline-text-4" id="text-3-1-1"> <div class="outline-text-4" id="text-3-1-1">
<ul class="org-ul"> <ul class="org-ul">
<li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li> <li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li>
@ -1148,8 +1148,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-org1804a4c" class="outline-4"> <div id="outline-container-org3d1ce14" class="outline-4">
<h4 id="org1804a4c"><span class="section-number-4">3.1.2</span> C header</h4> <h4 id="org3d1ce14"><span class="section-number-4">3.1.2</span> C header</h4>
<div class="outline-text-4" id="text-3-1-2"> <div class="outline-text-4" id="text-3-1-2">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> ( <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_distance_rescaled</span> (
@ -1170,8 +1170,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-org924e8e9" class="outline-4"> <div id="outline-container-orgde25a61" class="outline-4">
<h4 id="org924e8e9"><span class="section-number-4">3.1.3</span> Source</h4> <h4 id="orgde25a61"><span class="section-number-4">3.1.3</span> Source</h4>
<div class="outline-text-4" id="text-3-1-3"> <div class="outline-text-4" id="text-3-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_rescaled_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span> <pre class="src src-f90"><span style="color: #228b22;">integer</span><span style="color: #a0522d;"> function qmckl_distance_rescaled_f(context, transa, transb, m, n, </span><span style="color: #a020f0;">&amp;</span>
@ -1341,8 +1341,8 @@ the leading dimension: <code>[n][3]</code> in C and <code>(3,n)</code> in Fortra
</div> </div>
</div> </div>
<div id="outline-container-org3ff818c" class="outline-4"> <div id="outline-container-orgab9df15" class="outline-4">
<h4 id="org3ff818c"><span class="section-number-4">3.1.4</span> Performance</h4> <h4 id="orgab9df15"><span class="section-number-4">3.1.4</span> Performance</h4>
<div class="outline-text-4" id="text-3-1-4"> <div class="outline-text-4" id="text-3-1-4">
<p> <p>
This function is more efficient when <code>A</code> and <code>B</code> are transposed. This function is more efficient when <code>A</code> and <code>B</code> are transposed.
@ -1354,7 +1354,7 @@ This function is more efficient when <code>A</code> and <code>B</code> are trans
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Electrons</title> <title>Electrons</title>
@ -311,49 +311,49 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#orgd0f1d1f">1. Context</a> <li><a href="#orgea60151">1. Context</a>
<ul> <ul>
<li><a href="#orgeaa6df6">1.1. Data structure</a></li> <li><a href="#orgc4e2244">1.1. Data structure</a></li>
<li><a href="#org935a557">1.2. Access functions</a> <li><a href="#orgf6096ab">1.2. Access functions</a>
<ul> <ul>
<li><a href="#org6c63049">1.2.1. Number of electrons</a></li> <li><a href="#orgf3b34c9">1.2.1. Number of electrons</a></li>
<li><a href="#orge1ffce9">1.2.2. Number of walkers</a></li> <li><a href="#org3af7b79">1.2.2. Number of walkers</a></li>
<li><a href="#org193167f">1.2.3. Scaling factors Kappa</a></li> <li><a href="#org963af2c">1.2.3. Scaling factors Kappa</a></li>
<li><a href="#orgde61197">1.2.4. Electron coordinates</a></li> <li><a href="#org37d6e2d">1.2.4. Electron coordinates</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org1032f2c">1.3. Initialization functions</a></li> <li><a href="#org0eb3a30">1.3. Initialization functions</a></li>
<li><a href="#orgaa3c5da">1.4. Test</a></li> <li><a href="#org7734c5d">1.4. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org9bc884e">2. Computation</a> <li><a href="#org175e3b4">2. Computation</a>
<ul> <ul>
<li><a href="#orgadbda5d">2.1. Electron-electron distances</a> <li><a href="#orgaa1209b">2.1. Electron-electron distances</a>
<ul> <ul>
<li><a href="#orgd5b2628">2.1.1. Get</a></li> <li><a href="#orgd797b1a">2.1.1. Get</a></li>
<li><a href="#org2c32fac">2.1.2. Compute</a></li> <li><a href="#orgab12160">2.1.2. Compute</a></li>
<li><a href="#orge4b5989">2.1.3. Test</a></li> <li><a href="#orgbd4c48b">2.1.3. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org0110181">2.2. Electron-electron rescaled distances</a> <li><a href="#org8223888">2.2. Electron-electron rescaled distances</a>
<ul> <ul>
<li><a href="#orgc4b1c13">2.2.1. Get</a></li> <li><a href="#org055e15f">2.2.1. Get</a></li>
<li><a href="#org1bfa4f6">2.2.2. Compute</a></li> <li><a href="#org3cd6325">2.2.2. Compute</a></li>
<li><a href="#orgd84fee6">2.2.3. Test</a></li> <li><a href="#orgcc87ec1">2.2.3. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org7fd8f7f">2.3. Electron-nucleus distances</a> <li><a href="#org6b6ebea">2.3. Electron-nucleus distances</a>
<ul> <ul>
<li><a href="#org46eca9b">2.3.1. Get</a></li> <li><a href="#org627a627">2.3.1. Get</a></li>
<li><a href="#org9c12d2c">2.3.2. Compute</a></li> <li><a href="#org6976478">2.3.2. Compute</a></li>
<li><a href="#orga9ac9b1">2.3.3. Test</a></li> <li><a href="#orgcf3c3e1">2.3.3. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org12cceb3">2.4. Electron-nucleus rescaled distances</a> <li><a href="#orgc1a0c4f">2.4. Electron-nucleus rescaled distances</a>
<ul> <ul>
<li><a href="#orge9e316e">2.4.1. Get</a></li> <li><a href="#org42b8ab1">2.4.1. Get</a></li>
<li><a href="#orgbd3bb90">2.4.2. Compute</a></li> <li><a href="#org4bd3185">2.4.2. Compute</a></li>
<li><a href="#org6e47542">2.4.3. Test</a></li> <li><a href="#orga90ba22">2.4.3. Test</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
@ -362,8 +362,8 @@ for the JavaScript code in this tag.
</div> </div>
</div> </div>
<div id="outline-container-orgd0f1d1f" class="outline-2"> <div id="outline-container-orgea60151" class="outline-2">
<h2 id="orgd0f1d1f"><span class="section-number-2">1</span> Context</h2> <h2 id="orgea60151"><span class="section-number-2">1</span> Context</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
The following data stored in the context: The following data stored in the context:
@ -382,123 +382,123 @@ The following data stored in the context:
<tbody> <tbody>
<tr> <tr>
<td class="org-left"><code>uninitialized</code></td> <td class="org-left"><code>uninitialized</code></td>
<td class="org-left">int32<sub>t</sub></td> <td class="org-left"><code>int32_t</code></td>
<td class="org-left">Keeps bit set for uninitialized data</td> <td class="org-left">Keeps bit set for uninitialized data</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>num</code></td> <td class="org-left"><code>num</code></td>
<td class="org-left">int64<sub>t</sub></td> <td class="org-left"><code>int64_t</code></td>
<td class="org-left">Total number of electrons</td> <td class="org-left">Total number of electrons</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>up_num</code></td> <td class="org-left"><code>up_num</code></td>
<td class="org-left">int64<sub>t</sub></td> <td class="org-left"><code>int64_t</code></td>
<td class="org-left">Number of up-spin electrons</td> <td class="org-left">Number of up-spin electrons</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>down_num</code></td> <td class="org-left"><code>down_num</code></td>
<td class="org-left">int64<sub>t</sub></td> <td class="org-left"><code>int64_t</code></td>
<td class="org-left">Number of down-spin electrons</td> <td class="org-left">Number of down-spin electrons</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>walk_num</code></td> <td class="org-left"><code>walk_num</code></td>
<td class="org-left">int64<sub>t</sub></td> <td class="org-left"><code>int64_t</code></td>
<td class="org-left">Number of walkers</td> <td class="org-left">Number of walkers</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>rescale_factor_kappa_ee</code></td> <td class="org-left"><code>rescale_factor_kappa_ee</code></td>
<td class="org-left">double</td> <td class="org-left"><code>double</code></td>
<td class="org-left">The distance scaling factor</td> <td class="org-left">The distance scaling factor</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>rescale_factor_kappa_en</code></td> <td class="org-left"><code>rescale_factor_kappa_en</code></td>
<td class="org-left">double</td> <td class="org-left"><code>double</code></td>
<td class="org-left">The distance scaling factor</td> <td class="org-left">The distance scaling factor</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>provided</code></td> <td class="org-left"><code>provided</code></td>
<td class="org-left">bool</td> <td class="org-left"><code>bool</code></td>
<td class="org-left">If true, <code>electron</code> is valid</td> <td class="org-left">If true, <code>electron</code> is valid</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>coord_new</code></td> <td class="org-left"><code>coord_new</code></td>
<td class="org-left">double[walk<sub>num</sub>][3][num]</td> <td class="org-left"><code>double[walk_num][3][num]</code></td>
<td class="org-left">New set of electron coordinates</td> <td class="org-left">New set of electron coordinates</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>coord_old</code></td> <td class="org-left"><code>coord_old</code></td>
<td class="org-left">double[walk<sub>num</sub>][3][num]</td> <td class="org-left"><code>double[walk_num][3][num]</code></td>
<td class="org-left">Old set of electron coordinates</td> <td class="org-left">Old set of electron coordinates</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>coord_new_date</code></td> <td class="org-left"><code>coord_new_date</code></td>
<td class="org-left">uint64<sub>t</sub></td> <td class="org-left"><code>uint64_t</code></td>
<td class="org-left">Last modification date of the coordinates</td> <td class="org-left">Last modification date of the coordinates</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>ee_distance</code></td> <td class="org-left"><code>ee_distance</code></td>
<td class="org-left">double[walk<sub>num</sub>][num][num]</td> <td class="org-left"><code>double[walk_num][num][num]</code></td>
<td class="org-left">Electron-electron distances</td> <td class="org-left">Electron-electron distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>ee_distance_date</code></td> <td class="org-left"><code>ee_distance_date</code></td>
<td class="org-left">uint64<sub>t</sub></td> <td class="org-left"><code>uint64_t</code></td>
<td class="org-left">Last modification date of the electron-electron distances</td> <td class="org-left">Last modification date of the electron-electron distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>en_distance</code></td> <td class="org-left"><code>en_distance</code></td>
<td class="org-left">double[walk<sub>num</sub>][nucl<sub>num</sub>][num]</td> <td class="org-left"><code>double[walk_num][nucl_num][num]</code></td>
<td class="org-left">Electron-nucleus distances</td> <td class="org-left">Electron-nucleus distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>en_distance_date</code></td> <td class="org-left"><code>en_distance_date</code></td>
<td class="org-left">uint64<sub>t</sub></td> <td class="org-left"><code>uint64_t</code></td>
<td class="org-left">Last modification date of the electron-electron distances</td> <td class="org-left">Last modification date of the electron-electron distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>ee_distance_rescaled</code></td> <td class="org-left"><code>ee_distance_rescaled</code></td>
<td class="org-left">double[walk<sub>num</sub>][num][num]</td> <td class="org-left"><code>double[walk_num][num][num]</code></td>
<td class="org-left">Electron-electron distances</td> <td class="org-left">Electron-electron distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>ee_distance_rescaled_date</code></td> <td class="org-left"><code>ee_distance_rescaled_date</code></td>
<td class="org-left">uint64<sub>t</sub></td> <td class="org-left"><code>uint64_t</code></td>
<td class="org-left">Last modification date of the electron-electron distances</td> <td class="org-left">Last modification date of the electron-electron distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>en_distance_rescaled</code></td> <td class="org-left"><code>en_distance_rescaled</code></td>
<td class="org-left">double[walk<sub>num</sub>][nucl<sub>num</sub>][num]</td> <td class="org-left"><code>double[walk_num][nucl_num][num]</code></td>
<td class="org-left">Electron-nucleus distances</td> <td class="org-left">Electron-nucleus distances</td>
</tr> </tr>
<tr> <tr>
<td class="org-left"><code>en_distance_rescaled_date</code></td> <td class="org-left"><code>en_distance_rescaled_date</code></td>
<td class="org-left">uint64<sub>t</sub></td> <td class="org-left"><code>uint64_t</code></td>
<td class="org-left">Last modification date of the electron-electron distances</td> <td class="org-left">Last modification date of the electron-electron distances</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
</div> </div>
<div id="outline-container-orgeaa6df6" class="outline-3"> <div id="outline-container-orgc4e2244" class="outline-3">
<h3 id="orgeaa6df6"><span class="section-number-3">1.1</span> Data structure</h3> <h3 id="orgc4e2244"><span class="section-number-3">1.1</span> Data structure</h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">qmckl_electron_struct</span> { <pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">qmckl_electron_struct</span> {
@ -522,20 +522,45 @@ The following data stored in the context:
<span style="color: #228b22;">int32_t</span> <span style="color: #a0522d;">uninitialized</span>; <span style="color: #228b22;">int32_t</span> <span style="color: #a0522d;">uninitialized</span>;
<span style="color: #228b22;">bool</span> <span style="color: #a0522d;">provided</span>; <span style="color: #228b22;">bool</span> <span style="color: #a0522d;">provided</span>;
} <span style="color: #228b22;">qmckl_electron_struct</span>; } <span style="color: #228b22;">qmckl_electron_struct</span>;
</pre> </pre>
</div> </div>
<p> <p>
The <code>uninitialized</code> integer contains one bit set to one for each The <code>uninitialized</code> 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 to zero after all initialization functions have been called. The
struct is then initialized and <code>provided == true</code>. struct is then initialized and <code>provided == true</code>.
Some values are initialized by default, and are not concerned by
this mechanism.
</p> </p>
<p> <div class="org-src-container">
When all the data relative to electrons have been set, the <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_init_electron</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>);
following function returns <code>true</code>. </pre>
</p> </div>
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_init_electron</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>) {
<span style="color: #a020f0;">if</span> (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
<span style="color: #a020f0;">return</span> <span style="color: #008b8b;">false</span>;
}
<span style="color: #228b22;">qmckl_context_struct</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">ctx</span> = (<span style="color: #228b22;">qmckl_context_struct</span>* <span style="color: #a020f0;">const</span>) context;
assert (ctx != <span style="color: #008b8b;">NULL</span>);
ctx-&gt;electron.uninitialized = (1 &lt;&lt; 2) - 1;
/* <span style="color: #b22222;">Default values </span>*/
ctx-&gt;electron.rescale_factor_kappa_ee = 1.0;
ctx-&gt;electron.rescale_factor_kappa_en = 1.0;
<span style="color: #a020f0;">return</span> QMCKL_SUCCESS;
}
</pre>
</div>
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">bool</span> <span style="color: #0000ff;">qmckl_electron_provided</span> (<span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>); <pre class="src src-c"><span style="color: #228b22;">bool</span> <span style="color: #0000ff;">qmckl_electron_provided</span> (<span style="color: #a020f0;">const</span> <span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>);
@ -544,8 +569,8 @@ following function returns <code>true</code>.
</div> </div>
</div> </div>
<div id="outline-container-org935a557" class="outline-3"> <div id="outline-container-orgf6096ab" class="outline-3">
<h3 id="org935a557"><span class="section-number-3">1.2</span> Access functions</h3> <h3 id="orgf6096ab"><span class="section-number-3">1.2</span> Access functions</h3>
<div class="outline-text-3" id="text-1-2"> <div class="outline-text-3" id="text-1-2">
<p> <p>
Access functions return <code>QMCKL_SUCCESS</code> when the data has been Access functions return <code>QMCKL_SUCCESS</code> when the data has been
@ -557,12 +582,12 @@ contains the requested data. Otherwise, this variable is untouched.
</p> </p>
</div> </div>
<div id="outline-container-org6c63049" class="outline-4"> <div id="outline-container-orgf3b34c9" class="outline-4">
<h4 id="org6c63049"><span class="section-number-4">1.2.1</span> Number of electrons</h4> <h4 id="orgf3b34c9"><span class="section-number-4">1.2.1</span> Number of electrons</h4>
</div> </div>
<div id="outline-container-orge1ffce9" class="outline-4"> <div id="outline-container-org3af7b79" class="outline-4">
<h4 id="orge1ffce9"><span class="section-number-4">1.2.2</span> Number of walkers</h4> <h4 id="org3af7b79"><span class="section-number-4">1.2.2</span> Number of walkers</h4>
<div class="outline-text-4" id="text-1-2-2"> <div class="outline-text-4" id="text-1-2-2">
<p> <p>
A walker is a set of electron coordinates that are arguments of A walker is a set of electron coordinates that are arguments of
@ -571,12 +596,12 @@ the wave function. <code>walk_num</code> is the number of walkers.
</div> </div>
</div> </div>
<div id="outline-container-org193167f" class="outline-4"> <div id="outline-container-org963af2c" class="outline-4">
<h4 id="org193167f"><span class="section-number-4">1.2.3</span> Scaling factors Kappa</h4> <h4 id="org963af2c"><span class="section-number-4">1.2.3</span> Scaling factors Kappa</h4>
</div> </div>
<div id="outline-container-orgde61197" class="outline-4"> <div id="outline-container-org37d6e2d" class="outline-4">
<h4 id="orgde61197"><span class="section-number-4">1.2.4</span> Electron coordinates</h4> <h4 id="org37d6e2d"><span class="section-number-4">1.2.4</span> Electron coordinates</h4>
<div class="outline-text-4" id="text-1-2-4"> <div class="outline-text-4" id="text-1-2-4">
<p> <p>
Returns the current electron coordinates. The pointer is assumed Returns the current electron coordinates. The pointer is assumed
@ -620,8 +645,8 @@ The order of the indices is:
</div> </div>
<div id="outline-container-org1032f2c" class="outline-3"> <div id="outline-container-org0eb3a30" class="outline-3">
<h3 id="org1032f2c"><span class="section-number-3">1.3</span> Initialization functions</h3> <h3 id="org0eb3a30"><span class="section-number-3">1.3</span> Initialization functions</h3>
<div class="outline-text-3" id="text-1-3"> <div class="outline-text-3" id="text-1-3">
<p> <p>
To set the data relative to the electrons in the context, the To set the data relative to the electrons in the context, the
@ -631,10 +656,12 @@ both allocated.
</p> </p>
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">up_num</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">down_num</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">up_num</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">down_num</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_kappa</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_ee</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_en</span>); <span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_walk_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">walk_num</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_walk_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">walk_num</span>); <span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_coord</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">char</span> <span style="color: #a0522d;">transp</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">coord</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_coord</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">char</span> <span style="color: #a0522d;">transp</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">coord</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_rescale_factor_ee</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">kappa_ee</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_electron_rescale_factor_en</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">kappa_en</span>);
</pre> </pre>
</div> </div>
@ -666,8 +693,8 @@ in the context.
</div> </div>
</div> </div>
<div id="outline-container-orgaa3c5da" class="outline-3"> <div id="outline-container-org7734c5d" class="outline-3">
<h3 id="orgaa3c5da"><span class="section-number-3">1.4</span> Test</h3> <h3 id="org7734c5d"><span class="section-number-3">1.4</span> Test</h3>
<div class="outline-text-3" id="text-1-4"> <div class="outline-text-3" id="text-1-4">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/ <pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/
@ -675,14 +702,13 @@ in the context.
<span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_num</span> = chbrclf_elec_num; <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_num</span> = chbrclf_elec_num;
<span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_up_num</span> = chbrclf_elec_up_num; <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_up_num</span> = chbrclf_elec_up_num;
<span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_dn_num</span> = chbrclf_elec_dn_num; <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">elec_dn_num</span> = chbrclf_elec_dn_num;
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_ee</span> = 1.0; // <span style="color: #b22222;">TODO Get rescale_factor_kappa_ee from chbrclf</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_ee</span> = 2.0;
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_en</span> = 1.0; // <span style="color: #b22222;">TODO Get rescale_factor_kappa_en from chbrclf</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa_en</span> = 3.0;
<span style="color: #228b22;">double</span>* <span style="color: #a0522d;">elec_coord</span> = &amp;(chbrclf_elec_coord[0][0][0]); <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">elec_coord</span> = &amp;(chbrclf_elec_coord[0][0][0]);
<span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">nucl_num</span> = chbrclf_nucl_num; <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">nucl_num</span> = chbrclf_nucl_num;
<span style="color: #228b22;">double</span>* <span style="color: #a0522d;">charge</span> = chbrclf_charge; <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">charge</span> = chbrclf_charge;
<span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_coord</span> = &amp;(chbrclf_nucl_coord[0][0]); <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_coord</span> = &amp;(chbrclf_nucl_coord[0][0]);
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">nucl_rescale_factor_kappa</span> = 1.0; // <span style="color: #b22222;">TODO Change get rescale_factor_kappa from chbrclf example</span>
/* <span style="color: #b22222;">--- </span>*/ /* <span style="color: #b22222;">--- </span>*/
@ -717,23 +743,27 @@ rc = qmckl_get_electron_num (context, &amp;n);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
<span style="color: #0000ff;">assert</span>(n == elec_num); <span style="color: #0000ff;">assert</span>(n == elec_num);
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">k_ee</span>; <span style="color: #228b22;">double</span> <span style="color: #a0522d;">k_ee</span> = 0.;
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">k_en</span>; <span style="color: #228b22;">double</span> <span style="color: #a0522d;">k_en</span> = 0.;
rc = qmckl_get_kappa_ee (context, &amp;k_ee); rc = qmckl_get_electron_rescale_factor_ee (context, &amp;k_ee);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_NOT_PROVIDED);
rc = qmckl_get_kappa_en (context, &amp;k_en);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_NOT_PROVIDED);
rc = qmckl_set_kappa (context, rescale_factor_kappa_ee, rescale_factor_kappa_en);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
assert(!qmckl_electron_provided(context)); <span style="color: #0000ff;">assert</span>(k_ee == 1.0);
rc = qmckl_get_kappa_ee (context, &amp;k_ee); rc = qmckl_get_electron_rescale_factor_en (context, &amp;k_en);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
<span style="color: #0000ff;">assert</span>(k_en == 1.0);
rc = qmckl_set_electron_rescale_factor_en(context, rescale_factor_kappa_en);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_set_electron_rescale_factor_ee(context, rescale_factor_kappa_ee);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_get_electron_rescale_factor_ee (context, &amp;k_ee);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
<span style="color: #0000ff;">assert</span>(k_ee == rescale_factor_kappa_ee); <span style="color: #0000ff;">assert</span>(k_ee == rescale_factor_kappa_ee);
rc = qmckl_get_kappa_en (context, &amp;k_en); rc = qmckl_get_electron_rescale_factor_en (context, &amp;k_en);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
<span style="color: #0000ff;">assert</span>(k_en == rescale_factor_kappa_en); <span style="color: #0000ff;">assert</span>(k_en == rescale_factor_kappa_en);
@ -769,8 +799,8 @@ rc = qmckl_get_electron_coord (context, <span style="color: #8b2252;">'N'</span>
</div> </div>
</div> </div>
<div id="outline-container-org9bc884e" class="outline-2"> <div id="outline-container-org175e3b4" class="outline-2">
<h2 id="org9bc884e"><span class="section-number-2">2</span> Computation</h2> <h2 id="org175e3b4"><span class="section-number-2">2</span> Computation</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
<p> <p>
The computed data is stored in the context so that it can be reused The computed data is stored in the context so that it can be reused
@ -783,12 +813,12 @@ current date is stored.
</p> </p>
</div> </div>
<div id="outline-container-orgadbda5d" class="outline-3"> <div id="outline-container-orgaa1209b" class="outline-3">
<h3 id="orgadbda5d"><span class="section-number-3">2.1</span> Electron-electron distances</h3> <h3 id="orgaa1209b"><span class="section-number-3">2.1</span> Electron-electron distances</h3>
<div class="outline-text-3" id="text-2-1"> <div class="outline-text-3" id="text-2-1">
</div> </div>
<div id="outline-container-orgd5b2628" class="outline-4"> <div id="outline-container-orgd797b1a" class="outline-4">
<h4 id="orgd5b2628"><span class="section-number-4">2.1.1</span> Get</h4> <h4 id="orgd797b1a"><span class="section-number-4">2.1.1</span> Get</h4>
<div class="outline-text-4" id="text-2-1-1"> <div class="outline-text-4" id="text-2-1-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_ee_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">distance</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_ee_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">distance</span>);
@ -797,10 +827,10 @@ current date is stored.
</div> </div>
</div> </div>
<div id="outline-container-org2c32fac" class="outline-4"> <div id="outline-container-orgab12160" class="outline-4">
<h4 id="org2c32fac"><span class="section-number-4">2.1.2</span> Compute</h4> <h4 id="orgab12160"><span class="section-number-4">2.1.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-1-2"> <div class="outline-text-4" id="text-2-1-2">
<table id="org2e1ff9a" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org4700edb" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -896,8 +926,8 @@ current date is stored.
</div> </div>
</div> </div>
<div id="outline-container-orge4b5989" class="outline-4"> <div id="outline-container-orgbd4c48b" class="outline-4">
<h4 id="orge4b5989"><span class="section-number-4">2.1.3</span> Test</h4> <h4 id="orgbd4c48b"><span class="section-number-4">2.1.3</span> Test</h4>
<div class="outline-text-4" id="text-2-1-3"> <div class="outline-text-4" id="text-2-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #0000ff;">assert</span>(<span style="color: #228b22;">qmckl_electron_provided</span>(<span style="color: #a0522d;">context</span>)); <pre class="src src-c"><span style="color: #0000ff;">assert</span>(<span style="color: #228b22;">qmckl_electron_provided</span>(<span style="color: #a0522d;">context</span>));
@ -931,12 +961,12 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance);
</div> </div>
</div> </div>
<div id="outline-container-org0110181" class="outline-3"> <div id="outline-container-org8223888" class="outline-3">
<h3 id="org0110181"><span class="section-number-3">2.2</span> Electron-electron rescaled distances</h3> <h3 id="org8223888"><span class="section-number-3">2.2</span> Electron-electron rescaled distances</h3>
<div class="outline-text-3" id="text-2-2"> <div class="outline-text-3" id="text-2-2">
</div> </div>
<div id="outline-container-orgc4b1c13" class="outline-4"> <div id="outline-container-org055e15f" class="outline-4">
<h4 id="orgc4b1c13"><span class="section-number-4">2.2.1</span> Get</h4> <h4 id="org055e15f"><span class="section-number-4">2.2.1</span> Get</h4>
<div class="outline-text-4" id="text-2-2-1"> <div class="outline-text-4" id="text-2-2-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_ee_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">distance_rescaled</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_ee_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">distance_rescaled</span>);
@ -945,10 +975,10 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance);
</div> </div>
</div> </div>
<div id="outline-container-org1bfa4f6" class="outline-4"> <div id="outline-container-org3cd6325" class="outline-4">
<h4 id="org1bfa4f6"><span class="section-number-4">2.2.2</span> Compute</h4> <h4 id="org3cd6325"><span class="section-number-4">2.2.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-2-2"> <div class="outline-text-4" id="text-2-2-2">
<table id="orgc0ee98f" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org56b4bb8" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -1053,8 +1083,8 @@ rc = qmckl_get_electron_ee_distance(context, ee_distance);
</div> </div>
</div> </div>
<div id="outline-container-orgd84fee6" class="outline-4"> <div id="outline-container-orgcc87ec1" class="outline-4">
<h4 id="orgd84fee6"><span class="section-number-4">2.2.3</span> Test</h4> <h4 id="orgcc87ec1"><span class="section-number-4">2.2.3</span> Test</h4>
<div class="outline-text-4" id="text-2-2-3"> <div class="outline-text-4" id="text-2-2-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #0000ff;">assert</span>(<span style="color: #228b22;">qmckl_electron_provided</span>(<span style="color: #a0522d;">context</span>)); <pre class="src src-c"><span style="color: #0000ff;">assert</span>(<span style="color: #228b22;">qmckl_electron_provided</span>(<span style="color: #a0522d;">context</span>));
@ -1089,12 +1119,12 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled);
</div> </div>
</div> </div>
<div id="outline-container-org7fd8f7f" class="outline-3"> <div id="outline-container-org6b6ebea" class="outline-3">
<h3 id="org7fd8f7f"><span class="section-number-3">2.3</span> Electron-nucleus distances</h3> <h3 id="org6b6ebea"><span class="section-number-3">2.3</span> Electron-nucleus distances</h3>
<div class="outline-text-3" id="text-2-3"> <div class="outline-text-3" id="text-2-3">
</div> </div>
<div id="outline-container-org46eca9b" class="outline-4"> <div id="outline-container-org627a627" class="outline-4">
<h4 id="org46eca9b"><span class="section-number-4">2.3.1</span> Get</h4> <h4 id="org627a627"><span class="section-number-4">2.3.1</span> Get</h4>
<div class="outline-text-4" id="text-2-3-1"> <div class="outline-text-4" id="text-2-3-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_en_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_en_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance</span>);
@ -1103,10 +1133,10 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled);
</div> </div>
</div> </div>
<div id="outline-container-org9c12d2c" class="outline-4"> <div id="outline-container-org6976478" class="outline-4">
<h4 id="org9c12d2c"><span class="section-number-4">2.3.2</span> Compute</h4> <h4 id="org6976478"><span class="section-number-4">2.3.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-3-2"> <div class="outline-text-4" id="text-2-3-2">
<table id="org8c34674" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org780050f" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -1223,8 +1253,8 @@ rc = qmckl_get_electron_ee_distance_rescaled(context, ee_distance_rescaled);
</div> </div>
</div> </div>
<div id="outline-container-orga9ac9b1" class="outline-4"> <div id="outline-container-orgcf3c3e1" class="outline-4">
<h4 id="orga9ac9b1"><span class="section-number-4">2.3.3</span> Test</h4> <h4 id="orgcf3c3e1"><span class="section-number-4">2.3.3</span> Test</h4>
<div class="outline-text-4" id="text-2-3-3"> <div class="outline-text-4" id="text-2-3-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"> <pre class="src src-c">
@ -1234,9 +1264,6 @@ assert(!qmckl_nucleus_provided(context));
rc = qmckl_set_nucleus_num (context, nucl_num); rc = qmckl_set_nucleus_num (context, nucl_num);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_set_nucleus_charge (context, charge); rc = qmckl_set_nucleus_charge (context, charge);
<span style="color: #0000ff;">assert</span> (rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span> (rc == QMCKL_SUCCESS);
@ -1275,12 +1302,12 @@ rc = qmckl_get_electron_en_distance(context, &amp;(en_distance[0][0][0]));
</div> </div>
</div> </div>
<div id="outline-container-org12cceb3" class="outline-3"> <div id="outline-container-orgc1a0c4f" class="outline-3">
<h3 id="org12cceb3"><span class="section-number-3">2.4</span> Electron-nucleus rescaled distances</h3> <h3 id="orgc1a0c4f"><span class="section-number-3">2.4</span> Electron-nucleus rescaled distances</h3>
<div class="outline-text-3" id="text-2-4"> <div class="outline-text-3" id="text-2-4">
</div> </div>
<div id="outline-container-orge9e316e" class="outline-4"> <div id="outline-container-org42b8ab1" class="outline-4">
<h4 id="orge9e316e"><span class="section-number-4">2.4.1</span> Get</h4> <h4 id="org42b8ab1"><span class="section-number-4">2.4.1</span> Get</h4>
<div class="outline-text-4" id="text-2-4-1"> <div class="outline-text-4" id="text-2-4-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_en_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance_rescaled</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_electron_en_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance_rescaled</span>);
@ -1289,10 +1316,10 @@ rc = qmckl_get_electron_en_distance(context, &amp;(en_distance[0][0][0]));
</div> </div>
</div> </div>
<div id="outline-container-orgbd3bb90" class="outline-4"> <div id="outline-container-org4bd3185" class="outline-4">
<h4 id="orgbd3bb90"><span class="section-number-4">2.4.2</span> Compute</h4> <h4 id="org4bd3185"><span class="section-number-4">2.4.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-4-2"> <div class="outline-text-4" id="text-2-4-2">
<table id="org210b4d5" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="orge5d8c92" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -1424,8 +1451,8 @@ rc = qmckl_get_electron_en_distance(context, &amp;(en_distance[0][0][0]));
</div> </div>
</div> </div>
<div id="outline-container-org6e47542" class="outline-4"> <div id="outline-container-orga90ba22" class="outline-4">
<h4 id="org6e47542"><span class="section-number-4">2.4.3</span> Test</h4> <h4 id="orga90ba22"><span class="section-number-4">2.4.3</span> Test</h4>
<div class="outline-text-4" id="text-2-4-3"> <div class="outline-text-4" id="text-2-4-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"> <pre class="src src-c">
@ -1434,9 +1461,6 @@ rc = qmckl_get_electron_en_distance(context, &amp;(en_distance[0][0][0]));
rc = qmckl_set_nucleus_num (context, nucl_num); rc = qmckl_set_nucleus_num (context, nucl_num);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_set_nucleus_charge (context, charge); rc = qmckl_set_nucleus_charge (context, charge);
<span style="color: #0000ff;">assert</span> (rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span> (rc == QMCKL_SUCCESS);
@ -1479,7 +1503,7 @@ rc = qmckl_get_electron_en_distance_rescaled(context, &amp;(en_distance_rescaled
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Error handling</title> <title>Error handling</title>
@ -311,17 +311,17 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org03f2562">1. Decoding errors</a></li> <li><a href="#org513b134">1. Decoding errors</a></li>
<li><a href="#org39f3e25">2. Data structure in context</a></li> <li><a href="#orgf02fde3">2. Data structure in context</a></li>
<li><a href="#orgb89cbdb">3. Updating errors in the context</a></li> <li><a href="#org471f45d">3. Updating errors in the context</a></li>
<li><a href="#org769b56b">4. Get the error</a></li> <li><a href="#org8a808bb">4. Get the error</a></li>
<li><a href="#org3ac9867">5. Failing</a></li> <li><a href="#orgac9f02b">5. Failing</a></li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-org03f2562" class="outline-2"> <div id="outline-container-org513b134" class="outline-2">
<h2 id="org03f2562"><span class="section-number-2">1</span> Decoding errors</h2> <h2 id="org513b134"><span class="section-number-2">1</span> Decoding errors</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
To decode the error messages, <code>qmckl_string_of_error</code> converts an To decode the error messages, <code>qmckl_string_of_error</code> converts an
@ -451,8 +451,8 @@ The text strings are extracted from the previous table.
</div> </div>
</div> </div>
<div id="outline-container-org39f3e25" class="outline-2"> <div id="outline-container-orgf02fde3" class="outline-2">
<h2 id="org39f3e25"><span class="section-number-2">2</span> Data structure in context</h2> <h2 id="orgf02fde3"><span class="section-number-2">2</span> Data structure in context</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
<p> <p>
The strings are declared with a maximum fixed size to avoid The strings are declared with a maximum fixed size to avoid
@ -475,8 +475,8 @@ dynamic memory allocation.
</div> </div>
</div> </div>
<div id="outline-container-orgb89cbdb" class="outline-2"> <div id="outline-container-org471f45d" class="outline-2">
<h2 id="orgb89cbdb"><span class="section-number-2">3</span> Updating errors in the context</h2> <h2 id="org471f45d"><span class="section-number-2">3</span> Updating errors in the context</h2>
<div class="outline-text-2" id="text-3"> <div class="outline-text-2" id="text-3">
<p> <p>
The error is updated in the context using <code>qmckl_set_error</code>. The error is updated in the context using <code>qmckl_set_error</code>.
@ -522,8 +522,8 @@ explaining the error. The exit code can't be <code>QMCKL_SUCCESS</code>.
</div> </div>
</div> </div>
<div id="outline-container-org769b56b" class="outline-2"> <div id="outline-container-org8a808bb" class="outline-2">
<h2 id="org769b56b"><span class="section-number-2">4</span> Get the error</h2> <h2 id="org8a808bb"><span class="section-number-2">4</span> Get the error</h2>
<div class="outline-text-2" id="text-4"> <div class="outline-text-2" id="text-4">
<p> <p>
Upon error, the error type and message can be obtained from the Upon error, the error type and message can be obtained from the
@ -564,8 +564,8 @@ function name and message is mandatory.
</div> </div>
</div> </div>
<div id="outline-container-org3ac9867" class="outline-2"> <div id="outline-container-orgac9f02b" class="outline-2">
<h2 id="org3ac9867"><span class="section-number-2">5</span> Failing</h2> <h2 id="orgac9f02b"><span class="section-number-2">5</span> Failing</h2>
<div class="outline-text-2" id="text-5"> <div class="outline-text-2" id="text-5">
<p> <p>
To make a function fail, the <code>qmckl_failwith</code> function should be To make a function fail, the <code>qmckl_failwith</code> function should be
@ -628,7 +628,7 @@ For example, this function can be used as
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Memory management</title> <title>Memory management</title>
@ -311,15 +311,15 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#orgc2e25f1">1. Memory data structure for the context</a></li> <li><a href="#org8008f0c">1. Memory data structure for the context</a></li>
<li><a href="#org69e7c1b">2. Passing info to allocation routines</a></li> <li><a href="#org1e6f62d">2. Passing info to allocation routines</a></li>
<li><a href="#org3e12247">3. Allocation/deallocation functions</a></li> <li><a href="#orgfd32acb">3. Allocation/deallocation functions</a></li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-orgc2e25f1" class="outline-2"> <div id="outline-container-org8008f0c" class="outline-2">
<h2 id="orgc2e25f1"><span class="section-number-2">1</span> Memory data structure for the context</h2> <h2 id="org8008f0c"><span class="section-number-2">1</span> Memory data structure for the context</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
Every time a new block of memory is allocated, the information Every time a new block of memory is allocated, the information
@ -361,8 +361,8 @@ array, and the number of allocated blocks.
</div> </div>
</div> </div>
<div id="outline-container-org69e7c1b" class="outline-2"> <div id="outline-container-org1e6f62d" class="outline-2">
<h2 id="org69e7c1b"><span class="section-number-2">2</span> Passing info to allocation routines</h2> <h2 id="org1e6f62d"><span class="section-number-2">2</span> Passing info to allocation routines</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
<p> <p>
Passing information to the allocation routine should be done by Passing information to the allocation routine should be done by
@ -371,8 +371,8 @@ passing an instance of a <code>qmckl_memory_info_struct</code>.
</div> </div>
</div> </div>
<div id="outline-container-org3e12247" class="outline-2"> <div id="outline-container-orgfd32acb" class="outline-2">
<h2 id="org3e12247"><span class="section-number-2">3</span> Allocation/deallocation functions</h2> <h2 id="orgfd32acb"><span class="section-number-2">3</span> Allocation/deallocation functions</h2>
<div class="outline-text-2" id="text-3"> <div class="outline-text-2" id="text-3">
<p> <p>
Memory allocation inside the library should be done with Memory allocation inside the library should be done with
@ -535,7 +535,7 @@ allocation and needs to be updated.
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Nucleus</title> <title>Nucleus</title>
@ -333,35 +333,35 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#orgc2ee80a">1. Context</a> <li><a href="#orgaa0c5b3">1. Context</a>
<ul> <ul>
<li><a href="#orga78a06c">1.1. Data structure</a></li> <li><a href="#org3086435">1.1. Data structure</a></li>
<li><a href="#org134c6c0">1.2. Access functions</a></li> <li><a href="#orgb0d5896">1.2. Access functions</a></li>
<li><a href="#orgd1d6103">1.3. Initialization functions</a></li> <li><a href="#org8a3fe00">1.3. Initialization functions</a></li>
<li><a href="#org3f21a18">1.4. Test</a></li> <li><a href="#org826df4e">1.4. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org184fa04">2. Computation</a> <li><a href="#org0775b5c">2. Computation</a>
<ul> <ul>
<li><a href="#org8813417">2.1. Nucleus-nucleus distances</a> <li><a href="#orgf546c7d">2.1. Nucleus-nucleus distances</a>
<ul> <ul>
<li><a href="#orgb1c8199">2.1.1. Get</a></li> <li><a href="#org8be202d">2.1.1. Get</a></li>
<li><a href="#orgc20259f">2.1.2. Compute</a></li> <li><a href="#org0d0076c">2.1.2. Compute</a></li>
<li><a href="#orgbf270b5">2.1.3. Test</a></li> <li><a href="#org747ca70">2.1.3. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#org6611378">2.2. Nucleus-nucleus rescaled distances</a> <li><a href="#orgae1005f">2.2. Nucleus-nucleus rescaled distances</a>
<ul> <ul>
<li><a href="#orgc2200b8">2.2.1. Get</a></li> <li><a href="#orged6f24f">2.2.1. Get</a></li>
<li><a href="#org71b83d0">2.2.2. Compute</a></li> <li><a href="#org6b672e1">2.2.2. Compute</a></li>
<li><a href="#org8d6b2cc">2.2.3. Test</a></li> <li><a href="#orgef0d489">2.2.3. Test</a></li>
</ul> </ul>
</li> </li>
<li><a href="#orgb436160">2.3. Nuclear repulsion energy</a> <li><a href="#org78af237">2.3. Nuclear repulsion energy</a>
<ul> <ul>
<li><a href="#org73725ae">2.3.1. Get</a></li> <li><a href="#org93f36f5">2.3.1. Get</a></li>
<li><a href="#org6c5fa46">2.3.2. Compute</a></li> <li><a href="#orgd718f71">2.3.2. Compute</a></li>
<li><a href="#orgb6fe90e">2.3.3. Test</a></li> <li><a href="#org3b8dbf8">2.3.3. Test</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
@ -370,8 +370,8 @@ for the JavaScript code in this tag.
</div> </div>
</div> </div>
<div id="outline-container-orgc2ee80a" class="outline-2"> <div id="outline-container-orgaa0c5b3" class="outline-2">
<h2 id="orgc2ee80a"><span class="section-number-2">1</span> Context</h2> <h2 id="orgaa0c5b3"><span class="section-number-2">1</span> Context</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
The following data stored in the context: The following data stored in the context:
@ -463,8 +463,8 @@ The following data stored in the context:
</table> </table>
</div> </div>
<div id="outline-container-orga78a06c" class="outline-3"> <div id="outline-container-org3086435" class="outline-3">
<h3 id="orga78a06c"><span class="section-number-3">1.1</span> Data structure</h3> <h3 id="org3086435"><span class="section-number-3">1.1</span> Data structure</h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">qmckl_nucleus_struct</span> { <pre class="src src-c"><span style="color: #a020f0;">typedef</span> <span style="color: #a020f0;">struct</span> <span style="color: #228b22;">qmckl_nucleus_struct</span> {
@ -481,6 +481,7 @@ The following data stored in the context:
<span style="color: #228b22;">int32_t</span> <span style="color: #a0522d;">uninitialized</span>; <span style="color: #228b22;">int32_t</span> <span style="color: #a0522d;">uninitialized</span>;
<span style="color: #228b22;">bool</span> <span style="color: #a0522d;">provided</span>; <span style="color: #228b22;">bool</span> <span style="color: #a0522d;">provided</span>;
} <span style="color: #228b22;">qmckl_nucleus_struct</span>; } <span style="color: #228b22;">qmckl_nucleus_struct</span>;
</pre> </pre>
</div> </div>
@ -489,12 +490,41 @@ The <code>uninitialized</code> integer contains one bit set to one for each
initialization function which has not been called. It becomes equal initialization function which has not been called. It becomes equal
to zero after all initialization functions have been called. The to zero after all initialization functions have been called. The
struct is then initialized and <code>provided == true</code>. struct is then initialized and <code>provided == true</code>.
Some values are initialized by default, and are not concerned by
this mechanism.
</p> </p>
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_init_nucleus</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>);
</pre>
</div>
<div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_init_nucleus</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>) {
<span style="color: #a020f0;">if</span> (qmckl_context_check(context) == QMCKL_NULL_CONTEXT) {
<span style="color: #a020f0;">return</span> <span style="color: #008b8b;">false</span>;
}
<span style="color: #228b22;">qmckl_context_struct</span>* <span style="color: #a020f0;">const</span> <span style="color: #a0522d;">ctx</span> = (<span style="color: #228b22;">qmckl_context_struct</span>* <span style="color: #a020f0;">const</span>) context;
assert (ctx != <span style="color: #008b8b;">NULL</span>);
ctx-&gt;nucleus.uninitialized = (1 &lt;&lt; 3) - 1;
/* <span style="color: #b22222;">Default values </span>*/
ctx-&gt;nucleus.rescale_factor_kappa = 1.0;
<span style="color: #a020f0;">return</span> QMCKL_SUCCESS;
}
</pre>
</div>
</div> </div>
</div> </div>
<div id="outline-container-org134c6c0" class="outline-3">
<h3 id="org134c6c0"><span class="section-number-3">1.2</span> Access functions</h3>
<div id="outline-container-orgb0d5896" class="outline-3">
<h3 id="orgb0d5896"><span class="section-number-3">1.2</span> Access functions</h3>
<div class="outline-text-3" id="text-1-2"> <div class="outline-text-3" id="text-1-2">
<p> <p>
When all the data relative to nuclei have been set, the following When all the data relative to nuclei have been set, the following
@ -508,8 +538,8 @@ function returns <code>true</code>.
</div> </div>
</div> </div>
<div id="outline-container-orgd1d6103" class="outline-3"> <div id="outline-container-org8a3fe00" class="outline-3">
<h3 id="orgd1d6103"><span class="section-number-3">1.3</span> Initialization functions</h3> <h3 id="org8a3fe00"><span class="section-number-3">1.3</span> Initialization functions</h3>
<div class="outline-text-3" id="text-1-3"> <div class="outline-text-3" id="text-1-3">
<p> <p>
To set the data relative to the nuclei in the context, the To set the data relative to the nuclei in the context, the
@ -519,8 +549,9 @@ following functions need to be called.
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">num</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_num</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">num</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_charge</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">charge</span>); <span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_charge</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">charge</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_kappa</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_coord</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">char</span> <span style="color: #a0522d;">transp</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">coord</span>); <span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_coord</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">char</span> <span style="color: #a0522d;">transp</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">coord</span>);
<span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_set_nucleus_rescale_factor</span> (<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">rescale_factor_kappa</span>);
</pre> </pre>
</div> </div>
@ -543,14 +574,14 @@ atoms. The coordinates should be given in atomic units.
</div> </div>
</div> </div>
<div id="outline-container-org3f21a18" class="outline-3"> <div id="outline-container-org826df4e" class="outline-3">
<h3 id="org3f21a18"><span class="section-number-3">1.4</span> Test</h3> <h3 id="org826df4e"><span class="section-number-3">1.4</span> Test</h3>
<div class="outline-text-3" id="text-1-4"> <div class="outline-text-3" id="text-1-4">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">nucl_num</span> = chbrclf_nucl_num; <pre class="src src-c"><span style="color: #a020f0;">const</span> <span style="color: #228b22;">int64_t</span> <span style="color: #a0522d;">nucl_num</span> = chbrclf_nucl_num;
<span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_charge</span> = chbrclf_charge; <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_charge</span> = chbrclf_charge;
<span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_coord</span> = &amp;(chbrclf_nucl_coord[0][0]); <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">nucl_coord</span> = &amp;(chbrclf_nucl_coord[0][0]);
<span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">nucl_rescale_factor_kappa</span> = 1.0; // <span style="color: #b22222;">TODO Change get rescale_factor_kappa from chbrclf example</span> <span style="color: #a020f0;">const</span> <span style="color: #228b22;">double</span> <span style="color: #a0522d;">nucl_rescale_factor_kappa</span> = 2.0;
/* <span style="color: #b22222;">--- </span>*/ /* <span style="color: #b22222;">--- </span>*/
@ -572,15 +603,15 @@ rc = qmckl_get_nucleus_num (context, &amp;n);
<span style="color: #0000ff;">assert</span>(n == nucl_num); <span style="color: #0000ff;">assert</span>(n == nucl_num);
<span style="color: #228b22;">double</span> <span style="color: #a0522d;">k</span>; <span style="color: #228b22;">double</span> <span style="color: #a0522d;">k</span>;
rc = qmckl_get_nucleus_kappa (context, &amp;k); rc = qmckl_get_nucleus_rescale_factor (context, &amp;k);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_NOT_PROVIDED);
rc = qmckl_set_nucleus_kappa (context, nucl_rescale_factor_kappa);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
assert(!qmckl_nucleus_provided(context)); <span style="color: #0000ff;">assert</span>(k == 1.0);
rc = qmckl_get_nucleus_kappa (context, &amp;k);
rc = qmckl_set_nucleus_rescale_factor (context, nucl_rescale_factor_kappa);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
rc = qmckl_get_nucleus_rescale_factor (context, &amp;k);
<span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS); <span style="color: #0000ff;">assert</span>(rc == QMCKL_SUCCESS);
<span style="color: #0000ff;">assert</span>(k == nucl_rescale_factor_kappa); <span style="color: #0000ff;">assert</span>(k == nucl_rescale_factor_kappa);
@ -628,8 +659,8 @@ rc = qmckl_get_nucleus_charge(context, nucl_charge2);
</div> </div>
</div> </div>
<div id="outline-container-org184fa04" class="outline-2"> <div id="outline-container-org0775b5c" class="outline-2">
<h2 id="org184fa04"><span class="section-number-2">2</span> Computation</h2> <h2 id="org0775b5c"><span class="section-number-2">2</span> Computation</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
<p> <p>
The computed data is stored in the context so that it can be reused The computed data is stored in the context so that it can be reused
@ -642,12 +673,12 @@ current date is stored.
</p> </p>
</div> </div>
<div id="outline-container-org8813417" class="outline-3"> <div id="outline-container-orgf546c7d" class="outline-3">
<h3 id="org8813417"><span class="section-number-3">2.1</span> Nucleus-nucleus distances</h3> <h3 id="orgf546c7d"><span class="section-number-3">2.1</span> Nucleus-nucleus distances</h3>
<div class="outline-text-3" id="text-2-1"> <div class="outline-text-3" id="text-2-1">
</div> </div>
<div id="outline-container-orgb1c8199" class="outline-4"> <div id="outline-container-org8be202d" class="outline-4">
<h4 id="orgb1c8199"><span class="section-number-4">2.1.1</span> Get</h4> <h4 id="org8be202d"><span class="section-number-4">2.1.1</span> Get</h4>
<div class="outline-text-4" id="text-2-1-1"> <div class="outline-text-4" id="text-2-1-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_nn_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_nn_distance</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance</span>);
@ -656,10 +687,10 @@ current date is stored.
</div> </div>
</div> </div>
<div id="outline-container-orgc20259f" class="outline-4"> <div id="outline-container-org0d0076c" class="outline-4">
<h4 id="orgc20259f"><span class="section-number-4">2.1.2</span> Compute</h4> <h4 id="org0d0076c"><span class="section-number-4">2.1.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-1-2"> <div class="outline-text-4" id="text-2-1-2">
<table id="orgab9fe99" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org297bb20" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -737,8 +768,8 @@ current date is stored.
</div> </div>
</div> </div>
<div id="outline-container-orgbf270b5" class="outline-4"> <div id="outline-container-org747ca70" class="outline-4">
<h4 id="orgbf270b5"><span class="section-number-4">2.1.3</span> Test</h4> <h4 id="org747ca70"><span class="section-number-4">2.1.3</span> Test</h4>
<div class="outline-text-4" id="text-2-1-3"> <div class="outline-text-4" id="text-2-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/ <pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/
@ -758,12 +789,12 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
<div id="outline-container-org6611378" class="outline-3"> <div id="outline-container-orgae1005f" class="outline-3">
<h3 id="org6611378"><span class="section-number-3">2.2</span> Nucleus-nucleus rescaled distances</h3> <h3 id="orgae1005f"><span class="section-number-3">2.2</span> Nucleus-nucleus rescaled distances</h3>
<div class="outline-text-3" id="text-2-2"> <div class="outline-text-3" id="text-2-2">
</div> </div>
<div id="outline-container-orgc2200b8" class="outline-4"> <div id="outline-container-orged6f24f" class="outline-4">
<h4 id="orgc2200b8"><span class="section-number-4">2.2.1</span> Get</h4> <h4 id="orged6f24f"><span class="section-number-4">2.2.1</span> Get</h4>
<div class="outline-text-4" id="text-2-2-1"> <div class="outline-text-4" id="text-2-2-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_nn_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance_rescaled</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_nn_distance_rescaled</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">distance_rescaled</span>);
@ -772,10 +803,10 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
</div> </div>
<div id="outline-container-org71b83d0" class="outline-4"> <div id="outline-container-org6b672e1" class="outline-4">
<h4 id="org71b83d0"><span class="section-number-4">2.2.2</span> Compute</h4> <h4 id="org6b672e1"><span class="section-number-4">2.2.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-2-2"> <div class="outline-text-4" id="text-2-2-2">
<table id="orgda09015" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org0046483" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -854,8 +885,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
</div> </div>
<div id="outline-container-org8d6b2cc" class="outline-4"> <div id="outline-container-orgef0d489" class="outline-4">
<h4 id="org8d6b2cc"><span class="section-number-4">2.2.3</span> Test</h4> <h4 id="orgef0d489"><span class="section-number-4">2.2.3</span> Test</h4>
<div class="outline-text-4" id="text-2-2-3"> <div class="outline-text-4" id="text-2-2-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/ <pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/
@ -875,8 +906,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
</div> </div>
<div id="outline-container-orgb436160" class="outline-3"> <div id="outline-container-org78af237" class="outline-3">
<h3 id="orgb436160"><span class="section-number-3">2.3</span> Nuclear repulsion energy</h3> <h3 id="org78af237"><span class="section-number-3">2.3</span> Nuclear repulsion energy</h3>
<div class="outline-text-3" id="text-2-3"> <div class="outline-text-3" id="text-2-3">
<p> <p>
\[ \[
@ -885,8 +916,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</p> </p>
</div> </div>
<div id="outline-container-org73725ae" class="outline-4"> <div id="outline-container-org93f36f5" class="outline-4">
<h4 id="org73725ae"><span class="section-number-4">2.3.1</span> Get</h4> <h4 id="org93f36f5"><span class="section-number-4">2.3.1</span> Get</h4>
<div class="outline-text-4" id="text-2-3-1"> <div class="outline-text-4" id="text-2-3-1">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_repulsion</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">energy</span>); <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_get_nucleus_repulsion</span>(<span style="color: #228b22;">qmckl_context</span> <span style="color: #a0522d;">context</span>, <span style="color: #228b22;">double</span>* <span style="color: #a0522d;">energy</span>);
@ -895,10 +926,10 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
</div> </div>
<div id="outline-container-org6c5fa46" class="outline-4"> <div id="outline-container-orgd718f71" class="outline-4">
<h4 id="org6c5fa46"><span class="section-number-4">2.3.2</span> Compute</h4> <h4 id="orgd718f71"><span class="section-number-4">2.3.2</span> Compute</h4>
<div class="outline-text-4" id="text-2-3-2"> <div class="outline-text-4" id="text-2-3-2">
<table id="orge3e26b9" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org43d9666" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -986,8 +1017,8 @@ rc = qmckl_get_nucleus_nn_distance(context, distance);
</div> </div>
</div> </div>
<div id="outline-container-orgb6fe90e" class="outline-4"> <div id="outline-container-org3b8dbf8" class="outline-4">
<h4 id="orgb6fe90e"><span class="section-number-4">2.3.3</span> Test</h4> <h4 id="org3b8dbf8"><span class="section-number-4">2.3.3</span> Test</h4>
<div class="outline-text-4" id="text-2-3-3"> <div class="outline-text-4" id="text-2-3-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/ <pre class="src src-c">/* <span style="color: #b22222;">Reference input data </span>*/
@ -1007,7 +1038,7 @@ rc = qmckl_get_nucleus_repulsion(context, &amp;rep);
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Numerical precision</title> <title>Numerical precision</title>
@ -333,16 +333,16 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org8181830">1. Control of the numerical precision</a></li> <li><a href="#orgb75e6f5">1. Control of the numerical precision</a></li>
<li><a href="#orga28b4d6">2. Precision</a></li> <li><a href="#org08ed499">2. Precision</a></li>
<li><a href="#org5142567">3. Range</a></li> <li><a href="#org9b272ff">3. Range</a></li>
<li><a href="#orgd75d906">4. Helper functions</a></li> <li><a href="#org380d435">4. Helper functions</a></li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-org8181830" class="outline-2"> <div id="outline-container-orgb75e6f5" class="outline-2">
<h2 id="org8181830"><span class="section-number-2">1</span> Control of the numerical precision</h2> <h2 id="orgb75e6f5"><span class="section-number-2">1</span> Control of the numerical precision</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
Controlling numerical precision enables optimizations. Here, the Controlling numerical precision enables optimizations. Here, the
@ -353,7 +353,7 @@ Arithmetic (IEEE 754),
refers to the number of exponent bits. refers to the number of exponent bits.
</p> </p>
<table id="orgd427a08" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org52fb9ab" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -397,8 +397,8 @@ integer. The update functions return <code>QMCKL_SUCCESS</code> or
</div> </div>
</div> </div>
<div id="outline-container-orga28b4d6" class="outline-2"> <div id="outline-container-org08ed499" class="outline-2">
<h2 id="orga28b4d6"><span class="section-number-2">2</span> Precision</h2> <h2 id="org08ed499"><span class="section-number-2">2</span> Precision</h2>
<div class="outline-text-2" id="text-2"> <div class="outline-text-2" id="text-2">
<p> <p>
<code>qmckl_context_set_numprec_precision</code> modifies the parameter for the <code>qmckl_context_set_numprec_precision</code> modifies the parameter for the
@ -485,8 +485,8 @@ numerical precision in the context.
</div> </div>
</div> </div>
<div id="outline-container-org5142567" class="outline-2"> <div id="outline-container-org9b272ff" class="outline-2">
<h2 id="org5142567"><span class="section-number-2">3</span> Range</h2> <h2 id="org9b272ff"><span class="section-number-2">3</span> Range</h2>
<div class="outline-text-2" id="text-3"> <div class="outline-text-2" id="text-3">
<p> <p>
<code>qmckl_set_numprec_range</code> modifies the parameter for the numerical <code>qmckl_set_numprec_range</code> modifies the parameter for the numerical
@ -561,8 +561,8 @@ range in a given context.
</div> </div>
</div> </div>
</div> </div>
<div id="outline-container-orgd75d906" class="outline-2"> <div id="outline-container-org380d435" class="outline-2">
<h2 id="orgd75d906"><span class="section-number-2">4</span> Helper functions</h2> <h2 id="org380d435"><span class="section-number-2">4</span> Helper functions</h2>
<div class="outline-text-2" id="text-4"> <div class="outline-text-2" id="text-4">
<p> <p>
<code>qmckl_get_numprec_epsilon</code> returns \(\epsilon = 2^{1-n}\) where <code>n</code> is the precision. <code>qmckl_get_numprec_epsilon</code> returns \(\epsilon = 2^{1-n}\) where <code>n</code> is the precision.
@ -581,7 +581,7 @@ We need to remove the sign bit from the precision.
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Data for Tests</title> <title>Data for Tests</title>
@ -233,20 +233,20 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org23d8a57">1. CHBrClF</a> <li><a href="#orgf4fb7d2">1. CHBrClF</a>
<ul> <ul>
<li><a href="#orgd209b7c">1.1. XYZ coordinates</a></li> <li><a href="#orgf44a479">1.1. XYZ coordinates</a></li>
<li><a href="#org2cba217">1.2. Atomic basis set</a></li> <li><a href="#org3334ff0">1.2. Atomic basis set</a></li>
<li><a href="#org8e238de">1.3. <span class="todo TODO">TODO</span> Molecular orbitals</a></li> <li><a href="#org695a994">1.3. <span class="todo TODO">TODO</span> Molecular orbitals</a></li>
<li><a href="#orgdca5466">1.4. Electron coordinates</a></li> <li><a href="#org8567dad">1.4. Electron coordinates</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
</div> </div>
</div> </div>
<div id="outline-container-org23d8a57" class="outline-2"> <div id="outline-container-orgf4fb7d2" class="outline-2">
<h2 id="org23d8a57"><span class="section-number-2">1</span> CHBrClF</h2> <h2 id="orgf4fb7d2"><span class="section-number-2">1</span> CHBrClF</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
<p> <p>
This test is the all-electron Hartree-Fock wave function of CHClBr, This test is the all-electron Hartree-Fock wave function of CHClBr,
@ -330,8 +330,8 @@ and with a high maximum angular momentum.
</div> </div>
<div id="outline-container-orgd209b7c" class="outline-3"> <div id="outline-container-orgf44a479" class="outline-3">
<h3 id="orgd209b7c"><span class="section-number-3">1.1</span> XYZ coordinates</h3> <h3 id="orgf44a479"><span class="section-number-3">1.1</span> XYZ coordinates</h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<pre class="example"> <pre class="example">
5 5
@ -361,8 +361,8 @@ Nuclear coordinates are stored in atomic units in transposed format.
</div> </div>
</div> </div>
<div id="outline-container-org2cba217" class="outline-3"> <div id="outline-container-org3334ff0" class="outline-3">
<h3 id="org2cba217"><span class="section-number-3">1.2</span> Atomic basis set</h3> <h3 id="org3334ff0"><span class="section-number-3">1.2</span> Atomic basis set</h3>
<div class="outline-text-3" id="text-1-2"> <div class="outline-text-3" id="text-1-2">
<pre class="example"> <pre class="example">
HYDROGEN HYDROGEN
@ -1175,11 +1175,11 @@ F 1
</div> </div>
</div> </div>
<div id="outline-container-org8e238de" class="outline-3"> <div id="outline-container-org695a994" class="outline-3">
<h3 id="org8e238de"><span class="section-number-3">1.3</span> <span class="todo TODO">TODO</span> Molecular orbitals</h3> <h3 id="org695a994"><span class="section-number-3">1.3</span> <span class="todo TODO">TODO</span> Molecular orbitals</h3>
</div> </div>
<div id="outline-container-orgdca5466" class="outline-3"> <div id="outline-container-org8567dad" class="outline-3">
<h3 id="orgdca5466"><span class="section-number-3">1.4</span> Electron coordinates</h3> <h3 id="org8567dad"><span class="section-number-3">1.4</span> Electron coordinates</h3>
<div class="outline-text-3" id="text-1-4"> <div class="outline-text-3" id="text-1-4">
<p> <p>
Electron coordinates are stored in atomic units in normal format. Electron coordinates are stored in atomic units in normal format.
@ -1339,7 +1339,7 @@ Electron coordinates are stored in atomic units in normal format.
</div> </div>
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>

View File

@ -3,7 +3,7 @@
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head> <head>
<!-- 2021-06-09 Wed 22:11 --> <!-- 2021-06-10 Thu 21:55 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Utility functions</title> <title>Utility functions</title>
@ -333,13 +333,13 @@ for the JavaScript code in this tag.
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<div id="text-table-of-contents"> <div id="text-table-of-contents">
<ul> <ul>
<li><a href="#org10e8d9f">1. Matrix operations</a> <li><a href="#org77ea838">1. Matrix operations</a>
<ul> <ul>
<li><a href="#org951ba0b">1.1. <code>qmckl_transpose</code></a> <li><a href="#orga006629">1.1. <code>qmckl_transpose</code></a>
<ul> <ul>
<li><a href="#org5a3c27d">1.1.1. Requirements</a></li> <li><a href="#orgc55e613">1.1.1. Requirements</a></li>
<li><a href="#org53609fc">1.1.2. C header</a></li> <li><a href="#org92628c4">1.1.2. C header</a></li>
<li><a href="#org44c441f">1.1.3. Source</a></li> <li><a href="#org6b02956">1.1.3. Source</a></li>
</ul> </ul>
</li> </li>
</ul> </ul>
@ -348,18 +348,18 @@ for the JavaScript code in this tag.
</div> </div>
</div> </div>
<div id="outline-container-org10e8d9f" class="outline-2"> <div id="outline-container-org77ea838" class="outline-2">
<h2 id="org10e8d9f"><span class="section-number-2">1</span> Matrix operations</h2> <h2 id="org77ea838"><span class="section-number-2">1</span> Matrix operations</h2>
<div class="outline-text-2" id="text-1"> <div class="outline-text-2" id="text-1">
</div> </div>
<div id="outline-container-org951ba0b" class="outline-3"> <div id="outline-container-orga006629" class="outline-3">
<h3 id="org951ba0b"><span class="section-number-3">1.1</span> <code>qmckl_transpose</code></h3> <h3 id="orga006629"><span class="section-number-3">1.1</span> <code>qmckl_transpose</code></h3>
<div class="outline-text-3" id="text-1-1"> <div class="outline-text-3" id="text-1-1">
<p> <p>
Transposes a matrix: \(B_{ji} = A_{ij}\) Transposes a matrix: \(B_{ji} = A_{ij}\)
</p> </p>
<table id="orgd46e630" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides"> <table id="org8746e03" border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup> <colgroup>
@ -424,8 +424,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
</table> </table>
</div> </div>
<div id="outline-container-org5a3c27d" class="outline-4"> <div id="outline-container-orgc55e613" class="outline-4">
<h4 id="org5a3c27d"><span class="section-number-4">1.1.1</span> Requirements</h4> <h4 id="orgc55e613"><span class="section-number-4">1.1.1</span> Requirements</h4>
<div class="outline-text-4" id="text-1-1-1"> <div class="outline-text-4" id="text-1-1-1">
<ul class="org-ul"> <ul class="org-ul">
<li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li> <li><code>context</code> is not <code>QMCKL_NULL_CONTEXT</code></li>
@ -439,8 +439,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
</div> </div>
</div> </div>
<div id="outline-container-org53609fc" class="outline-4"> <div id="outline-container-org92628c4" class="outline-4">
<h4 id="org53609fc"><span class="section-number-4">1.1.2</span> C header</h4> <h4 id="org92628c4"><span class="section-number-4">1.1.2</span> C header</h4>
<div class="outline-text-4" id="text-1-1-2"> <div class="outline-text-4" id="text-1-1-2">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_transpose</span> ( <pre class="src src-c"><span style="color: #228b22;">qmckl_exit_code</span> <span style="color: #0000ff;">qmckl_transpose</span> (
@ -456,8 +456,8 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
</div> </div>
</div> </div>
<div id="outline-container-org44c441f" class="outline-4"> <div id="outline-container-org6b02956" class="outline-4">
<h4 id="org44c441f"><span class="section-number-4">1.1.3</span> Source</h4> <h4 id="org6b02956"><span class="section-number-4">1.1.3</span> Source</h4>
<div class="outline-text-4" id="text-1-1-3"> <div class="outline-text-4" id="text-1-1-3">
<div class="org-src-container"> <div class="org-src-container">
<pre class="src src-f90"><span style="color: #228b22;">integer </span><span style="color: #a020f0;">function</span><span style="color: #a0522d;"> </span><span style="color: #0000ff;">qmckl_transpose_f</span><span style="color: #000000; background-color: #ffffff;">(context, m, n, A, LDA, B, LDB)</span><span style="color: #a0522d;"> </span><span style="color: #a020f0;">&amp;</span> <pre class="src src-f90"><span style="color: #228b22;">integer </span><span style="color: #a020f0;">function</span><span style="color: #a0522d;"> </span><span style="color: #0000ff;">qmckl_transpose_f</span><span style="color: #000000; background-color: #ffffff;">(context, m, n, A, LDA, B, LDB)</span><span style="color: #a0522d;"> </span><span style="color: #a020f0;">&amp;</span>
@ -516,7 +516,7 @@ Transposes a matrix: \(B_{ji} = A_{ij}\)
</div> </div>
<div id="postamble" class="status"> <div id="postamble" class="status">
<p class="author">Author: TREX CoE</p> <p class="author">Author: TREX CoE</p>
<p class="date">Created: 2021-06-09 Wed 22:11</p> <p class="date">Created: 2021-06-10 Thu 21:55</p>
<p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p> <p class="validation"><a href="http://validator.w3.org/check?uri=referer">Validate</a></p>
</div> </div>
</body> </body>