import numpy as np
from sklearn.calibration import calibration_curve
from glest.helpers import bins_from_strategy
from sklearn.tree import DecisionTreeRegressor



def gl_true(model, f_star, X, y, n_bins=10, strategy='quantile'):
    """
    Calculate the true GL

    Args:
        model: The model to audit.
        X: The input data.
        y: The target variable.

    Returns:
        np.ndarray: The predicted probabilities.
    """
    # Placeholder for actual GL model calculation
    y_pred = model.predict_proba(X)[:,1]
    F = f_star.predict_proba(X)[:,1]
    C, _ = calibration_curve(y, y_pred, n_bins=n_bins, strategy='quantile')
    bins = bins_from_strategy(n_bins, strategy, y_pred)
    binids = np.searchsorted(bins[1:-1], y_pred)
    C = C[binids]
    return 2 * np.mean(np.square(F - C))


def sampling(X,y, proportion=0.1):
    """
    Sample a proportion of the data.

    Args:
        X: The input data.
        y: The target variable.
        proportion: The proportion of data to sample.

    Returns:
        tuple: A tuple containing the sampled input data and target variable.
    """
    n_samples = int(len(X) * proportion)
    indices = np.random.choice(len(X), n_samples, replace=False)
    return X[indices], y[indices]


def get_solver(model_type, model_params):
    """
    Get the solver for the model.

    Args:
        model_type (str): The type of model.
        model_params (dict): The parameters for the model.

    Returns:
        Any: The solver for the model.
    """
    if model_type == "decision_tree":
        return DecisionTreeRegressor(**model_params)
    else:
        raise ValueError(f"Unsupported model type: {model_type}")