# SOS Transformer

A transformer-based approach for Sum of Squares (SOS) polynomial optimization problems.

## Installation

### Prerequisites

- Python >= 3.8

### Setup

Install the packages in development mode from this directory:

```bash
# Install the SOS package
cd sos
pip install -e .

# Install the transformer package
cd ../transformer
pip install -e .
```

### Required Dependencies

The following packages will be installed automatically:

- `numpy`
- `torch`
- `transformers`
- `wandb` (for experiment tracking)
- `tqdm`
- `cvxpy` (for SDP solving)

## Mosek License (Required for SDP Solving)

This project uses CVXPY for semidefinite programming (SDP), which requires a Mosek license for optimal performance.

**Academic License (Free):**
- Mosek offers free academic licenses for educational and research purposes
- Visit [https://www.mosek.com/products/academic-licenses/](https://www.mosek.com/products/academic-licenses/)
- Follow the instructions to obtain your academic license
- Install the license file as directed by Mosek

## Model Weights

**Note:** Pre-trained model weights are not included in this release due to the storage limitation of the submission. All model and training parameters as well as data set generation are detailed in the paper to enable reproducibility.

## Usage

### Running Experiments

You can execute the provided shell scripts to run experiments:

```bash
# Run our approach, Table 1, row with dense n = 6, d = 12 and m = 30
cd sos/sh-scripts
./run_cascading_oracles_sweep.sh

# Run the Newton polytope approach
./run_sdp_oracles_sweep.sh
```