"""
CoBET: Copula-Based Test with identity weights.
"""
import numpy as np
from ..core import get_identity_weights, block_diag
from .base import BaseCoBET


class CoBET(BaseCoBET):
    """
    CoBET method using identity weight matrices.
    
    This is the baseline method that uses identity weights,
    making no assumptions about the frequency content of dependencies.
    
    Parameters
    ----------
    K : int, default=4
        Dyadic depth
    d : int, default=2
        Dimension
    theta : float, default=2
        Clayton copula parameter
    alpha : float, default=0.05
        Significance level
    seed : int, default=123
        Random seed
    unbiased : bool, default=True
        Use unbiased variance estimator
        
    Examples
    --------
    >>> from cobet.methods import CoBET
    >>> import numpy as np
    >>> 
    >>> # Create test instance
    >>> test = CoBET(K=4, d=2, alpha=0.05)
    >>> 
    >>> # Generate some data
    >>> n = 100
    >>> X = np.random.randn(n, 2)
    >>> Y = np.random.randn(n, 2)
    >>> 
    >>> # Run test
    >>> result = test.test(X, Y)
    >>> print(f"P-value: {result['p_value']:.4f}")
    """
    
    def __init__(self, K=4, d=2, theta=2, alpha=0.05, seed=123, unbiased=True):
        super().__init__(K=K, d=d, theta=theta, alpha=alpha, seed=seed, unbiased=unbiased)
        self.method_name = 'CoBET'
    
    def get_weights(self, A, B):
        """
        Get identity weight matrices.
        
        Parameters
        ----------
        A, B : np.ndarray, shape (p, n)
            Feature matrices (not used, but kept for interface consistency)
            
        Returns
        -------
        W_A, W_B, W_C : np.ndarray
            Identity weight matrices
        """
        W_A, W_B, W_C, _ = get_identity_weights(self.d, self.K, self._subsets)
        return W_A, W_B, W_C
