10
1
mirror of https://gitlab.com/scemama/QCaml.git synced 2024-12-31 16:45:41 +01:00
QCaml/Utils/Coordinate.mli

109 lines
1.7 KiB
OCaml
Raw Normal View History

2018-02-26 10:43:21 +01:00
(** Type for coordinates in 3D space.
All operations on points are done in atomic units. Therefore,
all coordinates are given in bohr and manipulated with this
2018-02-26 10:43:21 +01:00
module.
*)
type bohr
type angstrom
type xyz = {
x : float ;
y : float ;
z : float ;
}
type 'a point = xyz
type t = bohr point
val make : 'a point -> t
(** Creates a point in atomic units *)
val make_angstrom : 'a point -> angstrom point
(** Creates a point in Angstrom *)
2018-02-13 17:36:25 +01:00
type axis = X | Y | Z
val bohr_to_angstrom : bohr point -> angstrom point
(** Converts a point in bohr to angstrom. *)
2018-02-26 10:43:21 +01:00
val angstrom_to_bohr : angstrom point -> bohr point
(** Converts a point in Angstrom to bohr. *)
2018-02-26 10:43:21 +01:00
val zero : bohr point
(** [zero = { x = 0. ; y=0. ; z=0. }] *)
2018-02-26 10:43:21 +01:00
val get : axis -> bohr point -> float
2018-02-26 10:43:21 +01:00
(** Extracts the projection of the coordinate on an axis.
Example:
[Coordinate.(get Y) { x=1. ; y=2. ; z=3. } -> 2.]
2018-02-26 10:43:21 +01:00
*)
(** {1 Vector operations} *)
val ( |. ) : float -> t -> t
2018-02-26 10:43:21 +01:00
(** Scale by a float.
Example:
[ 2. |. { x=1. ; y=2. ; z=3. } -> { x=2. ; y=4. ; z=6. } ]
2018-02-26 10:43:21 +01:00
*)
val ( |+ ) : t -> t -> t
2018-02-26 10:43:21 +01:00
(** Add two vectors.
Example:
{[{ x=1. ; y=2. ; z=3. } |+ { x=2. ; y=3. ; z=1. } ->
{ x=3. ; y=5. ; z=4. }]}
2018-02-26 10:43:21 +01:00
*)
val ( |- ) : t -> t -> t
2018-02-26 10:43:21 +01:00
(** Subtract two vectors.
Example:
{[{ x=1. ; y=2. ; z=3. } |- { x=2. ; y=3. ; z=1. } ->
{ x=-1. ; y=-1. ; z=2. }]}
2018-02-26 10:43:21 +01:00
*)
val neg : t -> t
2018-02-26 10:43:21 +01:00
(** Example:
{[Coordinate.neg { x=1. ; y=2. ; z=-3. } ->
{ x=-1. ; y=-2. ; z=3. }]}
2018-02-26 10:43:21 +01:00
*)
val dot : t -> t -> float
2018-02-26 10:43:21 +01:00
(** Dot product. *)
2018-02-13 17:36:25 +01:00
val norm : t -> float
2018-02-26 10:43:21 +01:00
(** L{^2} norm of the vector. *)
2018-01-17 18:19:38 +01:00
2018-03-15 15:25:49 +01:00
(** {2 Printers} *)
val pp: Format.formatter -> t -> unit
2018-03-16 00:23:47 +01:00
val pp_bohr: Format.formatter -> t -> unit
2018-03-15 15:25:49 +01:00
val pp_angstrom : Format.formatter -> t -> unit
2018-03-15 15:25:49 +01:00