#%%
import numpy as np

#%%

def generate_y(f_star, X, method="predict_proba"):
    """
    Generate y from f_star and X.

    Args:
        f_star (Any): The model to use for generating y.
        X (np.ndarray): The input data.

    Returns:
        np.ndarray: The generated y.
    """
    # Placeholder for actual generation logic
    if method == "predict_proba":
        y = f_star.predict_proba(X)
        y = np.random.binomial(1, y[:, 1])
    elif method == "predict":
        y = f_star.predict(X)
    elif method == "full_random":
        y = np.random.randint(0, 2, size=X.shape[0])
    else:
        raise ValueError(f"Unsupported method: {method}")
    return y

def generate_X(f_star):
    """
    Generate X from f_star.

    Args:
        f_star (Any): The model to use for generating X.

    Returns:
        np.ndarray: The generated X.
    """
    # Placeholder for actual generation logic
    X = f_star.sample(1000)  # Assuming f_star has a sample method
    return X


