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

Added phantom types to Vectors

This commit is contained in:
Anthony Scemama 2020-10-02 14:43:58 +02:00
parent 99a78616fd
commit 13b791e321
7 changed files with 65 additions and 64 deletions

View File

@ -1,7 +1,7 @@
type t = type 'a t =
{ {
p : Vector.t list; p : 'a Vector.t list;
e : Vector.t list; e : 'a Vector.t list;
m : int; m : int;
mmax : int; mmax : int;
} }

View File

@ -48,15 +48,15 @@ $$ %}
*) *)
type t type 'a t
val make : ?mmax:int -> unit -> t val make : ?mmax:int -> unit -> 'a t
(** Initialize DIIS with a maximum size.*) (** Initialize DIIS with a maximum size.*)
val append : p:Vector.t -> e:Vector.t -> t -> t val append : p:'a Vector.t -> e:'a Vector.t -> 'a t -> 'a t
(** Append a parameter vector [p] and the corresponding error vector [e]. *) (** Append a parameter vector [p] and the corresponding error vector [e]. *)
val next : t -> Vector.t val next : 'a t -> 'a Vector.t
(** Returns a new parameter vector. *) (** Returns a new parameter vector. *)

View File

@ -47,10 +47,10 @@ val increment_chem : t -> int -> int -> int -> int -> float -> unit
val increment_phys : t -> int -> int -> int -> int -> float -> unit val increment_phys : t -> int -> int -> int -> int -> float -> unit
(** Increments an integral using the Physicist's convention {% $\langle ij|kl \rangle$ %}. *) (** Increments an integral using the Physicist's convention {% $\langle ij|kl \rangle$ %}. *)
val get_chem_all_i : t -> j:int -> k:int -> l:int -> Vector.t val get_chem_all_i : t -> j:int -> k:int -> l:int -> 'a Vector.t
(** Get all integrals in an array [a.{i} =] {% $(\cdot j|kl)$ %} . *) (** Get all integrals in an array [a.{i} =] {% $(\cdot j|kl)$ %} . *)
val get_phys_all_i : t -> j:int -> k:int -> l:int -> Vector.t val get_phys_all_i : t -> j:int -> k:int -> l:int -> 'a Vector.t
(** Get all integrals in an array [a.{i} =] {% $\langle \cdot j|kl \rangle$ %} . *) (** Get all integrals in an array [a.{i} =] {% $\langle \cdot j|kl \rangle$ %} . *)
val get_chem_all_ij : t -> k:int -> l:int -> Matrix.t val get_chem_all_ij : t -> k:int -> l:int -> Matrix.t

View File

@ -73,16 +73,16 @@ val to_bigarray_inplace :
t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array2.t t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array2.t
(** Converts the matrix into a Bigarray in Fortran layout in place*) (** Converts the matrix into a Bigarray in Fortran layout in place*)
val to_col_vecs : t -> Vector.t array val to_col_vecs : t -> 'a Vector.t array
(** Converts the matrix into an array of vectors *) (** Converts the matrix into an array of vectors *)
val to_col_vecs_list : t -> Vector.t list val to_col_vecs_list : t -> 'a Vector.t list
(** Converts the matrix into a list of vectors *) (** Converts the matrix into a list of vectors *)
val of_col_vecs : Vector.t array -> t val of_col_vecs : 'a Vector.t array -> t
(** Converts an array of vectors into a matrix *) (** Converts an array of vectors into a matrix *)
val of_col_vecs_list : Vector.t list -> t val of_col_vecs_list : 'a Vector.t list -> t
(** Converts a list of vectors into a matrix *) (** Converts a list of vectors into a matrix *)
val of_bigarray : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array2.t -> t val of_bigarray : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array2.t -> t
@ -98,7 +98,7 @@ val copy: ?m:int -> ?n:int -> ?br:int -> ?bc:int -> ?ar:int -> ?ac:int -> t -> t
val copy_inplace: ?m:int -> ?n:int -> ?br:int -> ?bc:int -> b:t -> ?ar:int -> ?ac:int -> t -> unit val copy_inplace: ?m:int -> ?n:int -> ?br:int -> ?bc:int -> b:t -> ?ar:int -> ?ac:int -> t -> unit
(** Copies all or part of a two-dimensional matrix A to an existing matrix B *) (** Copies all or part of a two-dimensional matrix A to an existing matrix B *)
val col: t -> int -> Vector.t val col: t -> int -> 'a Vector.t
(** Returns a column of the matrix as a vector *) (** Returns a column of the matrix as a vector *)
val detri: t -> t val detri: t -> t
@ -109,10 +109,10 @@ val detri_inplace: t -> unit
(** Takes an upper-triangular matrix, and makes it a symmetric matrix (** Takes an upper-triangular matrix, and makes it a symmetric matrix
by mirroring the defined triangle along the diagonal. *) by mirroring the defined triangle along the diagonal. *)
val as_vec_inplace: t -> Vector.t val as_vec_inplace: t -> 'a Vector.t
(** Interpret the matrix as a vector (reshape). *) (** Interpret the matrix as a vector (reshape). *)
val as_vec: t -> Vector.t val as_vec: t -> 'a Vector.t
(** Return a copy of the reshaped matrix into a vector *) (** Return a copy of the reshaped matrix into a vector *)
val random: ?rnd_state:Random.State.t -> ?from:float -> ?range:float -> int -> int -> t val random: ?rnd_state:Random.State.t -> ?from:float -> ?range:float -> int -> int -> t
@ -131,19 +131,19 @@ val scale: float -> t -> t
val scale_inplace: float -> t -> unit val scale_inplace: float -> t -> unit
(** Multiplies the matrix by a constant *) (** Multiplies the matrix by a constant *)
val scale_cols: t -> Vector.t -> t val scale_cols: t -> 'a Vector.t -> t
(** Multiplies the matrix by a constant *) (** Multiplies the matrix by a constant *)
val scale_cols_inplace: t -> Vector.t -> unit val scale_cols_inplace: t -> 'a Vector.t -> unit
(** Multiplies the matrix by a constant *) (** Multiplies the matrix by a constant *)
val sycon: t -> float val sycon: t -> float
(** Returns the condition number of a matrix *) (** Returns the condition number of a matrix *)
val outer_product : ?alpha:float -> Vector.t -> Vector.t -> t val outer_product : ?alpha:float -> 'a Vector.t -> 'b Vector.t -> t
(** Computes M = %{ $\alpha u.v^t$ %} *) (** Computes M = %{ $\alpha u.v^t$ %} *)
val outer_product_inplace : t -> ?alpha:float -> Vector.t -> Vector.t -> unit val outer_product_inplace : t -> ?alpha:float -> 'a Vector.t -> 'b Vector.t -> unit
(** Computes M = %{ $\alpha u.v^t$ %} *) (** Computes M = %{ $\alpha u.v^t$ %} *)
val gemm_inplace : ?m:int -> ?n:int -> ?k:int -> ?beta:float -> c:t -> ?transa:[`N | `T] -> ?alpha:float -> val gemm_inplace : ?m:int -> ?n:int -> ?k:int -> ?beta:float -> c:t -> ?transa:[`N | `T] -> ?alpha:float ->
@ -163,7 +163,7 @@ val gemm_trace: ?transa:[`N | `T] -> t -> ?transb:[`N | `T] -> t -> float
[transa=`N] [transb=`N] [transa=`N] [transb=`N]
[gemm_trace a b]: %{ $C = Tr(A B)$ *) [gemm_trace a b]: %{ $C = Tr(A B)$ *)
val svd: t -> t * Vector.t * t val svd: t -> t * 'b Vector.t * t
(** Singular value decomposition. *) (** Singular value decomposition. *)
val qr: t -> t * t val qr: t -> t * t
@ -175,7 +175,7 @@ val normalize_mat : t -> t
val normalize_mat_inplace : t -> unit val normalize_mat_inplace : t -> unit
(** Returns the matrix with all the column vectors normalized *) (** Returns the matrix with all the column vectors normalized *)
val diagonalize_symm : t -> t * Vector.t val diagonalize_symm : t -> t * 'a Vector.t
(** Diagonalize a symmetric matrix. Returns the eigenvectors and the eigenvalues. *) (** Diagonalize a symmetric matrix. Returns the eigenvectors and the eigenvalues. *)
val xt_o_x : o:t -> x:t -> t val xt_o_x : o:t -> x:t -> t

View File

@ -1,6 +1,6 @@
open Lacaml.D open Lacaml.D
type t = Vec.t type 'a t = Vec.t
let copy ?n ?ofsy ?incy ?y ?ofsx ?incx t = copy ?n ?ofsy ?incy ?y ?ofsx ?incx t let copy ?n ?ofsy ?incy ?y ?ofsx ?incx t = copy ?n ?ofsy ?incy ?y ?ofsx ?incx t
let norm t = nrm2 t let norm t = nrm2 t

View File

@ -8,121 +8,122 @@ The indexing of vectors is 1-based.
open Lacaml.D open Lacaml.D
type t = Vec.t type 'a t = Vec.t
(* Parameter ['a] defines the basis on which the vector is expanded. *)
val dim : t -> int val dim : 'a t -> int
(** Returns the dimension of the vector *) (** Returns the dimension of the vector *)
val add : t -> t -> t val add : 'a t -> 'a t -> 'a t
(** [c = add a b] : %{ $c = a + b$ %} *) (** [c = add a b] : %{ $c = a + b$ %} *)
val sub : t -> t -> t val sub : 'a t -> 'a t -> 'a t
(** [c = sub a b] : %{ $c = a - b$ %} *) (** [c = sub a b] : %{ $c = a - b$ %} *)
val mul : t -> t -> t val mul : 'a t -> 'a t -> 'a t
(** [c = mul a b] : %{ $c_i = a_i \times b_i$ %} *) (** [c = mul a b] : %{ $c_i = a_i \times b_i$ %} *)
val div : t -> t -> t val div : 'a t -> 'a t -> 'a t
(** [c = div a b] : %{ $c_i = a_i / b_i$ %} *) (** [c = div a b] : %{ $c_i = a_i / b_i$ %} *)
val dot : t -> t -> float val dot : 'a t -> 'a t -> float
(** [dot v1 v2] : Dot product between v1 and v2 *) (** [dot v1 v2] : Dot product between v1 and v2 *)
val norm : t -> float val norm : 'a t -> float
(** Norm of the vector : %{ ||v|| = $\sqrt{v.v}$ %} *) (** Norm of the vector : %{ ||v|| = $\sqrt{v.v}$ %} *)
val sqr : t -> t val sqr : 'a t -> 'a t
(** [sqr t = map (fun x -> x *. x) t] *) (** [sqr t = map (fun x -> x *. x) t] *)
val sqrt : t -> t val sqrt : 'a t -> 'a t
(** [sqrt t = map sqrt t] *) (** [sqrt t = map sqrt t] *)
val neg : t -> t val neg : 'a t -> 'a t
(** [neg t = map (f x -> -. x) t *) (** [neg t = map (f x -> -. x) t *)
val reci : t -> t val reci : 'a t -> 'a t
(** [reci t = map (f x -> 1./x) t *) (** [reci t = map (f x -> 1./x) t *)
val abs : t -> t val abs : 'a t -> 'a t
(** [abs t = map (f x -> abs_float x) t *) (** [abs t = map (f x -> abs_float x) t *)
val cos : t -> t val cos : 'a t -> 'a t
(** [cos t = map (f x -> cos x) t *) (** [cos t = map (f x -> cos x) t *)
val sin : t -> t val sin : 'a t -> 'a t
(** [sin t = map (f x -> sin x) t *) (** [sin t = map (f x -> sin x) t *)
val tan : t -> t val tan : 'a t -> 'a t
(** [tan t = map (f x -> tan x) t *) (** [tan t = map (f x -> tan x) t *)
val acos : t -> t val acos : 'a t -> 'a t
(** [acos t = map (f x -> acos x) t *) (** [acos t = map (f x -> acos x) t *)
val asin : t -> t val asin : 'a t -> 'a t
(** [asin t = map (f x -> asin x) t *) (** [asin t = map (f x -> asin x) t *)
val atan : t -> t val atan : 'a t -> 'a t
(** [atan t = map (f x -> atan x) t *) (** [atan t = map (f x -> atan x) t *)
val normalize : t -> t val normalize : 'a t -> 'a t
(** Returns the vector normalized *) (** Returns the vector normalized *)
val init : int -> (int -> float) -> t val init : int -> (int -> float) -> 'a t
(** Initialized the vector with a function taking the index as parameter.*) (** Initialize the vector with a function taking the index as parameter.*)
val sum : t -> float val sum : 'a t -> float
(** Returns the sum of the elements of the vector *) (** Returns the sum of the elements of the vector *)
val copy : ?n:int -> ?ofsy:int -> ?incy:int -> ?y:vec -> ?ofsx:int -> ?incx:int -> t -> t val copy : ?n:int -> ?ofsy:int -> ?incy:int -> ?y:vec -> ?ofsx:int -> ?incx:int -> 'a t -> 'a t
(** Returns a copy of the vector X into Y. [ofs] controls the offset and [inc] (** Returns a copy of the vector X into Y. [ofs] controls the offset and [inc]
the increment. *) the increment. *)
val map : (float -> float) -> t -> t val map : (float -> float) -> 'a t -> 'a t
(** Equivalent to [Array.map] *) (** Equivalent to [Array.map] *)
val iter : (float -> unit) -> t -> unit val iter : (float -> unit) -> 'a t -> unit
(** Equivalent to [Array.iter] *) (** Equivalent to [Array.iter] *)
val iteri : (int -> float -> unit) -> t -> unit val iteri : (int -> float -> unit) -> 'a t -> unit
(** Equivalent to [Array.iteri] *) (** Equivalent to [Array.iteri] *)
val of_array : float array -> t val of_array : float array -> 'a t
(** Converts an array of floats into a vector *) (** Converts an array of floats into a vector *)
val of_list : float list -> t val of_list : float list -> 'a t
(** Converts a list of floats into a vector *) (** Converts a list of floats into a vector *)
val to_array : t -> float array val to_array : 'a t -> float array
(** Converts to an array of floats *) (** Converts to an array of floats *)
val to_list : t -> float list val to_list : 'a t -> float list
(** Converts to a list of floats *) (** Converts to a list of floats *)
val create : int -> t val create : int -> 'a t
(** Creates an uninitialized vector *) (** Creates an uninitialized vector *)
val make : int -> float -> t val make : int -> float -> 'a t
(** Creates a vector initialized with the given [float].*) (** Creates a vector initialized with the given [float].*)
val make0 : int -> t val make0 : int -> 'a t
(** Creates a zero-initialized vector.*) (** Creates a zero-initialized vector.*)
val fold : ('a -> float -> 'a) -> 'a -> t -> 'a val fold : ('a -> float -> 'a) -> 'a -> 'a t -> 'a
(** Equivalent to [Array.fold] *) (** Equivalent to [Array.fold] *)
val random : ?rnd_state:Random.State.t -> ?from:float -> ?range:float -> int -> t val random : ?rnd_state:Random.State.t -> ?from:float -> ?range:float -> int -> 'a t
(** Returns a vector of uniform random numbers %{ $ f \le u \le f+r $ (** Returns a vector of uniform random numbers %{ $ f \le u \le f+r $
%} where [f] is [from] and [r] is [range]. %} where [f] is [from] and [r] is [range].
Default values: [from:-1.0] [range:2.0] *) Default values: [from:-1.0] [range:2.0] *)
val of_bigarray : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t -> t val of_bigarray : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t -> 'a t
(** Builds by converting from a Fortran bigarray *) (** Builds by converting from a Fortran bigarray *)
val to_bigarray : t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t val to_bigarray : 'a t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t
(** Converts the vector into a Fortran bigarray *) (** Converts the vector into a Fortran bigarray *)
val of_bigarray_inplace : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t -> t val of_bigarray_inplace : (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t -> 'a t
(** Builds by converting from a Fortran bigarray *) (** Builds by converting from a Fortran bigarray *)
val to_bigarray_inplace : t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t val to_bigarray_inplace : 'a t -> (float, Stdlib.Bigarray.float64_elt, Stdlib.Bigarray.fortran_layout) Stdlib.Bigarray.Array1.t
(** Converts the vector into a Fortran bigarray *) (** Converts the vector into a Fortran bigarray *)