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