# CoBET: Copula-Based Tests for Independence

A Python package implementing three copula-based independence tests:

- **CoBET**: Identity weights (baseline method)
- **dCoBET**: J-matrix weights (frequency-domain optimized)
- **wa_dCoBET**: Weighted Adaptive method (10-fold SNR selection)

## Installation

```bash
# From source
cd wa_CoBET
pip install -e .
```

## Quick Start

### Using the Unified API

```python
from cobet import run_test

# Define configuration
b_config_by_n = {
    250: {
        "trigU": [0.05, 0.08, 0.1],
        "linear": [0.1, 0.2, 0.3],
    },
    500: {
        "trigU": [0.03, 0.05, 0.10],
        "linear": [0.05, 0.10, 0.20],
    }
}

# Run CoBET simulation
results = run_test(
    method='cobet',
    n_list=[250, 500],
    K=4,
    d=5,
    theta=2,
    b_config_by_n=b_config_by_n,
    R_eval=1000,
    output='cobet_results.xlsx'
)
```

### Direct Method Usage

```python
from cobet import CoBET, dCoBET, wa_dCoBET
import numpy as np

# Generate data
n = 100
X = np.random.randn(n, 2)
Y = 0.5 * X + 0.5 * np.random.randn(n, 2)

# Method 1: CoBET (identity weights)
cobet = CoBET(K=4, d=2, alpha=0.05)
result = cobet.test(X, Y)
print(f"CoBET p-value: {result['p_value']:.4f}")

# Method 2: dCoBET (J weights)
dcobet = dCoBET(K=4, d=2, alpha=0.05)
result = dcobet.test(X, Y)
print(f"dCoBET p-value: {result['p_value']:.4f}")

# Method 3: wa_dCoBET (adaptive weights)
wa_dcobet = wa_dCoBET(K=4, d=2, alpha=0.05, n_folds=10)
result = wa_dcobet.test(X, Y)
print(f"wa_dCoBET p-value: {result['p_value']:.4f}")
print(f"Weight on identity: {result['w_identity']:.3f}")
```

## Package Structure

```
cobet/
├── core/               # Core computations
│   ├── copulas.py     # Clayton copula sampling
│   ├── transforms.py  # Transform families
│   ├── features.py    # Binary expansion features
│   ├── statistics.py  # Test statistics
│   └── weights.py     # Weight matrix construction
├── methods/           # Test methods
│   ├── base.py       # Base class
│   ├── cobet.py      # CoBET (identity weights)
│   ├── dcobet.py     # dCoBET (J weights)
│   └── wa_dcobet.py  # wa_dCoBET (adaptive)
├── simulation/        # Simulation framework
│   ├── runner.py     # Monte Carlo simulations
│   └── export.py     # Results export
├── api.py            # Unified API
└── examples/         # Example scripts
```

## Methods

### CoBET (Identity Weights)
- Baseline method using identity weight matrices
- No assumptions about frequency content
- Fast computation

### dCoBET (J Weights)
- Frequency-domain optimized weights
- Better power for certain dependency structures
- Uses numerical integration for J matrix

### wa_dCoBET (Adaptive Weights)
- 10-fold cross-validation for weight selection
- Adaptively blends identity and J weights
- SNR-based selection criterion

## Parameters

### Common Parameters
- `K`: Dyadic depth (default: 4)
- `d`: Dimension (default: 2)
- `theta`: Clayton copula parameter (default: 2)
- `alpha`: Significance level (default: 0.05)
- `seed`: Random seed (default: 123)

### Method-Specific Parameters
- `reuse_J` (dCoBET, wa_dCoBET): Cache J matrix (default: True)
- `n_folds` (wa_dCoBET): Number of folds (default: 10)

## Transform Families

Four built-in transform families:
- `trigU`: Trigonometric-uniform
- `expquad`: Exponential-quadratic
- `linear`: Linear
- `logquad`: Log-quadratic with phase modulation

## Examples

See `cobet/examples/example_usage.py` for comprehensive examples:

```bash
cd cobet/examples
python example_usage.py
```

## Dependencies

- numpy
- scipy
- pandas
- openpyxl or xlsxwriter (optional, for Excel export)

## Citation

If you use this package in your research, please cite:

```
[Your citation information here]
```

## License

[Your license information here]
