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