2019-02-20 18:15:15 +01:00
|
|
|
(** CI Classes of MOs : active, inactive, etc *)
|
|
|
|
|
|
|
|
type mo_class =
|
|
|
|
| Core of int (* Always doubly occupied *)
|
|
|
|
| Inactive of int (* With 0,1 or 2 holes *)
|
|
|
|
| Active of int (* With 0,1 or 2 holes or particles *)
|
|
|
|
| Virtual of int (* With 0,1 or 2 particles *)
|
|
|
|
| Deleted of int (* Always unoccupied *)
|
|
|
|
|
|
|
|
type t
|
|
|
|
|
|
|
|
(** Creation *)
|
|
|
|
val of_list : mo_class list -> t
|
|
|
|
|
2019-03-18 12:41:32 +01:00
|
|
|
val to_list : t -> mo_class list
|
|
|
|
|
2019-02-20 19:43:16 +01:00
|
|
|
val fci : ?frozen_core:bool -> MOBasis.t -> t
|
|
|
|
(** Creates the MO classes for FCI calculations : all [Active]. The
|
|
|
|
[n] lowest MOs are [Core] if [frozen_core = true].
|
|
|
|
*)
|
|
|
|
|
2019-03-18 12:41:32 +01:00
|
|
|
val cas_sd: MOBasis.t -> int -> int -> t
|
|
|
|
(** [cas_sd mo_basis n m ] creates the MO classes for CAS(n,m) + SD
|
|
|
|
calculations. lowest MOs are [Core], then all the next MOs are [Inactive],
|
|
|
|
then [Active], then [Virtual].
|
|
|
|
*)
|
|
|
|
|
2019-02-20 18:15:15 +01:00
|
|
|
|
|
|
|
val core_mos : t -> int list
|
|
|
|
(** Returns a list containing the indices of the core MOs. *)
|
|
|
|
|
|
|
|
val active_mos : t -> int list
|
|
|
|
(** Returns a list containing the indices of the active MOs. *)
|
|
|
|
|
|
|
|
val virtual_mos : t -> int list
|
|
|
|
(** Returns a list containing the indices of the virtual MOs. *)
|
|
|
|
|
|
|
|
val inactive_mos : t -> int list
|
|
|
|
(** Returns a list containing the indices of the inactive MOs. *)
|
|
|
|
|
|
|
|
val deleted_mos : t -> int list
|
|
|
|
(** Returns a list containing the indices of the deleted MOs. *)
|
|
|
|
|
2019-03-18 12:41:32 +01:00
|
|
|
val mo_class_array : t -> mo_class array
|
|
|
|
(** Returns an array [a] such that [a.(i)] returns the class of MO [i].
|
|
|
|
As the MO indices start from [1], the array has an extra zero entry
|
|
|
|
that should be ignored. *)
|
2019-02-20 18:15:15 +01:00
|
|
|
|
|
|
|
(** {2 Printers} *)
|
|
|
|
|
|
|
|
val pp_mo_occ : Format.formatter -> mo_class -> unit
|
|
|
|
|