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
|
|
|
|
2020-10-17 19:02:37 +02:00
|
|
|
let (%.) t i = t.{i}
|
2024-07-30 12:55:42 +02:00
|
|
|
|
2020-10-17 19:02:37 +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
|
|
|
|
|