"""
dCoBET: Copula-Based Test with J weights.
"""
import numpy as np
from ..core import get_J_weights
from .base import BaseCoBET


class dCoBET(BaseCoBET):
    """
    dCoBET method using J-matrix weights.
    
    This method uses frequency-domain optimized weights (J matrix)
    that can improve power for certain dependency structures.
    
    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
    reuse_J : bool, default=True
        Cache and reuse J matrix computation
        
    Examples
    --------
    >>> from cobet.methods import dCoBET
    >>> import numpy as np
    >>> 
    >>> # Create test instance
    >>> test = dCoBET(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, reuse_J=True):
        super().__init__(K=K, d=d, theta=theta, alpha=alpha, seed=seed, unbiased=unbiased)
        self.method_name = 'dCoBET'
        self.reuse_J = reuse_J
        
        # Pre-compute and cache J matrix if requested
        if reuse_J:
            _, _, _, _, self._J_cached = get_J_weights(
                self.d, self.K, J_cached=None, subsets=self._subsets, reuse_J=True
            )
    
    def get_weights(self, A, B):
        """
        Get J-based 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
            J-based weight matrices
        """
        W_A, W_B, W_C, _, _ = get_J_weights(
            self.d, self.K, 
            J_cached=self._J_cached if self.reuse_J else None,
            subsets=self._subsets,
            reuse_J=self.reuse_J
        )
        return W_A, W_B, W_C
