sig
val init : int -> unit
val full_init : int array -> unit
val self_init : unit -> unit
val bits : unit -> int
val int32 : Int32.t -> Int32.t
val nativeint : Nativeint.t -> Nativeint.t
val int64 : Int64.t -> Int64.t
val bool : unit -> bool
module State :
sig
type t
val make : int array -> t
val make_self_init : unit -> t
val copy : t -> t
val bits : t -> int
val int : t -> int -> int
val int32 : t -> Int32.t -> Int32.t
val nativeint : t -> Nativeint.t -> Nativeint.t
val int64 : t -> Int64.t -> Int64.t
val float : t -> float -> float
val bool : t -> bool
end
val get_state : unit -> State.t
val set_state : State.t -> unit
type state = Random.State.t
type 'a t = CCRandom.state -> 'a
type 'a random_gen = 'a CCRandom.t
val return : 'a -> 'a CCRandom.t
val flat_map : ('a -> 'b CCRandom.t) -> 'a CCRandom.t -> 'b CCRandom.t
val ( >>= ) : 'a CCRandom.t -> ('a -> 'b CCRandom.t) -> 'b CCRandom.t
val map : ('a -> 'b) -> 'a CCRandom.t -> 'b CCRandom.t
val ( >|= ) : 'a CCRandom.t -> ('a -> 'b) -> 'b CCRandom.t
val delay : (unit -> 'a CCRandom.t) -> 'a CCRandom.t
val choose : 'a CCRandom.t list -> 'a option CCRandom.t
val choose_exn : 'a CCRandom.t list -> 'a CCRandom.t
val choose_array : 'a CCRandom.t array -> 'a option CCRandom.t
val choose_return : 'a list -> 'a CCRandom.t
val replicate : int -> 'a CCRandom.t -> 'a list CCRandom.t
val sample_without_replacement :
?compare:('a -> 'a -> int) -> int -> 'a CCRandom.t -> 'a list CCRandom.t
val list_seq : 'a CCRandom.t list -> 'a list CCRandom.t
exception Pick_from_empty
val pick_list : 'a list -> 'a CCRandom.t
val pick_array : 'a array -> 'a CCRandom.t
val small_int : int CCRandom.t
val int : int -> int CCRandom.t
val int_range : int -> int -> int CCRandom.t
val small_float : float CCRandom.t
val float : float -> float CCRandom.t
val float_range : float -> float -> float CCRandom.t
val split : int -> (int * int) option CCRandom.t
val split_list : int -> len:int -> int list option CCRandom.t
val retry : ?max:int -> 'a option CCRandom.t -> 'a option CCRandom.t
val try_successively : 'a option CCRandom.t list -> 'a option CCRandom.t
val ( <?> ) :
'a option CCRandom.t -> 'a option CCRandom.t -> 'a option CCRandom.t
val fix :
?sub1:('a CCRandom.t -> 'a CCRandom.t) list ->
?sub2:('a CCRandom.t -> 'a CCRandom.t -> 'a CCRandom.t) list ->
?subn:(int CCRandom.t * ('a list CCRandom.t -> 'a CCRandom.t)) list ->
base:'a CCRandom.t -> int CCRandom.t -> 'a CCRandom.t
val pure : 'a -> 'a CCRandom.t
val ( <*> ) : ('a -> 'b) CCRandom.t -> 'a CCRandom.t -> 'b CCRandom.t
val run : ?st:CCRandom.state -> 'a CCRandom.t -> 'a
val uniformity_test :
?size_hint:int -> int -> 'a CCRandom.t -> bool CCRandom.t
end