# seq-kci: Sequential Kernel Conditional Independence

This repository contains code for sequential kernel-based conditional independence testing and related experiments. The project is organized for reproducibility and extensibility, supporting multiple datasets, models, and training configurations.

## Project Structure

```
code/
    train.py                # Main training script
    train_davt.py           # Training script for DAVT method
    train_ecrt.py           # Training script for ECRT method
    configs/                # Configuration files
        config.yaml         # Default config
        data/               # Dataset configs
        experiment/         # Experiment configs
        kernel/             # Kernel configs
    data/                   # Data generation and loading
    models/                 # Model definitions
    trainer/                # Training logic
    utils/                  # Utility functions
```

## Getting Started

### Requirements
- Python 3.8+
- wandb
- hydra
- torch
- numpy


## Usage

### Training
Run the main training script with a specific experiment configuration:
```bash
python train.py experiment=hardness_1d_skci wandb.disabled=true
```
- Replace `experiment=hardness_1d_skci` with your desired experiment (see `configs/experiment/` for available options).
- Set `wandb.disabled=true` to disable Weights & Biases logging if not needed.

### Custom Training Scripts
- `train_davt.py`: For DAVT method experiments
- `train_ecrt.py`: For ECRT method experiments

Example:
```bash
python train_davt.py experiment=gaussian_davt
```

## Configuration
- All experiment, data, and kernel configurations are in the `configs/` directory.
- Modify or add YAML files to customize experiments.

## Data
- Data generation and loading scripts are in `data/`.
- Supported datasets: carinsurance, gaussiancit, ratinabox, sincorrelation, etc.

## Models
- Model architectures and kernels are defined in `models/` and `configs/kernel/`.

## Trainers
- Training logic for different methods is in `trainer/`.

## Utilities
- Helper functions for data processing, training, and evaluation are in `utils/`.
