# Implements:
#   F(delta) = max_x  min_{rho >= rho_q(delta,x)}  max_y f(x,y,rho)
# and returns the minimum of F(delta) over delta >= 0 on a fixed uniform delta-grid.
#
# Tuned to be reasonably dense while fitting within runtime.

import numpy as np

# ----- Problem definitions -----

def theta(delta: float) -> float:
    return 0.5 * (np.sqrt((delta + 1.0) * (delta + 9.0)) - (delta + 3.0))

def rho_q_lower(delta: float, x: float) -> float:
    th = theta(delta)
    if x <= th:
        return 0.0
    num = 2.0 * np.sqrt(x) - np.sqrt((1.0 - x) * (delta + x))
    den = 1.0 + x
    return max((num / den) ** 2, 0.0)

def f_grid(x: float, ys: np.ndarray, rhos: np.ndarray) -> np.ndarray:
    """Matrix f(x, y_i, rho_j) for all y_i, rho_j. Shape (Ny, Nr)."""
    eps = 1e-9
    x = float(np.clip(x, eps, 1.0 - eps))
    Y = np.clip(ys, eps, 1.0 - eps)[:, None]      # (Ny,1)
    R = np.clip(rhos, 0.0, None)[None, :]         # (1,Nr)
    term = ((Y - x)/np.sqrt(x) - (Y - 1.0)*np.sqrt(R))**2
    return (Y - x) + (1.0 - x) * (R - (x/(Y*(1.0 - x)**2)) * term)

def inner_for_x(delta: float, x: float, ys: np.ndarray, rho_max: float, rho_points: int) -> float:
    """min_{rho >= rho_q(delta,x)} max_{y} f(x,y,rho) on given y-grid and rho-grid."""
    rho_lb = rho_q_lower(delta, x)
    rhos = np.linspace(rho_lb, rho_max, rho_points)
    vals = f_grid(x, ys, rhos)          # (Ny, Nr)
    max_over_y = vals.max(axis=0)       # (Nr,)
    return float(max_over_y.min())

def F_of_delta(delta: float, xs: np.ndarray, ys: np.ndarray, rho_max: float, rho_points: int) -> float:
    """max_x [ min_{rho >= rho_lb} max_y f(x,y,rho) ] on given x,y grids and rho discretization."""
    best = -1e18
    for x in xs:
        cand = inner_for_x(delta, float(x), ys, rho_max, rho_points)
        if cand > best:
            best = cand
    return float(best)

# ----- Grids (single-pass) -----
# delta grid
deltas = np.linspace(0.0, 10.0, 400)  
# x, y grids
xs = np.linspace(1e-9, 1.0 - 1e-9, 400)
ys = np.linspace(1e-9, 1.0 - 1e-9, 400)
# rho grid upper bound and resolution
rho_max = 10.0
rho_points = 500

# ----- Evaluate F(delta) for all delta -----
F_vals = np.empty_like(deltas)
for i, d in enumerate(deltas):
    F_vals[i] = F_of_delta(float(d), xs, ys, rho_max, rho_points)

# ----- Extract results -----
idx = int(np.argmin(F_vals))
delta_star = float(deltas[idx])
F_star = float(F_vals[idx])

# Also compute F(0) on the same grids
F_at_zero = float(F_of_delta(0.0, xs, ys, rho_max, rho_points))

print("=== Single-pass dense grid (no refinement) ===")
print(f"Minimum value over delta-grid: {F_star:.12f}")
print(f"Achieved at delta: {delta_star:.6f}")
print(f"F(0): {F_at_zero:.12f}")
