sig   type state = Random.State.t   type 'a t = CCRandom.state -> 'a   type 'a random_gen = 'CCRandom.t   val return : '-> 'CCRandom.t   val flat_map : ('-> 'CCRandom.t) -> 'CCRandom.t -> 'CCRandom.t   val ( >>= ) : 'CCRandom.t -> ('-> 'CCRandom.t) -> 'CCRandom.t   val map : ('-> 'b) -> 'CCRandom.t -> 'CCRandom.t   val ( >|= ) : 'CCRandom.t -> ('-> 'b) -> 'CCRandom.t   val delay : (unit -> 'CCRandom.t) -> 'CCRandom.t   val choose : 'CCRandom.t list -> 'a option CCRandom.t   val choose_exn : 'CCRandom.t list -> 'CCRandom.t   val choose_array : 'CCRandom.t array -> 'a option CCRandom.t   val choose_return : 'a list -> 'CCRandom.t   val replicate : int -> 'CCRandom.t -> 'a list CCRandom.t   val sample_without_replacement :     ?compare:('-> '-> int) -> int -> 'CCRandom.t -> 'a list CCRandom.t   val list_seq : 'CCRandom.t list -> 'a list CCRandom.t   exception Pick_from_empty   val pick_list : 'a list -> 'CCRandom.t   val pick_array : 'a array -> '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:('CCRandom.t -> 'CCRandom.t) list ->     ?sub2:('CCRandom.t -> 'CCRandom.t -> 'CCRandom.t) list ->     ?subn:(int CCRandom.t * ('a list CCRandom.t -> 'CCRandom.t)) list ->     base:'CCRandom.t -> int CCRandom.t -> 'CCRandom.t   val pure : '-> 'CCRandom.t   val ( <*> ) : ('-> 'b) CCRandom.t -> 'CCRandom.t -> 'CCRandom.t   val run : ?st:CCRandom.state -> 'CCRandom.t -> 'a   val uniformity_test :     ?size_hint:int -> int -> 'CCRandom.t -> bool CCRandom.t end