# Conformal Generation

This project implements conformal generation, a statistical method for ensuring the validity of outputs made by generative models. The main class, `ConformalGeneration`, provides methods for generating conformal sequences and calibrating parameters based on a calibration dataset.

## Installation

To install the package, you can use pip. First, clone the repository:

```bash
git clone https://github.com/author/conformal_generation.git
cd conformal_generation
```

### (Optional) Use pyenv

```bash
pyenv virtualenv 3.11.6 conformal_generation
pyenv activate conformal_generation
```

Then, install the package using pip:

```bash
pip install .
```

## Usage

After installation, you can use the `ConformalGeneration` class in your Python scripts:

```python
# import the sequence selector, calibration dataset, and conformal generation classes of your choice
from conformal_generation.sequence_selector import RunningMaxSequenceSelector
from conformal_generation.calibration_dataset import IndividualScoreCalibrationDataset
from conformal_generation.conformal_generation import ConformalGeneration

# Initialize the classes for sequence selector, calibration dataset, and conformal generation
# Please refer to the notebooks in our `example` folder for specific usage details
my_sequence_selector = RunningMaxSequenceSelector(score_fn=lambda x, y: (x - y) ** 2)
my_calibration_dataset = IndividualScoreCalibrationDataset(
    sequence_selector=my_sequence_selector,
    input_dataset=x_train,
    raw_generated_dataset=y_train,
    admissibility_dataset=a_train,
    admissibility_aggregation=lambda a_list: max(a_list) if len(a_list) > 0 else 1,
)
CG = ConformalGeneration(sequence_selector=my_sequence_selector, calibration_dataset=my_calibration_dataset)

# Generate conformal sequences
selected = CG.select(instance=x, raw_generated_sequence=y)
```

## Testing

To run the tests, navigate to the project directory and execute:

```bash
pytest tests/
```

## License

This project is licensed under the MIT License. See the LICENSE file for more details.
