10
1
mirror of https://gitlab.com/scemama/QCaml.git synced 2025-01-05 10:58:47 +01:00
QCaml/Utils/FourIdxStorage.mli

47 lines
1.3 KiB
OCaml
Raw Normal View History

2018-03-27 19:32:37 +02:00
(** Storage for four-index data (integrals, density matrices, ...).
There are two kinds of ordering of indices:
2018-03-28 01:50:19 +02:00
- Physicist's : {% $\langle i j | k l \rangle$ %}
- Chemist's : {% $(ij|kl)$ %}
2018-03-27 19:32:37 +02:00
*)
type t
2018-06-28 14:43:24 +02:00
type element = (** Element for the stream *)
{
i_r1: int ;
j_r2: int ;
k_r1: int ;
l_r2: int ;
value: float
}
2018-03-27 19:32:37 +02:00
val create : size:int -> [< `Dense | `Sparse ] -> t
(** If [`Dense] is chosen, internally the data is stored as a 4-dimensional
[Bigarray]. Else, it is stored as a hash table.
*)
(** {2 Accessors} *)
val get_chem : t -> int -> int -> int -> int -> float
2018-06-29 16:04:40 +02:00
(** Get an integral using the Chemist's convention {% $(ij|kl)$ %}. *)
2018-03-27 19:32:37 +02:00
val get_phys : t -> int -> int -> int -> int -> float
2018-06-29 16:04:40 +02:00
(** Get an integral using the Physicist's convention {% $\langle ij|kl \rangle$ %}. *)
2018-03-27 19:32:37 +02:00
val set_chem : t -> int -> int -> int -> int -> float -> unit
2018-06-29 16:04:40 +02:00
(** Set an integral using the Chemist's convention {% $(ij|kl)$ %}. *)
2018-03-27 19:32:37 +02:00
val set_phys : t -> int -> int -> int -> int -> float -> unit
2018-06-29 16:04:40 +02:00
(** Set an integral using the Physicist's convention {% $\langle ij|kl \rangle$ %}. *)
2018-03-27 19:32:37 +02:00
2018-06-28 14:43:24 +02:00
val to_stream : t -> element Stream.t
2018-06-29 16:04:40 +02:00
(** Fetch all integrals from a stream. *)
2018-06-28 14:43:24 +02:00
2018-03-27 19:32:37 +02:00
(** {2 I/O} *)
2018-06-29 16:04:40 +02:00
2018-03-27 19:32:37 +02:00
val to_file : ?cutoff:float -> filename:string -> t -> unit
(** Write the data to file, using the physicist's ordering. *)