From c63a23ae9a78d6603fe960aa1dadf6a189ece456 Mon Sep 17 00:00:00 2001 From: q-posev <45995097+q-posev@users.noreply.github.com> Date: Fri, 29 Apr 2022 14:20:14 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20@=20TREX-CoE?= =?UTF-8?q?/trexio@dab4310efac9b735a25b6725b67b7e3a577efb3f=20=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.html | 4 +- examples.html | 82 +++--- index.html | 4 +- templator_front.html | 670 +++++++++++++++++++++++-------------------- templator_hdf5.html | 70 ++--- templator_text.html | 88 +++--- trex.html | 134 ++++----- 7 files changed, 554 insertions(+), 498 deletions(-) diff --git a/README.html b/README.html index 3b10641..f055db0 100644 --- a/README.html +++ b/README.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + TREXIO source code documentation @@ -347,7 +347,7 @@ and bug reports should be submitted at

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/examples.html b/examples.html index 474f328..82a4d00 100644 --- a/examples.html +++ b/examples.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Examples @@ -333,24 +333,24 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Accessing sparse quantities

+
+

1 Accessing sparse quantities

-
-

1.1 Fortran

+
+

1.1 Fortran

program print_energy
@@ -411,8 +411,8 @@ One needs to read from the TREXIO file:
 
-
-

1.1.1 Declare Temporary variables

+
+

1.1.1 Declare Temporary variables

integer                       :: i, j, k, l, m
@@ -427,8 +427,8 @@ One needs to read from the TREXIO file:
 
-
-

1.1.2 Obtain the name of the TREXIO file from the command line, and open it for reading

+
+

1.1.2 Obtain the name of the TREXIO file from the command line, and open it for reading

call getarg(1, filename)
@@ -444,8 +444,8 @@ f = trexio_open (filename, 'r', TREXIO_HDF5
 
-
-

1.1.3 Read the nuclear repulsion energy

+
+

1.1.3 Read the nuclear repulsion energy

rc = trexio_read_nucleus_repulsion(f, E_nn)
@@ -459,8 +459,8 @@ f = trexio_open (filename, 'r', TREXIO_HDF5
 
-
-

1.1.4 Read the number of molecular orbitals

+
+

1.1.4 Read the number of molecular orbitals

rc = trexio_read_mo_num(f, n)
@@ -474,8 +474,8 @@ f = trexio_open (filename, 'r', TREXIO_HDF5
 
-
-

1.1.5 Allocate memory

+
+

1.1.5 Allocate memory

allocate( D(n,n), h0(n,n) )
@@ -487,8 +487,8 @@ W(:,:,:,:) = 0.d0
 
-
-

1.1.6 Read one-electron quantities

+
+

1.1.6 Read one-electron quantities

rc = trexio_has_mo_1e_int_core_hamiltonian(f)
@@ -520,8 +520,8 @@ rc = trexio_read_rdm_1e(f, D)
 
-
-

1.1.7 Read two-electron quantities

+
+

1.1.7 Read two-electron quantities

Reading is done with OpenMP. Each thread reads its own buffer, and @@ -537,8 +537,8 @@ to be protected in the critical section when modified.

-
-
1.1.7.1 Electron repulsion integrals
+
+
1.1.7.1 Electron repulsion integrals
rc = trexio_has_mo_2e_int_eri(f)
@@ -587,8 +587,8 @@ icount = BUFSIZE
 
-
-
1.1.7.2 Reduced density matrix
+
+
1.1.7.2 Reduced density matrix
rc = trexio_has_rdm_2e(f)
@@ -632,8 +632,8 @@ icount = bufsize
 
-
-

1.1.8 Compute the energy

+
+

1.1.8 Compute the energy

When the orbitals are real, we can use @@ -679,8 +679,8 @@ E = E + E_nn

-
-

1.1.9 Terminate

+
+

1.1.9 Terminate

  deallocate( D, h0, G, W )
@@ -695,7 +695,7 @@ E = E + E_nn
 

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/index.html b/index.html index 3b10641..f055db0 100644 --- a/index.html +++ b/index.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + TREXIO source code documentation @@ -347,7 +347,7 @@ and bug reports should be submitted at

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/templator_front.html b/templator_front.html index 777137d..7836ee4 100644 --- a/templator_front.html +++ b/templator_front.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Front end API @@ -333,174 +333,174 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Coding conventions

+
+

1 Coding conventions

  • integer types will be defined using types given in stdint.h
  • @@ -515,8 +515,8 @@ for the JavaScript code in this tag.
-
-

1.1 Memory allocation

+
+

1.1 Memory allocation

Memory allocation of structures can be facilitated by using the @@ -551,8 +551,8 @@ The maximum string size for the filenames is 4096 characters.

-
-

2 Front end

+
+

2 Front end

All calls to TREXIO are thread-safe. @@ -560,10 +560,10 @@ TREXIO front end is modular, which simplifies implementation of new back ends.

-
-

2.1 Error handling

+
+

2.1 Error handling

- +
@@ -852,8 +852,8 @@ and the corresponding message are not propagated to the source code. -
-

2.1.1 Decoding errors

+
+

2.1.1 Decoding errors

The trexio_string_of_error converts an exit code into a string. The @@ -879,8 +879,8 @@ and the corresponding message are not propagated to the source code.

-
-
2.1.1.1 C source code
+
+
2.1.1.1 C source code
const char*
@@ -1015,8 +1015,8 @@ and the corresponding message are not propagated to the source code.
 
-
-
2.1.1.2 Fortran interface
+
+
2.1.1.2 Fortran interface
interface
@@ -1032,8 +1032,8 @@ and the corresponding message are not propagated to the source code.
 
-
-
2.1.1.3 Python interface
+
+
2.1.1.3 Python interface
class Error(Exception):
@@ -1066,8 +1066,8 @@ and the corresponding message are not propagated to the source code.
 
-
-

2.2 Back ends

+
+

2.2 Back ends

TREXIO has several back ends: @@ -1096,8 +1096,8 @@ lines that correspond to the TREXIO_JSON back end (not implemented

-
-

2.2.1 C

+
+

2.2.1 C

typedef int32_t back_end_t;
@@ -1146,8 +1146,8 @@ This is useful due to the fact that HDF5 back end can be disabled at configure s
 
-
-

2.2.2 Fortran

+
+

2.2.2 Fortran

  integer(trexio_back_end_t), parameter :: TREXIO_HDF5 = 0
@@ -1188,8 +1188,8 @@ consistency, in version 2.2 it was renamed trexio_has_back_end.
 
-
-

2.2.3 Python

+
+

2.2.3 Python

# define TREXIO back ends
@@ -1204,8 +1204,8 @@ consistency, in version 2.2 it was renamed trexio_has_back_end.
 
-
-

2.3 Read/write behavior

+
+

2.3 Read/write behavior

Every time a reading function is called, the data is read from the @@ -1234,8 +1234,8 @@ concurrent programs, the behavior is not specified.

-
-

2.4 TREXIO file type

+
+

2.4 TREXIO file type

trexio_s is the the main type for TREXIO files, visible to the users @@ -1391,8 +1391,8 @@ to work with TREXIO files.

-
-

2.5 TODO (Remove) : Polymorphism of the file handle

+
+

2.5 TODO (Remove) : Polymorphism of the file handle

Polymorphism of the trexio_t type is handled by ensuring that the @@ -1411,8 +1411,8 @@ corresponding types for all back ends can be safely casted to

-
-

2.6 File opening

+
+

2.6 File opening

trexio_open creates a new TREXIO file or opens the existing one. @@ -1468,8 +1468,8 @@ renaming the .txt data files.

-
-

2.6.1 C

+
+

2.6.1 C

trexio_t*
@@ -1786,8 +1786,8 @@ renaming the .txt data files.
 
-
-

2.6.2 Fortran

+
+

2.6.2 Fortran

interface
@@ -1805,8 +1805,8 @@ renaming the .txt data files.
 
-
-

2.6.3 Python

+
+

2.6.3 Python

def _open(file_name: str, mode: str, back_end: int):
@@ -1854,8 +1854,8 @@ renaming the .txt data files.
 
-
-

2.6.4 Zero-based versus one-based arrays of indices

+
+

2.6.4 Zero-based versus one-based arrays of indices

Because arrays are zero-based in Fortran, we need to set a flag to @@ -1888,8 +1888,8 @@ know if we need to shift by 1 arrays of indices.

-
-

2.7 File closing

+
+

2.7 File closing

trexio_close closes an existing trexio_t file. @@ -1906,8 +1906,8 @@ output:

-
-

2.7.1 C

+
+

2.7.1 C

trexio_exit_code
@@ -1992,8 +1992,8 @@ output:
 
-
-

2.7.2 Fortran

+
+

2.7.2 Fortran

interface
@@ -2008,8 +2008,8 @@ output:
 
-
-

2.7.3 Python

+
+

2.7.3 Python

def _close(trexio_file):
@@ -2027,8 +2027,8 @@ output:
 
-
-

2.8 File existence

+
+

2.8 File existence

trexio_inquire check whether TREXIO file exists. @@ -2065,8 +2065,8 @@ You can see examples of both functionalities in test_f.f90 (search

-
-

2.8.1 C

+
+

2.8.1 C

trexio_exit_code
@@ -2096,8 +2096,8 @@ You can see examples of both functionalities in test_f.f90  (search
 
-
-

2.8.2 Fortran

+
+

2.8.2 Fortran

The function below is a C binding. @@ -2117,8 +2117,8 @@ The front end Fortran function for trexio_inquire can be found in t

-
-

2.8.3 Python

+
+

2.8.3 Python

def _inquire(file_name: str) -> bool:
@@ -2137,8 +2137,8 @@ The front end Fortran function for trexio_inquire can be found in t
 
-
-

2.9 File state

+
+

2.9 File state

trexio_set_state set an existing trexio_t file handle to a given state. @@ -2157,8 +2157,8 @@ output:

-
-

2.9.1 C

+
+

2.9.1 C

trexio_exit_code
@@ -2186,8 +2186,8 @@ output:
 
-
-

2.9.2 Fortran

+
+

2.9.2 Fortran

interface
@@ -2212,8 +2212,8 @@ output:
 
-
-

2.9.3 Python

+
+

2.9.3 Python

See TREXIO File Python class. @@ -2222,8 +2222,8 @@ See TREXIO File Python class.

-
-

2.10 Tasks to be done before closing

+
+

2.10 Tasks to be done before closing

trexio_exit_code
@@ -2324,12 +2324,12 @@ See TREXIO File Python class.
 
-
-

3 Templates for front end

+
+

3 Templates for front end

-
-

3.1 Description

+
+

3.1 Description

Consider the following block of trex.json: @@ -2550,12 +2550,12 @@ value will result in TREXIO_INVALID_ARG_2 exit code.

-
-

3.2 Templates for front end has/read/write a single numerical attribute

+
+

3.2 Templates for front end has/read/write a single numerical attribute

-
-

3.2.1 Introduction

+
+

3.2.1 Introduction

This section concerns API calls related to numerical attributes, @@ -2626,8 +2626,8 @@ namely single value of int/float types.

-
-

3.2.2 C templates for front end

+
+

3.2.2 C templates for front end

The C templates that correspond to each of the abovementioned @@ -2641,12 +2641,12 @@ precision (see Table above).

-
-
3.2.2.1 Function declarations
+
+
3.2.2.1 Function declarations
-
-
3.2.2.2 Source code for double precision functions
+
+
3.2.2.2 Source code for double precision functions
trexio_exit_code
@@ -2710,8 +2710,8 @@ precision (see Table above).
 
-
-
3.2.2.3 Source code for single precision functions
+
+
3.2.2.3 Source code for single precision functions
trexio_exit_code
@@ -2787,8 +2787,8 @@ precision (see Table above).
 
-
-
3.2.2.4 Source code for default functions
+
+
3.2.2.4 Source code for default functions
trexio_exit_code
@@ -2843,8 +2843,8 @@ precision (see Table above).
 
-
-

3.2.3 Fortran templates for front end

+
+

3.2.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -2936,8 +2936,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.2.4 Python templates for front end

+
+

3.2.4 Python templates for front end

def write_$group_num$(trexio_file, num_w: $group_num_py_dtype$) -> None:
@@ -3010,12 +3010,12 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

3.3 Templates for front end has/read/write a dataset of numerical data

+
+

3.3 Templates for front end has/read/write a dataset of numerical data

-
-

3.3.1 Introduction

+
+

3.3.1 Introduction

This section concerns API calls related to datasets. @@ -3097,8 +3097,8 @@ This section concerns API calls related to datasets.

-
-

3.3.2 C templates for front end

+
+

3.3.2 C templates for front end

The C templates that correspond to each of the abovementioned functions can be found below. @@ -3109,12 +3109,12 @@ The basic (non-suffixed) API call on datasets deals with real(cdouble

-
-
3.3.2.1 Function declarations
+
+
3.3.2.1 Function declarations
-
-
3.3.2.2 Source code for double precision functions
+
+
3.3.2.2 Source code for double precision functions
trexio_exit_code
@@ -3277,8 +3277,8 @@ The basic (non-suffixed) API call on datasets deals with real(cdouble
 
-
-
3.3.2.3 Source code for single precision functions
+
+
3.3.2.3 Source code for single precision functions
trexio_exit_code
@@ -3429,11 +3429,11 @@ The basic (non-suffixed) API call on datasets deals with real(cdouble
 
-
-
3.3.2.4 Source code for memory-safe functions
+
+
3.3.2.4 Source code for memory-safe functions
-
trexio_exit_code rc;
+
trexio_exit_code rc;
 int64_t $group_dset_dim$ = 0;
 
 /* Error handling for this call is added by the generator */
@@ -3589,8 +3589,8 @@ rc = trexio_read_$group_dset_dim$_64(file, &($group_dset_dim$));
 
-
-
3.3.2.5 Source code for default functions
+
+
3.3.2.5 Source code for default functions
trexio_exit_code
@@ -3665,8 +3665,8 @@ rc = trexio_read_$group_dset_dim$_64(file, &($group_dset_dim$));
 
-
-

3.3.3 Fortran templates for front end

+
+

3.3.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -3758,8 +3758,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.3.4 Python templates for front end

+
+

3.3.4 Python templates for front end

def write_$group_dset$(trexio_file, dset_w) -> None:
@@ -3936,12 +3936,12 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

3.4 Templates for front end has/read/write a dataset of sparse data

+
+

3.4 Templates for front end has/read/write a dataset of sparse data

-
-

3.4.1 Introduction

+
+

3.4.1 Introduction

Sparse data structures are used typically for large tensors such as @@ -4102,16 +4102,16 @@ This section concerns API calls related to sparse data structures.

-
-

3.4.2 C templates for front end

+
+

3.4.2 C templates for front end

-
-
3.4.2.1 Function declarations
+
+
3.4.2.1 Function declarations
-
-
3.4.2.2 Source code for default functions
+
+
3.4.2.2 Source code for default functions
trexio_exit_code trexio_read_safe_$group_dset$(trexio_t* const file,
@@ -4387,8 +4387,8 @@ This section concerns API calls related to sparse data structures.
 
-
-

3.4.3 Fortran templates for front end

+
+

3.4.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -4489,8 +4489,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.4.4 Python templates for front end

+
+

3.4.4 Python templates for front end

def write_$group_dset$(trexio_file: File, offset_file: int, buffer_size: int, indices: list, values: list) -> None:
@@ -4702,12 +4702,12 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

3.5 Templates for front end has/read/write a dataset of strings

+
+

3.5 Templates for front end has/read/write a dataset of strings

-
-

3.5.1 Introduction

+
+

3.5.1 Introduction

This section concerns API calls related to datasets of strings. @@ -4747,8 +4747,8 @@ This section concerns API calls related to datasets of strings.

-
-

3.5.2 C templates for front end

+
+

3.5.2 C templates for front end

First parameter is the TREXIO file handle. Second parameter is the variable to be written/read @@ -4756,12 +4756,12 @@ to/from the TREXIO file (except for trexio_has_ functi

-
-
3.5.2.1 Function declarations
+
+
3.5.2.1 Function declarations
-
-
3.5.2.2 Source code for default functions
+
+
3.5.2.2 Source code for default functions
trexio_exit_code
@@ -5011,8 +5011,8 @@ to/from the TREXIO file (except for trexio_has_ functi
 
-
-

3.5.3 Fortran templates for front end

+
+

3.5.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -5111,8 +5111,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.5.4 Python templates for front end

+
+

3.5.4 Python templates for front end

def write_$group_dset$(trexio_file, dset_w: list) -> None:
@@ -5210,12 +5210,12 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

3.6 Templates for front end has/read/write a single string attribute

+
+

3.6 Templates for front end has/read/write a single string attribute

-
-

3.6.1 Introduction

+
+

3.6.1 Introduction

This section concerns API calls related to string attributes. @@ -5255,16 +5255,16 @@ This section concerns API calls related to string attributes.

-
-

3.6.2 C templates for front end

+
+

3.6.2 C templates for front end

-
-
3.6.2.1 Function declarations
+
+
3.6.2.1 Function declarations
-
-
3.6.2.2 Source code for default functions
+
+
3.6.2.2 Source code for default functions
trexio_exit_code
@@ -5368,8 +5368,8 @@ This section concerns API calls related to string attributes.
 
-
-

3.6.3 Fortran templates for front end

+
+

3.6.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -5449,8 +5449,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.6.4 Python templates for front end

+
+

3.6.4 Python templates for front end

def write_$group_str$(trexio_file, str_w: str) -> None:
@@ -5525,12 +5525,12 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

3.7 Templates for front end delete an entire group (UNSAFE MODE)

+
+

3.7 Templates for front end delete an entire group (UNSAFE MODE)

-
-

3.7.1 Introduction

+
+

3.7.1 Introduction

This section concerns API calls related to string attributes. @@ -5560,8 +5560,8 @@ This section concerns API calls related to string attributes.

-
-

3.7.2 C templates for front end

+
+

3.7.2 C templates for front end

trexio_exit_code
@@ -5596,8 +5596,8 @@ This section concerns API calls related to string attributes.
 
-
-

3.7.3 Fortran templates for front end

+
+

3.7.3 Fortran templates for front end

The Fortran templates that provide an access to the C API calls from Fortran. @@ -5617,8 +5617,8 @@ These templates are based on the use of iso_c_binding. Pointers hav

-
-

3.7.4 Python templates for front end

+
+

3.7.4 Python templates for front end

def delete_$group$(trexio_file) -> None:
@@ -5643,8 +5643,8 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

4 Source code for the determinant part

+
+

4 Source code for the determinant part

Storage of the determinants is a particular case, @@ -5706,13 +5706,43 @@ This section concerns API calls related to Slater determinants.

+ + + + +
trexio_read_determinant_coefficient_size Get the number of the coefficients
trexio_get_int64_numGet the number of int64 bit fields per determinant
-
-

4.0.1 C source code

+
+

4.0.1 C source code

+
+
trexio_exit_code
+trexio_get_int64_num(trexio_t* const file, int32_t* const num)
+{
+
+  if (file  == NULL) return TREXIO_INVALID_ARG_1;
+  if (num   == NULL) return TREXIO_INVALID_ARG_2;
+
+  /* Read the number of mos */
+  int64_t mo_num = 0L;
+  trexio_exit_code rc = trexio_read_mo_num_64(file, &mo_num);
+  if (rc != TREXIO_SUCCESS) return rc;
+  if (mo_num == 0L) return TREXIO_INVALID_NUM;
+
+  /* Compute how many integer numbers is needed to represent a determinant */
+  int32_t int_num = 0;
+  int_num = (mo_num - 1L)/64 + 1;
+
+  *num = int_num;
+
+  return TREXIO_SUCCESS;
+}
+
+
+
trexio_exit_code
 trexio_read_determinant_list (trexio_t* const file, const int64_t offset_file, int64_t* const buffer_size_read, int64_t* const dset)
@@ -5722,17 +5752,10 @@ This section concerns API calls related to Slater determinants.
   if (dset  == NULL) return TREXIO_INVALID_ARG_2;
   if (trexio_has_determinant_list(file) != TREXIO_SUCCESS) return TREXIO_DSET_MISSING;
 
-  trexio_exit_code rc;
-
-  /* Read the number of mos */
-  int64_t mo_num = 0L;
-  rc = trexio_read_mo_num_64(file, &mo_num);
+  /* Get the number of int bit fields per determinant */
+  int32_t int_num = 0;
+  trexio_exit_code rc = trexio_get_int64_num(file, &int_num);
   if (rc != TREXIO_SUCCESS) return rc;
-  if (mo_num == 0L) return TREXIO_INVALID_NUM;
-
-  /* Compute how many integer numbers is needed to represent a determinant */
-  uint32_t int_num = 0;
-  int_num = (mo_num - 1)/64 + 1;
 
   uint32_t rank = 2;
   uint64_t det_size = (uint64_t) (*buffer_size_read);
@@ -5770,11 +5793,12 @@ This section concerns API calls related to Slater determinants.
   if (rc == TREXIO_END) *buffer_size_read = eof_read_size;
 
   return rc;
-
 }
+
+
- -trexio_exit_code +
+
trexio_exit_code
 trexio_read_determinant_coefficient (trexio_t* const file, const int64_t offset_file, int64_t* const buffer_size_read, double* const dset)
 {
 
@@ -5820,13 +5844,15 @@ This section concerns API calls related to Slater determinants.
   if (rc == TREXIO_END) *buffer_size_read = eof_read_size;
 
   return rc;
-
 }
+
+
- -trexio_exit_code +
+
trexio_exit_code
 trexio_read_determinant_coefficient_size(trexio_t* const file, int64_t* const size_max)
 {
+
   if (file  == NULL) return TREXIO_INVALID_ARG_1;
   if (size_max == NULL) return TREXIO_INVALID_ARG_2;
   if (trexio_has_determinant_coefficient(file) != TREXIO_SUCCESS) return TREXIO_DSET_MISSING;
@@ -5853,8 +5879,11 @@ This section concerns API calls related to Slater determinants.
     return TREXIO_FAILURE;  /* Impossible case */
   }
 }
+
+
-trexio_exit_code +
+
trexio_exit_code
 trexio_read_safe_determinant_list (trexio_t* const file, const int64_t offset_file, int64_t* const buffer_size_read, int64_t* const dset_out, const int64_t dim_out)
 {
   return trexio_read_determinant_list(file, offset_file, buffer_size_read, dset_out);
@@ -5876,17 +5905,10 @@ This section concerns API calls related to Slater determinants.
   if (file == NULL) return TREXIO_INVALID_ARG_1;
   if (dset == NULL) return TREXIO_INVALID_ARG_2;
 
-  trexio_exit_code rc;
-
-  /* Read the number of mos */
-  int64_t mo_num = 0L;
-  rc = trexio_read_mo_num_64(file, &mo_num);
+  /* Get the number of int bit fields per determinant */
+  int32_t int_num = 0;
+  trexio_exit_code rc = trexio_get_int64_num(file, &int_num);
   if (rc != TREXIO_SUCCESS) return rc;
-  if (mo_num == 0L) return TREXIO_INVALID_NUM;
-
-  /* Compute how many integer numbers is needed to represent a determinant */
-  uint32_t int_num = 0;
-  int_num = (mo_num - 1)/64 + 1;
 
   uint32_t rank = 2;
   uint64_t dims[2] = {buffer_size, int_num*2UL};
@@ -5939,8 +5961,11 @@ This section concerns API calls related to Slater determinants.
 
   return TREXIO_SUCCESS;
 }
+
+
-trexio_exit_code +
+
trexio_exit_code
 trexio_write_determinant_coefficient (trexio_t* const file, const int64_t offset_file, const int64_t buffer_size, const double* dset)
 {
 
@@ -5975,8 +6000,11 @@ This section concerns API calls related to Slater determinants.
 
   return TREXIO_FAILURE;
 }
+
+
-trexio_exit_code +
+
trexio_exit_code
 trexio_write_safe_determinant_list (trexio_t* const file, const int64_t offset_file, const int64_t buffer_size, const int64_t* dset_in, const int64_t dim_in)
 {
   return trexio_write_determinant_list(file, offset_file, buffer_size, dset_in);
@@ -6053,8 +6081,8 @@ This section concerns API calls related to Slater determinants.
 
-
-

4.0.2 Fortran interface

+
+

4.0.2 Fortran interface

The Fortran templates that provide an access to the C API calls from Fortran. @@ -6197,13 +6225,22 @@ These templates are based on the use of iso_c_binding. Pointers hav integer(c_int64_t), intent(in), value :: trex_file end function trexio_has_determinant_coefficient end interface + +interface + integer(trexio_exit_code) function trexio_get_int64_num (trex_file, num) bind(C) + use, intrinsic :: iso_c_binding + import + integer(c_int64_t), intent(in), value :: trex_file + integer(c_int32_t), intent(out) :: num + end function trexio_get_int64_num +end interface

-
-

4.0.3 Python interface

+
+

4.0.3 Python interface

def write_determinant_list(trexio_file: File, offset_file: int, buffer_size: int, determinants: list) -> None:
@@ -6274,6 +6311,7 @@ These templates are based on the use of iso_c_binding. Pointers hav
     if rc != TREXIO_SUCCESS:
         raise Error(rc)
 
+
 def write_determinant_coefficient(trexio_file: File, offset_file: int, buffer_size: int, coefficients: list) -> None:
     """Write the determinant coefficients in the TREXIO file.
 
@@ -6362,8 +6400,7 @@ These templates are based on the use of iso_c_binding. Pointers hav
     # read the number of determinants already in the file
     det_num = read_determinant_num(trexio_file)
     # calculate the int_num (number of int bit fields per determinant)
-    mo_num = read_mo_num(trexio_file)
-    int_num = 2*int((mo_num-1)/64+1)
+    int_num = 2 * get_int64_num(trexio_file)
 
     # additional modification needed to avoid allocating more memory than needed if EOF will be reached during read
     overflow = offset_file + buffer_size - det_num
@@ -6392,6 +6429,7 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
     return (dets_reshaped, n_int_read, eof_flag)
 
+
 def read_determinant_coefficient(trexio_file: File, offset_file: int, buffer_size: int) -> tuple:
     """Read determinant_coefficient from the TREXIO file.
 
@@ -6477,13 +6515,30 @@ These templates are based on the use of iso_c_binding. Pointers hav
         raise Error(rc)
 
     return num
+
+
+def get_int64_num(trexio_file) -> int:
+    """Compute the number of int64 bit fields corresponding to the TREXIO file.
+
+    Parameter is a ~TREXIO File~ object that has been created by a call to ~open~ function.
+
+    Returns:
+        ~num~: int
+        Number of int64 bit fields per determinant.
+
+    Raises:
+        - Exception from AssertionError if TREXIO return code ~rc~ is different from TREXIO_SUCCESS and prints the error message using trexio_string_of_error.
+        - Exception from some other error (e.g. RuntimeError).
+    """
+
+    rc, num = pytr.trexio_get_int64_num(trexio_file.pytrexio_s)
+    if rc != TREXIO_SUCCESS:
+        raise Error(rc)
+
+    return num
 
-

-#+endsrc -

-
def has_determinant_list(trexio_file) -> bool:
     """Check that determinant_list exists in the TREXIO file.
@@ -6504,6 +6559,7 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
     return rc == TREXIO_SUCCESS
 
+
 def has_determinant_coefficient(trexio_file) -> bool:
     """Check that determinant_coefficient exists in the TREXIO file.
 
@@ -6528,8 +6584,8 @@ These templates are based on the use of iso_c_binding. Pointers hav
 
-
-

5 General helper functions

+
+

5 General helper functions

This section contains general helper functions like trexio_info. @@ -6563,8 +6619,8 @@ of the determinant and returns two list of orbitals each corresponding to a diff

-
-

5.1 C

+
+

5.1 C

trexio_exit_code trexio_info(void);
@@ -6759,8 +6815,8 @@ of the determinant and returns two list of orbitals each corresponding to a diff
 
-
-

5.2 Fortran

+
+

5.2 Fortran

interface
@@ -6801,8 +6857,8 @@ of the determinant and returns two list of orbitals each corresponding to a diff
 
-
-

5.3 Python

+
+

5.3 Python

def info():
@@ -6878,8 +6934,8 @@ of the determinant and returns two list of orbitals each corresponding to a diff
 
-
-

6 Fortran helper/wrapper functions

+
+

6 Fortran helper/wrapper functions

The function below adapts the original C-based trexio_open for Fortran. @@ -7020,7 +7076,7 @@ two code are identical, i.e. if the assert statement pass. else call trexio_string_of_error(trexio_rc, str) print *, trim(str) - error stop 1 + stop 1 endif end subroutine trexio_assert @@ -7031,7 +7087,7 @@ two code are identical, i.e. if the assert statement pass.

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/templator_hdf5.html b/templator_hdf5.html index b39d402..f5e94a2 100644 --- a/templator_hdf5.html +++ b/templator_hdf5.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + HDF5 back end @@ -311,23 +311,23 @@ for the JavaScript code in this tag.

Table of Contents

-
-

1 Template for HDF5 definitions

+
+

1 Template for HDF5 definitions

#define $GROUP$_GROUP_NAME          "$group$"
@@ -339,8 +339,8 @@ for the JavaScript code in this tag.
 
-
-

2 Template for HDF5 structures

+
+

2 Template for HDF5 structures

typedef struct trexio_hdf5_s {
@@ -353,8 +353,8 @@ for the JavaScript code in this tag.
 
-
-

3 Template for HDF5 init/deinit

+
+

3 Template for HDF5 init/deinit

trexio_exit_code
@@ -459,8 +459,8 @@ for the JavaScript code in this tag.
 
-
-

4 Template for HDF5 has/read/write a numerical attribute

+
+

4 Template for HDF5 has/read/write a numerical attribute

trexio_exit_code
@@ -564,8 +564,8 @@ for the JavaScript code in this tag.
 
-
-

5 Template for HDF5 has/read/write a dataset of numerical data

+
+

5 Template for HDF5 has/read/write a dataset of numerical data

trexio_exit_code
@@ -699,8 +699,8 @@ for the JavaScript code in this tag.
 
-
-

6 Template for HDF5 has/read/write a dataset of sparse data

+
+

6 Template for HDF5 has/read/write a dataset of sparse data

Sparse data is stored using extensible datasets of HDF5. Extensibility is required @@ -903,8 +903,8 @@ due to the fact that the sparse data will be written in chunks of user-defined s

-
-

7 Template for HDF5 has/read/write a dataset of strings

+
+

7 Template for HDF5 has/read/write a dataset of strings

trexio_exit_code
@@ -1102,8 +1102,8 @@ due to the fact that the sparse data will be written in chunks of user-defined s
 
-
-

8 Template for HDF5 has/read/write a string attribute

+
+

8 Template for HDF5 has/read/write a string attribute

trexio_exit_code
@@ -1230,8 +1230,8 @@ due to the fact that the sparse data will be written in chunks of user-defined s
 
-
-

9 Template for HDF5 delete a group (UNSAFE mode)

+
+

9 Template for HDF5 delete a group (UNSAFE mode)

Note: in early versions of the HDF5 library (v < 1.10) unlinking an object was not working as expected @@ -1271,8 +1271,8 @@ Thus, any corrupted/lost file space will remain in the first file. The use of

-
-

10 Source code for the determinant part

+
+

10 Source code for the determinant part

Each array is stored in a separate HDF5 dataset due to the fact that determinant I/O has to be decoupled. @@ -1525,8 +1525,8 @@ Size specifies the number of data items (e.g. determinants) to process.

-
-

11 Helper functions

+
+

11 Helper functions

trexio_exit_code
@@ -1789,7 +1789,7 @@ Size specifies the number of data items (e.g. determinants) to process.
 

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/templator_text.html b/templator_text.html index 0dff8ed..c39f671 100644 --- a/templator_text.html +++ b/templator_text.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + TEXT back end @@ -311,20 +311,20 @@ for the JavaScript code in this tag.

Table of Contents

@@ -346,8 +346,8 @@ directory. The file is written when closed, or when the flush function is called.

-
-

1 Template for group-related structures in text back end

+
+

1 Template for group-related structures in text back end

typedef struct $group$_s {
@@ -366,8 +366,8 @@ The file is written when closed, or when the flush function is called.
 
-
-

2 Template for general structure in text back end

+
+

2 Template for general structure in text back end

typedef struct trexio_text_s {
@@ -380,8 +380,8 @@ The file is written when closed, or when the flush function is called.
 
-
-

3 Initialize function (constant part)

+
+

3 Initialize function (constant part)

trexio_exit_code
@@ -524,8 +524,8 @@ The file is written when closed, or when the flush function is called.
 
-
-

4 Deinitialize function (templated part)

+
+

4 Deinitialize function (templated part)

trexio_exit_code
@@ -547,8 +547,8 @@ The file is written when closed, or when the flush function is called.
 
-
-

5 Template for text read a group

+
+

5 Template for text read a group

$group$_t*
@@ -849,8 +849,8 @@ trexio_text_read_$group$ (trexio_text_t* 
 
-
-

6 Template for text flush a group

+
+

6 Template for text flush a group

trexio_exit_code
@@ -914,8 +914,8 @@ trexio_text_read_$group$ (trexio_text_t* 
 
-
-

7 Template for text free memory

+
+

7 Template for text free memory

Memory is allocated when reading. The following function frees memory. @@ -962,8 +962,8 @@ Memory is allocated when reading. The following function frees memory.

-
-

8 Template for has/read/write a numerical attribute

+
+

8 Template for has/read/write a numerical attribute

trexio_exit_code
@@ -1026,8 +1026,8 @@ Memory is allocated when reading. The following function frees memory.
 
-
-

9 Template for has/read/write a dataset of numerical data

+
+

9 Template for has/read/write a dataset of numerical data

The group_dset array is assumed allocated with the appropriate size. @@ -1123,8 +1123,8 @@ The group_dset array is assumed allocated with the appropriate size

-
-

10 Template for has/read/write a dataset of strings

+
+

10 Template for has/read/write a dataset of strings

The group_dset array is assumed allocated with the appropriate size. @@ -1225,8 +1225,8 @@ The group_dset array is assumed allocated with the appropriate size

-
-

11 Template for has/read/write a string attribute

+
+

11 Template for has/read/write a string attribute

trexio_exit_code
@@ -1300,8 +1300,8 @@ The group_dset array is assumed allocated with the appropriate size
 
-
-

12 Template for has/read/write the dataset of sparse data

+
+

12 Template for has/read/write the dataset of sparse data

Each sparse array is stored in a separate .txt file due to the fact that sparse I/O has to be decoupled @@ -1575,8 +1575,8 @@ User provides indices and values of the sparse array as two separate variables.

-
-

13 Template for text delete a group (UNSAFE mode)

+
+

13 Template for text delete a group (UNSAFE mode)

trexio_exit_code
@@ -1604,8 +1604,8 @@ User provides indices and values of the sparse array as two separate variables.
 
-
-

14 Source code for the determinant part

+
+

14 Source code for the determinant part

Each array is stored in a separate .txt file due to the fact that determinant I/O has to be decoupled @@ -2009,7 +2009,7 @@ Size specifies the number of data items, e.g. determinants.

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate

diff --git a/trex.html b/trex.html index 223bc37..cbfd9a1 100644 --- a/trex.html +++ b/trex.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + TREX Configuration file @@ -333,35 +333,35 @@ for the JavaScript code in this tag.

Table of Contents

@@ -407,8 +407,8 @@ the examples.

-
-

1 Metadata (metadata group)

+
+

1 Metadata (metadata group)

As we expect our files to be archived in open-data repositories, we @@ -418,7 +418,7 @@ which have participated to the creation of the file, a list of authors of the file, and a textual description.

- +
@@ -499,15 +499,15 @@ then the unsafe attribute value can be manually overwritten (in uns -
-

2 Electron (electron group)

+
+

2 Electron (electron group)

We consider wave functions expressed in the spin-free formalism, where the number of ↑ and ↓ electrons is fixed.

-
+
@@ -553,15 +553,15 @@ the number of ↑ and ↓ electrons is fixed. -
-

3 Nucleus (nucleus group)

+
+

3 Nucleus (nucleus group)

The nuclei are considered as fixed point charges. Coordinates are given in Cartesian \((x,y,z)\) format.

-
+
@@ -628,8 +628,8 @@ given in Cartesian \((x,y,z)\) format. -
-

4 Effective core potentials (ecp group)

+
+

4 Effective core potentials (ecp group)

An effective core potential (ECP) \(V_A^{\text{ECP}}\) replacing the @@ -662,7 +662,7 @@ The functions \(V_{A\ell}\) are parameterized as: See http://dx.doi.org/10.1063/1.4984046 or https://doi.org/10.1063/1.5121006 for more info.

-
+
@@ -764,8 +764,8 @@ If you encounter the aforementioned issue, please report it to our -

4.1 Example

+
+

4.1 Example

For example, consider H2 molecule with the following @@ -828,8 +828,8 @@ power = [

-
-

5 Basis set (basis group)

+
+

5 Basis set (basis group)

We consider here basis functions centered on nuclei. Hence, we enable @@ -882,7 +882,7 @@ If the the basis function is not considered normalized, \(\mathcal{N}_s=1\). All the basis set parameters are stored in one-dimensional arrays:

-
+
@@ -976,8 +976,8 @@ All the basis set parameters are stored in one-dimensional arrays:
-
-

5.1 Example

+
+

5.1 Example

For example, consider H2 with the following basis set (in GAMESS @@ -1055,8 +1055,8 @@ prim_factor =

-
-

6 Atomic orbitals (ao group)

+
+

6 Atomic orbitals (ao group)

Going from the atomic basis set to AOs implies a systematic @@ -1109,13 +1109,13 @@ shell, as in the GAMESS convention where

In such a case, one should set the normalization of the shell (in -the Basis set section) to \(\mathcal{N}_{z^2}\), which is the +the Basis set section) to \(\mathcal{N}_{z^2}\), which is the normalization factor of the atomic orbitals in spherical coordinates. The normalization factor of the \(xy\) function which should be introduced here should be \(\frac{\mathcal{N}_{xy}}{\mathcal{N}_{z^2}}\).

- +
@@ -1167,8 +1167,8 @@ introduced here should be \(\frac{\mathcal{N}_{xy}}{\mathcal{N}_{z^2}}\).
-
-

6.1 One-electron integrals (ao_1e_int group)

+
+

6.1 One-electron integrals (ao_1e_int group)

  • \[ \hat{V}_{\text{ne}} = \sum_{A=1}^{N_\text{nucl}} @@ -1185,7 +1185,7 @@ The one-electron integrals for a one-electron operator \(\hat{O}\) are over atomic orbitals.

    - +
    @@ -1245,8 +1245,8 @@ over atomic orbitals. -
    -

    6.2 Two-electron integrals (ao_2e_int group)

    +
    +

    6.2 Two-electron integrals (ao_2e_int group)

    The two-electron integrals for a two-electron operator \(\hat{O}\) are @@ -1267,7 +1267,7 @@ notation. \mathbf{r}_j \vert)}{\vert \mathbf{r}_i - \mathbf{r}_j \vert} \] : electron-electron long range potential -

    +
    @@ -1307,10 +1307,10 @@ notation. -
    -

    7 Molecular orbitals (mo group)

    +
    +

    7 Molecular orbitals (mo group)

    -
    +
    @@ -1376,8 +1376,8 @@ notation.
-
-

7.1 One-electron integrals (mo_1e_int group)

+
+

7.1 One-electron integrals (mo_1e_int group)

The operators as the same as those defined in the @@ -1385,7 +1385,7 @@ The operators as the same as those defined in the the basis of molecular orbitals.

- +
@@ -1445,8 +1445,8 @@ the basis of molecular orbitals. -
-

7.2 Two-electron integrals (mo_2e_int group)

+
+

7.2 Two-electron integrals (mo_2e_int group)

The operators as the same as those defined in the @@ -1454,7 +1454,7 @@ The operators as the same as those defined in the the basis of molecular orbitals.

-
+
@@ -1494,8 +1494,8 @@ the basis of molecular orbitals. -
-

8 Slater determinants (determinant group)

+
+

8 Slater determinants (determinant group)

The configuration interaction (CI) wave function \(\Psi\) @@ -1560,7 +1560,7 @@ Internally, bit fields for \(\alpha\) and \(\beta\) electrons are stored separat which is why the determinant.list attribute has a second dimension.

-
+
@@ -1606,8 +1606,8 @@ which is why the determinant.list attribute has a second dimension. -
-

9 Excited states (state group)

+
+

9 Excited states (state group)

By default, the determinant group corresponds to the ground state. @@ -1616,7 +1616,7 @@ correspond to excited state wave functions for the same set of determinants. This is the goal of the present group

-
+
@@ -1655,8 +1655,8 @@ determinants. This is the goal of the present group -
-

10 Reduced density matrices (rdm group)

+
+

10 Reduced density matrices (rdm group)

The reduced density matrices are defined in the basis of molecular @@ -1709,7 +1709,7 @@ The total energy can be computed as: \]

-
+
@@ -1790,8 +1790,8 @@ The total energy can be computed as: -
-

11 Quantum Monte Carlo data (qmc group)

+
+

11 Quantum Monte Carlo data (qmc group)

In quantum Monte Carlo calculations, the wave function is evaluated @@ -1805,7 +1805,7 @@ By convention, the electron coordinates contain first all the electrons of $↑$-spin and then all the $↓$-spin.

-
+
@@ -1860,7 +1860,7 @@ of $↑$-spin and then all the $↓$-spin.

Author: TREX-CoE

-

Created: 2022-04-23 Sat 17:25

+

Created: 2022-04-29 Fri 14:20

Validate