
import numpy as np
from typing import Tuple


def compute_index_domain(
    theta_0: np.ndarray,
    p_min: float,
    p_max: float,
    context_min: float,
    context_max: float,
    buffer_ratio: float = 0.15
) -> Tuple[float, float]:

    d_minus_1 = len(theta_0)
    

    c_theta_min = 0.0
    c_theta_max = np.sum(theta_0) * context_max
    

    s_min = p_min - c_theta_max
    s_max = p_max - c_theta_min
    
    if s_min > s_max:
        s_min, s_max = s_max, s_min
    
    width = s_max - s_min
    margin = width * buffer_ratio
    
    index_min = s_min - margin
    index_max = s_max + margin
    
    
    return index_min, index_max


def get_adaptive_params(T: int) -> dict:

    pilot_error = 1.0 / np.sqrt(T)
    
    eta = 1.0 / np.sqrt(T)
    
    if T <= 50:
        h = 0.15     
        n0 = max(15, T // 5)
    elif T <= 100:
        h = 0.10     
        n0 = max(20, T // 5)
    elif T <= 200:
        h = 0.08      
        n0 = max(25, T // 8)
    elif T <= 500:
        h = 0.05     
        n0 = max(30, T // 10)
    elif T <= 1000:
        h = 0.04      
        n0 = max(40, T // 15)
    else:
        h = 0.03      
        n0 = max(50, T // 20)
    
    params = {
        'pilot_error': pilot_error,
        'eta': eta,
        'h': h,
        'n0': n0,
        'K': 3,
        'kappa': 0.6,
        'zeta': 1.0,
        'Gamma1': 0.1,
        'Gamma2': 0.1,
        'Gamma3': 0.1
    }
    

    
    return params

