"""
Copula sampling functions for CoBET methods.
"""
import numpy as np


def clayton_copula_sample_nd(n, theta, d, rng=None):
    """
    Sample from d-dimensional Clayton copula.
    
    Parameters
    ----------
    n : int
        Number of samples
    theta : float
        Clayton copula parameter. theta=0 gives independence.
    d : int
        Dimension
    rng : np.random.RandomState, optional
        Random number generator for reproducibility
        
    Returns
    -------
    U : np.ndarray, shape (n, d)
        Samples from Clayton copula with uniform(0,1) marginals
        
    Notes
    -----
    Uses the Gamma-Exponential construction:
    - S ~ Gamma(1/theta, 1)
    - E_i ~ Exp(1) independent
    - U_i = (1 + E_i / S)^(-1/theta)
    """
    if rng is None:
        rng = np.random.RandomState()
    
    if theta == 0:
        return rng.uniform(0, 1, size=(n, d))
    
    # Gamma-Exponential construction
    S = rng.gamma(shape=1.0 / theta, scale=1.0, size=n)  # (n,)
    E = rng.exponential(scale=1.0, size=(n, d))
    U = (1.0 + E / S[:, None]) ** (-1.0 / theta)
    
    return U
