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

81 lines
1.6 KiB
OCaml
Raw Normal View History

2020-09-26 12:02:53 +02:00
open Lacaml.D
2024-07-30 12:55:42 +02:00
2020-10-02 14:43:58 +02:00
type 'a t = Vec.t
2020-09-26 12:02:53 +02:00
2020-10-02 18:55:19 +02:00
let relabel t = t
2024-07-30 12:55:42 +02:00
let copy ?n ?ofsy ?incy ?y ?ofsx ?incx t = copy ?n ?ofsy ?incy ?y ?ofsx ?incx t
let norm ?(l=`L2) t =
match l with
| `L2 -> nrm2 t
| `L1 -> asum t
| `Linf -> amax t
2020-09-26 12:02:53 +02:00
let dim t = Vec.dim t
let neg t = Vec.neg t
let sum t = Vec.sum t
let abs t = Vec.abs t
let sin t = Vec.sin t
let cos t = Vec.cos t
let tan t = Vec.tan t
let asin t = Vec.asin t
let acos t = Vec.acos t
let atan t = Vec.atan t
let reci t = Vec.reci t
let sqr t = Vec.sqr t
let sqrt t = Vec.sqrt t
let init f t = Vec.init f t
let iter f t = Vec.iter f t
let map f t = Vec.map f t
let iteri f t = Vec.iteri f t
let fold f a t = Vec.fold f a t
let add t1 t2 = Vec.add t1 t2
2020-10-02 15:49:09 +02:00
let sub t1 t2 = Vec.sub t1 t2
2020-09-26 12:02:53 +02:00
let mul t1 t2 = Vec.mul t1 t2
2020-10-02 15:49:09 +02:00
let div t1 t2 = Vec.div t1 t2
2020-09-26 12:02:53 +02:00
let dot t1 t2 = dot t1 t2
2020-10-18 01:58:22 +02:00
let amax t = amax t
2020-09-26 12:02:53 +02:00
let create n = Vec.create n
let make0 n = Vec.make0 n
let of_array a = Vec.of_array a
let of_list l = Vec.of_list l
let to_array t = Vec.to_array t
let to_list t = Vec.to_list t
let make n x = Vec.make n x
2020-10-03 15:40:06 +02:00
(*
2020-09-26 12:02:53 +02:00
let of_bigarray t = copy t
let to_bigarray t = copy t
2020-10-03 15:40:06 +02:00
*)
let of_bigarray_inplace t = t
2020-09-26 12:02:53 +02:00
let to_bigarray_inplace t = t
2024-07-30 12:55:42 +02:00
let random ?rnd_state ?(from= -. 1.0) ?(range=2.0) n =
2020-09-26 12:02:53 +02:00
let state =
match rnd_state with
| None -> Random.get_state ()
| Some state -> state
in
Vec.random ~rnd_state:state ~from ~range n
let normalize v =
let result = copy v in
scal (1. /. (nrm2 v)) result;
result
2020-10-02 15:49:09 +02:00
let (%.) t i = t.{i}
2024-07-30 12:55:42 +02:00
let set t i v = t.{i} <- v
2024-09-06 15:55:04 +02:00
let pp ppf m =
let m = to_bigarray_inplace m in
Lacaml.Io.pp_fvec ppf m