sig   val init : int -> (int -> 'a) -> 'a list   val make : int -> '-> 'a list   val first : 'a list -> 'a   val last : 'a list -> 'a   val iteri : (int -> '-> unit) -> 'a list -> unit   val mapi : (int -> '-> 'b) -> 'a list -> 'b list   val rfind : ('-> bool) -> 'a list -> 'a   val find_exc : ('-> bool) -> exn -> 'a list -> 'a   val findi : (int -> '-> bool) -> 'a list -> int * 'a   val unique : ?cmp:('-> '-> bool) -> 'a list -> 'a list   val filter_map : ('-> 'b option) -> 'a list -> 'b list   val find_map : ('-> 'b option) -> 'a list -> 'b   val split_nth : int -> 'a list -> 'a list * 'a list   val remove : 'a list -> '-> 'a list   val remove_if : ('-> bool) -> 'a list -> 'a list   val remove_all : 'a list -> '-> 'a list   val take : int -> 'a list -> 'a list   val drop : int -> 'a list -> 'a list   val takewhile : ('-> bool) -> 'a list -> 'a list   val dropwhile : ('-> bool) -> 'a list -> 'a list   val enum : 'a list -> 'Enum.t   val of_enum : 'Enum.t -> 'a list   val hd : 'a list -> 'a   val tl : 'a list -> 'a list   val nth : 'a list -> int -> 'a   val sort : ?cmp:('-> '-> int) -> 'a list -> 'a list   val map2 : ('-> '-> 'c) -> 'a list -> 'b list -> 'c list   val iter2 : ('-> '-> unit) -> 'a list -> 'b list -> unit   val fold_left2 : ('-> '-> '-> 'a) -> '-> 'b list -> 'c list -> 'a   val fold_right2 : ('-> '-> '-> 'c) -> 'a list -> 'b list -> '-> 'c   val for_all2 : ('-> '-> bool) -> 'a list -> 'b list -> bool   val exists2 : ('-> '-> bool) -> 'a list -> 'b list -> bool   val combine : 'a list -> 'b list -> ('a * 'b) list   val map : ('-> 'b) -> 'a list -> 'b list   val append : 'a list -> 'a list -> 'a list   val flatten : 'a list list -> 'a list   val concat : 'a list list -> 'a list   val fold_right : ('-> '-> 'b) -> 'a list -> '-> 'b   val remove_assoc : '-> ('a * 'b) list -> ('a * 'b) list   val remove_assq : '-> ('a * 'b) list -> ('a * 'b) list   val split : ('a * 'b) list -> 'a list * 'b list   val filter : ('-> bool) -> 'a list -> 'a list   val find_all : ('-> bool) -> 'a list -> 'a list   val partition : ('-> bool) -> 'a list -> 'a list * 'a list   val length : 'a list -> int   val rev_append : 'a list -> 'a list -> 'a list   val rev : 'a list -> 'a list   val rev_map : ('-> 'b) -> 'a list -> 'b list   val iter : ('-> unit) -> 'a list -> unit   val fold_left : ('-> '-> 'b) -> '-> 'a list -> 'b   val for_all : ('-> bool) -> 'a list -> bool   val exists : ('-> bool) -> 'a list -> bool   val find : ('-> bool) -> 'a list -> 'a   val mem : '-> 'a list -> bool   val memq : '-> 'a list -> bool   val assoc : '-> ('a * 'b) list -> 'b   val assq : '-> ('a * 'b) list -> 'b   val mem_assoc : '-> ('a * 'b) list -> bool   val mem_assq : '-> ('a * 'b) list -> bool   val stable_sort : ('-> '-> int) -> 'a list -> 'a list   val fast_sort : ('-> '-> int) -> 'a list -> 'a list   val merge : ('-> '-> int) -> 'a list -> 'a list -> 'a list   exception Empty_list   exception Invalid_index of int   exception Different_list_size of string end