import math, random

def q064_to_uniform(x: int) -> float:
    # x in {0,...,2^64-1} → U=(x+0.5)/2^64 ∈ (0,1)
    return (x + 0.5) / 2**64

def draw_q064() -> int:
    # 64-bit unsigned
    return random.getrandbits(64)

def exp_from_uniform(u: float, rate: float) -> float:
    # E = -log(1-U) / rate, avoids endpoint
    return -math.log(1.0 - u) / rate

def exp_draw(rate: float) -> float:
    return exp_from_uniform(q064_to_uniform(draw_q064()), rate)
