from RCAEval.e2e.RCDL.rcdl import rcdl

from RCAEval.io.time_series import (
    preprocess,
    convert_mem_mb,
    drop_constant,
    drop_extra,
    drop_near_constant,
    drop_time,
    select_useful_cols,
)


def rcdl_run(data, inject_time=None, dataset=None,**kwargs):
    normal_df = data[data["time"] < inject_time]
    anomal_df = data[data["time"] >= inject_time]
    normal_df = normal_df.drop(columns=["time"])
    anomal_df = anomal_df.drop(columns=["time"])

    normal_df = preprocess(
        data=normal_df, dataset=dataset, dk_select_useful=kwargs.get("dk_select_useful", False)
    )

    anomal_df = preprocess(
        data=anomal_df, dataset=dataset, dk_select_useful=kwargs.get("dk_select_useful", False)
    )
    intersects = [x for x in normal_df.columns if x in anomal_df.columns]
    normal_df = normal_df[intersects]
    anomal_df = anomal_df[intersects]
    if "time.1" in normal_df.columns:
        normal_df = normal_df.drop(columns=["time.1"])
    if "time.1" in anomal_df.columns:
        anomal_df = anomal_df.drop(columns=["time.1"])
        
    return rcdl(normal_df, anomal_df, isDiscrete=False, isGaussian=True, alpha=0.05)

