### This is the base class for the adaptive CIT 
### approach needed for the PAC and SAC PCMCI 
### methods. The functions are overloaded in the 
### classes for the persistent and sparse test.  

class EndoCIT():
    def __init__(self, mixed_cit, cont_cit, context_vars, context_values=None, type='persistent'):
        self.mixed_cit = mixed_cit
        self.cont_cit = cont_cit

        self.context_vars = context_vars
        self.context_values = context_values
        self.use_mask = True

    @property
    def dataframe(self):
        return self.mixed_cit.dataframe

    def set_dataframe(self, dataframe):
        self.mixed_cit.dataframe = dataframe
        self.cont_cit.dataframe = dataframe

    def check_context_in_Z(self, Z):
        pass

    def check_context_in_X_Y(self, X, Y):
        pass


    def get_masked_data(self, X, Y, Z, tau_max=0):
        pass

    def run_context_cond_ind(self, X, Y, Z, tau_max=0, alpha_or_thresh=None):
        pass


    def run_test(self, X, Y, Z, tau_max, alpha_or_thres=0.05):
        pass

    def __getattr__(self, name):
        if name == "mixed_cit":
            raise AttributeError("mixed_cit attribute not found")
        elif name == "cont_cit":
            raise AttributeError("cont_cit attribute not found")
        return getattr(self.mixed_cit, name)



