#!/usr/bin/env python3
"""
Quick run example for MiP-CRIP solver
Based on the README example
"""

import numpy as np
from mip_crip import MiP_CRIP, eng2cut


def main():
    # Generate Ising matrix (SK model)
    n = 1000
    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).astype(np.float32)
    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"\nResults(without Tuning):")
    print(f"Energy: {energy:.2f}")
    print(f"Cut: {cut:.2f}")
    print(f"Sync: {sync:.3f}")


if __name__ == "__main__":
    main()
