sig
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