import numpy as np
from sklearn.preprocessing import KBinsDiscretizer
from resreg import resampler
from config import CONFIG


def apply_smoter(X, y, relevance, relevance_threshold=0.5, k=5, over='balance'):
    """
    Applies SMOTER to oversample rare domain in the regression data.
    
    Args:
        X (array): Feature matrix.
        y (array): Target vector.
        relevance (array): Relevance values for targets.
        relevance_threshold (float): Threshold for identifying rare domain.
        k (int): Number of nearest neighbors for interpolation.
        over (str or float): Degree of oversampling ('balance', 'average', 'extreme' or percentage as float).
    
    Returns:
        Resampled (X, y).
    """
    X_resampled, y_resampled = resampler.smoter(X, y, relevance,
                                             relevance_threshold=relevance_threshold,
                                             k=k, over=over, random_state=CONFIG["random_state"])
    return X_resampled, y_resampled


def apply_gaussian_noise(X, y, relevance, relevance_threshold=0.5, delta=0.1, over='balance'):
    """
    Applies Gaussian noise strategy to oversample rare domain in the regression data.
    
    Args:
        X (array): Feature matrix.
        y (array): Target vector.
        relevance (array): Relevance values for targets.
        relevance_threshold (float): Threshold for identifying rare domain.
        delta (float): Amount of Gaussian noise to inject.
        over (str or float): Degree of oversampling ('balance', 'average', 'extreme' or percentage as float).
    
    Returns:
        Resampled (X, y).
    """
    X_resampled, y_resampled = resampler.gaussian_noise(X, y, relevance,
                                                     relevance_threshold=relevance_threshold,
                                                     delta=delta, over=over, random_state=CONFIG["random_state"])
    return X_resampled, y_resampled
