"""Exact rational verification of the central-box algebra for Proposition 4.1.

This script verifies the coefficient bounds used in the analytic central-box
proof for the q=3, d=2 zero-temperature Potts inequality

    W(Psi(x,y)) <= (W(x)+W(y))/2.

It checks the real-Fourier-coordinate polynomial K=6 R^3 G on the box
|m_1|, |m_2|, |d_1|, |d_2| <= 1/6.  All arithmetic is exact rational
arithmetic; no floating-point inequality is used.
"""
from fractions import Fraction
import sympy as sp

m1, m2, d1, d2 = sp.symbols("m1 m2 d1 d2")

R = 4 + 2 * ((m1**2 + m2**2) - (d1**2 + d2**2))

# If z=m+d and v=m-d, then the zero-temperature recursion in the complex
# Fourier coordinate is
#     T = (conj(m)^2 - conj(d)^2 - 4m) / R.
# Write T = (Nr+i Ni)/R.
Nr = m1**2 - m2**2 - d1**2 + d2**2 - 4 * m1
Ni = -2 * m1 * m2 + 2 * d1 * d2 - 4 * m2


def W_ab(a, b):
    """W in real Fourier coordinates z=a+ib: W=(2/3)|z|^2-(1/6)Re(z^3)."""
    return sp.Rational(2, 3) * (a * a + b * b) - sp.Rational(1, 6) * (a**3 - 3 * a * b * b)


W_T = (
    sp.Rational(2, 3) * (Nr**2 + Ni**2) / R**2
    - sp.Rational(1, 6) * (Nr**3 - 3 * Nr * Ni**2) / R**3
)
G = sp.Rational(1, 2) * (
    W_ab(m1 + d1, m2 + d2) + W_ab(m1 - d1, m2 - d2)
) - W_T

# Clear denominators exactly.
K_expr = sp.together(6 * R**3 * G).as_numer_denom()[0]
K = sp.Poly(sp.expand(K_expr), m1, m2, d1, d2)

K0 = 0
K2 = 0
Kge4 = 0
bad_d_degrees = []
for mon, coeff in K.terms():
    d_degree = mon[2] + mon[3]
    term = coeff * m1**mon[0] * m2**mon[1] * d1**mon[2] * d2**mon[3]
    if d_degree == 0:
        K0 += term
    elif d_degree == 2:
        K2 += term
    elif d_degree >= 4:
        Kge4 += term
    else:
        bad_d_degrees.append((mon, coeff))

assert not bad_d_degrees, bad_d_degrees

K2_poly = sp.Poly(K2, d1, d2)
A = sp.expand(K2_poly.coeff_monomial(d1**2))
B = sp.expand(K2_poly.coeff_monomial(d1 * d2))
C = sp.expand(K2_poly.coeff_monomial(d2**2))


def sp_to_fraction(q):
    q = sp.Rational(q)
    return Fraction(int(q.p), int(q.q))


def abs_coeff_box_bound(poly, variables, radius):
    """Sum |c_alpha| radius^|alpha| for a polynomial in the given variables."""
    P = sp.Poly(sp.expand(poly), *variables)
    out = Fraction(0)
    for mon, coeff in P.terms():
        out += abs(sp_to_fraction(coeff)) * radius ** sum(mon)
    return out


rad = Fraction(1, 6)

# These are the exact constants used in the proof.
A_bound = abs_coeff_box_bound(A - 256, [m1, m2], rad)
B_bound = abs_coeff_box_bound(B, [m1, m2], rad)
C_bound = abs_coeff_box_bound(C - 256, [m1, m2], rad)

assert A_bound == Fraction(2321, 36)
assert B_bound == Fraction(83665, 729)
assert C_bound == Fraction(186145, 2916)

# Every monomial in K_{>=4} has d-degree at least four.  On the box
# |m_i|,|d_i|<=1/6, bound it by const*|d|^2 using |d_i|<=1/6.
Kge4_bound = Fraction(0)
for mon, coeff in sp.Poly(sp.expand(Kge4), m1, m2, d1, d2).terms():
    m_degree = mon[0] + mon[1]
    d_degree = mon[2] + mon[3]
    Kge4_bound += abs(sp_to_fraction(coeff)) * rad**m_degree * rad ** (d_degree - 2)

assert Kge4_bound == Fraction(337601, 5832)

# K_2 lower bound after absorbing the mixed term B d1 d2 by
# |d1 d2| <= (d1^2+d2^2)/2.  We use the larger A-bound for both diagonal
# entries, so the bound is conservative and rational.
K2_lower_coeff = Fraction(256, 1) - Fraction(2321, 36) - Fraction(1, 2) * Fraction(83665, 729)
assert K2_lower_coeff == Fraction(391165, 2916)

final_d_coeff = K2_lower_coeff - Kge4_bound
assert final_d_coeff == Fraction(148243, 1944)
assert final_d_coeff > 0

# K0 lower-bound constant from the proof:
K0_r4_coeff = Fraction(288, 1) - Fraction(44, 6) - Fraction(48, 6**3) - Fraction(8, 6**5)
assert K0_r4_coeff > 0

print("central polynomial terms:", len(K.terms()))
print("d-degree decomposition: K0 + K2 + K>=4 verified")
print("A-256 bound:", A_bound)
print("B bound:", B_bound)
print("C-256 bound:", C_bound)
print("K>=4 bound:", Kge4_bound)
print("K2 lower coefficient:", K2_lower_coeff)
print("final |d|^2 coefficient:", final_d_coeff)
print("K0 r^4 coefficient lower bound:", K0_r4_coeff)
print("certificate status: PASS")
