# Opal: Canonicalization Demo (Supplementary Material)

This folder contains Python prototype (~150 lines) implementing the 
canonicalizer and tester described in the paper *"Opal: An Operator-Algebra View 
of RLHF Objectives"* (submitted to ICLR 2026).

## Contents

- `rlhf_canonicalizer_demo.py`  
  Main script implementing the ladder representation (Add/Rew/Link), 
  the canonicalizer, and the witness-based tester.  
- `rlhf_condensed_table.tex` / `rlhf_condensed_table.csv`  
  Example condensed results table generated by running the demo.  

## Requirements

- Python 3.9+  
- pandas (for pretty-printing tables)

You can install dependencies via:

```bash
pip install pandas
```

## Running the demo

From the command line:

```bash
python rlhf_canonicalizer_demo.py
```

Expected output:
- A table summarizing reducible vs. irreducible RLHF objectives.  
- A grouping of methods that collapse to the same canonical hash.  
- Optionally, CSV/LaTeX files for integration with the paper.  

## Notes

- This is a prototype for demonstration and reproducibility.  
- The code is anonymized for review (no author or institution identifiers).  
- A cleaned and documented release will be provided upon acceptance.  

## Citation

If referring to this material, please cite the corresponding ICLR 2026 submission.

