10
1
mirror of https://gitlab.com/scemama/QCaml.git synced 2025-01-07 03:43:01 +01:00
QCaml/gaussian/lib/atomic_shell.mli

98 lines
3.1 KiB
OCaml
Raw Normal View History

2024-01-17 14:24:28 +01:00
(** Atomic Shell *)
2018-03-20 14:11:31 +01:00
2024-01-17 14:24:28 +01:00
(**
* Set of contracted Gaussians differing only by the powers of $x$, $y$
* and $z$, with a constant ~Angular_momentum.t~, all centered on the same
* point.
*
* In other words, it is the set of all contracted shells sharing the same
* center.
*
* \begin{align*}
* \chi_{n_x,n_y,n_z}(r) & = f(n_x,n_y,n_z) \sum_{j=1}^{n} \sum_{i=1}^{m} \mathcal{N}_{ij}\, d_{ij}\, g_{ij\,n_x,n_y,n_z}(r) \\
* & = (x-X_A)^{n_x} (y-Y_A)^{n_y} (z-Z_A)^{n_z} f(n_x,n_y,n_z) \sum_{j=1}^{n} \sum_{i=1}^{m} \mathcal{N}_{ij}\, d_{ij}\, \exp \left( -\alpha_{ij} |r-R_A|^2 \right)
* \end{align*}
*
* where:
*
* - $g_{ij\,n_x,n_y,n_z}(r)$ is the $i$-th ~PrimitiveShell.t~ of the
* $j$-th ~Contracted_shell.t~
* - $n_x + n_y + n_z = l$, the total angular momentum
* - $\alpha_{ij}$ are the exponents (tabulated) of the $j$-th
* ~Contracted_shell.t~
* - $d_{ij}$ are the contraction coefficients of the $j$-th
* ~Contracted_shell.t~
* - $\mathcal{N}_{ij}$ is the normalization coefficient of the $i$-th
* primitive shell
* (~PrimitiveShell.norm_coef~) of the $j$-th ~Contracted_shell.t~
* - $f(n_x,n_y,n_z)$ is a scaling factor adjusting the normalization
* coefficient for the particular powers of $x,y,z$
* (~PrimitiveShell.norm_coef_scale~)
*)
2018-03-20 15:16:24 +01:00
2018-03-20 14:11:31 +01:00
2024-01-17 14:24:28 +01:00
(** Types and modules *)
type t
2020-10-09 09:47:57 +02:00
open Common
2021-01-06 09:03:26 +01:00
2018-03-20 14:11:31 +01:00
2024-01-17 14:24:28 +01:00
(** Access *)
2018-03-20 14:11:31 +01:00
2021-01-07 09:21:06 +01:00
val ang_mom : t -> Angular_momentum.t
2024-01-17 14:24:28 +01:00
(** Total angular momentum : $l = n_x + n_y + n_z$. *)
2021-01-07 09:21:06 +01:00
val center : t -> Coordinate.t
2024-01-17 14:24:28 +01:00
(** Coordinate of the center $\mathbf{A} = (X_A,Y_A,Z_A)$. *)
2021-01-07 09:21:06 +01:00
val coefficients : t -> float array array
2024-01-17 14:24:28 +01:00
(** Array of contraction coefficients $d_{ij}$. The first index is the index
* of the contracted function, and the second index is the index of the
* primitive.
*)
2021-01-07 09:21:06 +01:00
val contracted_shells : t -> Contracted_shell.t array
2024-01-17 14:24:28 +01:00
(** Array of contracted gaussians *)
2021-01-07 09:21:06 +01:00
val exponents : t -> float array array
2024-01-17 14:24:28 +01:00
(** Array of exponents $\alpha_{ij}$. The first index is the index of the
* contracted function, and the second index is the index of the primitive.
*)
2021-01-07 09:21:06 +01:00
val index : t -> int
2024-01-17 14:24:28 +01:00
(** Index in the basis set, represented as an array of contracted shells. *)
2021-01-07 09:21:06 +01:00
val normalizations : t -> float array array
2024-01-17 14:24:28 +01:00
(** Normalization coefficients $\mathcal{N}_{ij}$. The first index is the
* index of the contracted function, and the second index is the index of
* the primitive.
*)
2021-01-07 09:21:06 +01:00
val norm_scales : t -> float array
2024-01-17 14:24:28 +01:00
(** Scaling factors $f(n_x,n_y,n_z)$, given in the same order as
* ~Angular_momentum.zkey_array ang_mom~.
*)
2021-01-07 09:21:06 +01:00
val size_of_shell : t -> int
2024-01-17 14:24:28 +01:00
(** Number of contracted functions in the shell: length of
* ~norm_coef_scale~.
*)
2021-01-07 09:21:06 +01:00
val size : t -> int
2024-01-17 14:24:28 +01:00
(** Number of contracted functions, $n$ in the definition. *)
2018-03-20 14:11:31 +01:00
2024-01-17 14:24:28 +01:00
(** Creation *)
2018-03-20 14:11:31 +01:00
2024-01-17 14:24:28 +01:00
val make : ?index:int -> Contracted_shell.t array -> t
(** Creates a contracted shell from a list of coefficients and primitives. *)
2018-03-20 14:11:31 +01:00
2021-01-06 09:03:26 +01:00
val with_index : t -> int -> t
2024-01-17 14:24:28 +01:00
(** Returns a copy of the contracted shell with a modified index. *)
2021-01-06 09:03:26 +01:00
2024-01-17 14:24:28 +01:00
(** Printers *)
2021-01-06 09:03:26 +01:00
val pp : Format.formatter -> t -> unit