package gsl

  1. Overview
  2. Docs

Source file vector_flat.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
(* gsl-ocaml - OCaml interface to GSL                       *)
(* Copyright (©) 2002-2012 - Olivier Andrieu                *)
(* Distributed under the terms of the GPL version 3         *)

let () = Error.init ()

type double_vector_flat = {
  data : float array;
  off : int;
  len : int;
  stride : int;
}

type vector = double_vector_flat

let check v =
  let size = Array.length v.data in
  if
    v.off < 0 || v.len < 0 || v.stride < 1
    || v.off + ((v.len - 1) * v.stride) >= size
  then failwith "Vector_flat.check";
  v

let create ?(init = 0.) len =
  { data = Array.make len init; off = 0; len; stride = 1 }

let of_array arr =
  { data = Array.copy arr; off = 0; len = Array.length arr; stride = 1 }

let length { len } = len
let get v i = v.data.(v.off + (i * v.stride))
let set v i d = v.data.(v.off + (i * v.stride)) <- d

let set_all v d =
  for i = 0 to pred v.len do
    set v i d
  done

let set_zero v = set_all v 0.

let set_basis v i =
  set_zero v;
  set v i 1.

let to_array v = Array.init v.len (get v)

let subvector ?(stride = 1) v ~off ~len =
  check
    { v with off = (off * v.stride) + v.off; len; stride = stride * v.stride }

let view_array ?(stride = 1) ?(off = 0) ?len arr =
  let len = match len with None -> Array.length arr | Some l -> l in
  check { data = arr; off; stride; len }

let memcpy ~src:v ~dst:w =
  if v.len <> w.len then invalid_arg "Vector.memcpy";
  for i = 0 to pred v.len do
    set w i (get v i)
  done

let copy v = { v with data = Array.copy v.data }

let swap_element v i j =
  let d = get v i in
  let d' = get v j in
  set v j d;
  set v i d'

let reverse v =
  for i = 0 to pred (v.len / 2) do
    swap_element v i (pred v.len - i)
  done

external add : vector -> vector -> unit = "ml_gsl_vector_add"
external sub : vector -> vector -> unit = "ml_gsl_vector_sub"
external mul : vector -> vector -> unit = "ml_gsl_vector_mul"
external div : vector -> vector -> unit = "ml_gsl_vector_div"
external scale : vector -> float -> unit = "ml_gsl_vector_scale"
external add_constant : vector -> float -> unit = "ml_gsl_vector_add_constant"
external is_null : vector -> bool = "ml_gsl_vector_isnull"
external max : vector -> float = "ml_gsl_vector_max"
external min : vector -> float = "ml_gsl_vector_min"
external minmax : vector -> float * float = "ml_gsl_vector_minmax"
external max_index : vector -> int = "ml_gsl_vector_maxindex"
external min_index : vector -> int = "ml_gsl_vector_minindex"
external minmax_index : vector -> int * int = "ml_gsl_vector_minmaxindex"
OCaml

Innovation. Community. Security.