from sklearn.cross_decomposition import PLSRegression

class PLSDA(PLSRegression):
    def __init__(self, n_components=2, **kwargs):
        super().__init__(n_components=n_components, **kwargs)
    
    def fit(self, X, y):
        super().fit(X, y)

    def transform(self, X, y=None):
        return super().transform(X)
    
    def fit_transform(self, X, y):
        self.fit(X, y)
        return self.transform(X)
