mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-08 20:33:36 +01:00
split the basis format to depend on shell_num and prim_num
This commit is contained in:
parent
64b3e25da5
commit
9321213a21
71
trex.org
71
trex.org
@ -215,17 +215,18 @@ arrays are 0-based. Hence, we introduce the ~index~ type which is an
|
|||||||
All the basis set parameters are stored in one-dimensional arrays:
|
All the basis set parameters are stored in one-dimensional arrays:
|
||||||
|
|
||||||
#+NAME: basis
|
#+NAME: basis
|
||||||
| Variable | Type | Dimensions | Description |
|
| Variable | Type | Dimensions | Description |
|
||||||
|-----------------+---------+---------------+------------------------------------------------------------------|
|
|-----------------+---------+---------------------+--------------------------------------------------------------|
|
||||||
| ~type~ | ~str~ | | Type of basis set: "Gaussian" or "Slater" |
|
| ~type~ | ~str~ | | Type of basis set: "Gaussian" or "Slater" |
|
||||||
| ~num~ | ~dim~ | | Total number of primitives |
|
| ~prim_num~ | ~dim~ | | Total number of primitives |
|
||||||
| ~nucleus_index~ | ~index~ | ~(basis.num)~ | One-to-one correspondence between primitives and atomic indices |
|
| ~shell_num~ | ~dim~ | | Total number of shells |
|
||||||
| ~ang_mom~ | ~int~ | ~(basis.num)~ | One-to-one correspondence between primitives and angular momenta |
|
| ~nucleus_index~ | ~index~ | ~(basis.shell_num)~ | One-to-one correspondence between shells and atomic indices |
|
||||||
| ~shell_index~ | ~index~ | ~(basis.num)~ | One-to-one correspondence between primitives and atomic shells |
|
| ~ang_mom~ | ~int~ | ~(basis.shell_num)~ | One-to-one correspondence between shells and angular momenta |
|
||||||
| ~shell_factor~ | ~float~ | ~(basis.num)~ | Normalization factor of the shell ($\mathcal{N}_s$) |
|
| ~shell_factor~ | ~float~ | ~(basis.shell_num)~ | Normalization factor of each shell ($\mathcal{N}_s$) |
|
||||||
| ~exponent~ | ~float~ | ~(basis.num)~ | Exponents of the primitives ($\gamma_{ks}$) |
|
| ~shell_index~ | ~index~ | ~(basis.prim_num)~ | One-to-one correspondence between primitives and shell index |
|
||||||
| ~coefficient~ | ~float~ | ~(basis.num)~ | Coefficients of the primitives ($a_{ks}$) |
|
| ~exponent~ | ~float~ | ~(basis.prim_num)~ | Exponents of the primitives ($\gamma_{ks}$) |
|
||||||
| ~prim_factor~ | ~float~ | ~(basis.num)~ | Normalization coefficients for the primitives ($f_{ks}$) |
|
| ~coefficient~ | ~float~ | ~(basis.prim_num)~ | Coefficients of the primitives ($a_{ks}$) |
|
||||||
|
| ~prim_factor~ | ~float~ | ~(basis.prim_num)~ | Normalization coefficients for the primitives ($f_{ks}$) |
|
||||||
|
|
||||||
#+CALL: json(data=basis, title="basis")
|
#+CALL: json(data=basis, title="basis")
|
||||||
|
|
||||||
@ -233,15 +234,16 @@ arrays are 0-based. Hence, we introduce the ~index~ type which is an
|
|||||||
:RESULTS:
|
:RESULTS:
|
||||||
#+begin_src python :tangle trex.json
|
#+begin_src python :tangle trex.json
|
||||||
"basis": {
|
"basis": {
|
||||||
"type" : [ "str" , [] ]
|
"type" : [ "str" , [] ]
|
||||||
, "num" : [ "dim" , [] ]
|
, "prim_num" : [ "dim" , [] ]
|
||||||
, "nucleus_index" : [ "index", [ "basis.num" ] ]
|
, "shell_num" : [ "dim" , [] ]
|
||||||
, "ang_mom" : [ "int" , [ "basis.num" ] ]
|
, "nucleus_index" : [ "index", [ "basis.shell_num" ] ]
|
||||||
, "shell_index" : [ "index", [ "basis.num" ] ]
|
, "ang_mom" : [ "int" , [ "basis.shell_num" ] ]
|
||||||
, "shell_factor" : [ "float", [ "basis.num" ] ]
|
, "shell_factor" : [ "float", [ "basis.shell_num" ] ]
|
||||||
, "exponent" : [ "float", [ "basis.num" ] ]
|
, "shell_index" : [ "index", [ "basis.prim_num" ] ]
|
||||||
, "coefficient" : [ "float", [ "basis.num" ] ]
|
, "exponent" : [ "float", [ "basis.prim_num" ] ]
|
||||||
, "prim_factor" : [ "float", [ "basis.num" ] ]
|
, "coefficient" : [ "float", [ "basis.prim_num" ] ]
|
||||||
|
, "prim_factor" : [ "float", [ "basis.prim_num" ] ]
|
||||||
} ,
|
} ,
|
||||||
#+end_src
|
#+end_src
|
||||||
:END:
|
:END:
|
||||||
@ -275,27 +277,28 @@ D 1
|
|||||||
|
|
||||||
#+BEGIN_EXAMPLE
|
#+BEGIN_EXAMPLE
|
||||||
type = "Gaussian"
|
type = "Gaussian"
|
||||||
num = 20
|
prim_num = 20
|
||||||
|
shell_num = 12
|
||||||
|
|
||||||
# 10 primitives per H atom
|
# 6 shells per H atom
|
||||||
nucleus_index =
|
nucleus_index =
|
||||||
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
[ 0, 0, 0, 0, 0, 0,
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1 ]
|
1, 1, 1, 1, 1, 1 ]
|
||||||
|
|
||||||
# 7 primitives for S (l=0), 2 primitives for P (l=1), 1 primitive for D (l=2) shells
|
# 3 shells in S (l=0), 2 in P (l=1), 1 in D (l=2)
|
||||||
ang_mom =
|
ang_mom =
|
||||||
[ 0, 0, 0, 0, 0, 0, 0, 1, 1, 2,
|
[ 0, 0, 0, 1, 1, 2,
|
||||||
0, 0, 0, 0, 0, 0, 0, 1, 1, 2 ]
|
0, 0, 0, 1, 1, 2 ]
|
||||||
|
|
||||||
# 5 primitives for first S shell and then 1 primitive per remaining shells
|
|
||||||
shell_index =
|
|
||||||
[ 0, 0, 0, 0, 0, 1, 2, 3, 4, 5,
|
|
||||||
0, 0, 0, 0, 0, 1, 2, 3, 4, 5 ]
|
|
||||||
|
|
||||||
# no need to renormalize shells
|
# no need to renormalize shells
|
||||||
shell_factor =
|
shell_factor =
|
||||||
[ 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,
|
[ 1., 1., 1., 1., 1., 1.,
|
||||||
1., 1., 1., 1., 1., 1., 1., 1., 1., 1. ]
|
1., 1., 1., 1., 1., 1. ]
|
||||||
|
|
||||||
|
# 5 primitives for the first S shell and then 1 primitive per remaining shells in each H atom
|
||||||
|
shell_index =
|
||||||
|
[ 0, 0, 0, 0, 0, 1, 2, 3, 4, 5,
|
||||||
|
6, 6, 6, 6, 6, 7, 8, 9, 10, 11 ]
|
||||||
|
|
||||||
# parameters of the primitives (10 per H atom)
|
# parameters of the primitives (10 per H atom)
|
||||||
exponent =
|
exponent =
|
||||||
|
Loading…
Reference in New Issue
Block a user