# MiP-CRIP: Minima Preserving Continuous Relaxation for Ising Problems

Solver for Ising model optimization problems including MAX-CUT, Number Partitioning Problem (NPP), Sherrington-Kirkpatrick (SK) models, and complete graphs.

## Quick Setup

1. **Install Conda**: Download [Miniconda](https://docs.conda.io/en/latest/miniconda.html) if needed.

2. **Create Environment**:
```bash
conda env create -f environment.yml
conda activate mip_crip
```

3. **Run Demo**:
```bash
# Using Jupyter notebook
jupyter notebook demo_run.ipynb

# Or using Python script
python quick_run.py
```

## Usage

The [demo_run.ipynb](demo_run.ipynb) notebook contains:

- **MiP-CRIP solver**: Adam-based optimizer for Ising models
- **Multiple problem types**:
  - Sherrington-Kirkpatrick (SK) Model
  - Complete Graph (Kₙ)
  - G-set graphs (MAX-CUT) - requires [G10_graph.txt](G10_graph.txt)
  - Number Partitioning Problem (NPP)

## Quick Example

```python
# Generate Ising matrix (e.g., SK model)
n = 100
J_mat = np.random.randn(n, n).astype(np.float32)
J_mat = np.sign(J_mat + J_mat.T) / 2
np.fill_diagonal(J_mat, 0)
J_sum = np.sum(J_mat)

print(f"SK model generated with {n} spins.")

# Run MiP-CRIP
x0 = np.random.randn(n)
spin_vec = MiP_CRIP(J_mat, x0, T=10, K=200,
                    alpha=0.3, beta=3.75, lambda_=0.035,
                    step=0.5, sigma_noise=1e-3)

# Compute energy
energy = -0.5 * spin_vec.T @ J_mat @ spin_vec
cut = eng2cut(energy, J_sum)
sync = np.mean(spin_vec == np.sign(J_mat @ spin_vec))
print(f"Energy: {energy:.2f}, Cut: {cut:.2f}, Sync: {sync:.3f}")
```

## Files

- [mip_crip.py](mip_crip.py) - Core solver module with MiP_CRIP implementation
- [quick_run.py](quick_run.py) - Quick run script for SK model example
- [demo_run.ipynb](demo_run.ipynb) - Main notebook with solver and examples
- [G10_graph.txt](G10_graph.txt) - G-set graph data for MAX-CUT
- [environment.yml](environment.yml) - Conda environment specification