2022-04-27 12:33:27 +03:00
|
|
|
import pytest
|
|
|
|
|
|
2022-05-12 15:44:29 +03:00
|
|
|
from apt.utils.models import SklearnClassifier, SklearnRegressor, ModelOutputType, KerasClassifier, BlackboxClassifier
|
|
|
|
|
from apt.utils.datasets import ArrayDataset, Data
|
2022-04-27 12:33:27 +03:00
|
|
|
from apt.utils import dataset_utils
|
|
|
|
|
|
|
|
|
|
from sklearn.tree import DecisionTreeRegressor
|
|
|
|
|
from sklearn.ensemble import RandomForestClassifier
|
|
|
|
|
|
2022-05-12 15:44:29 +03:00
|
|
|
from tensorflow.keras.models import Sequential
|
|
|
|
|
from tensorflow.keras.layers import Dense, Input
|
|
|
|
|
|
2022-04-27 12:33:27 +03:00
|
|
|
|
|
|
|
|
def test_sklearn_classifier():
|
2022-05-12 15:44:29 +03:00
|
|
|
(x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset_np()
|
2022-04-27 12:33:27 +03:00
|
|
|
underlying_model = RandomForestClassifier()
|
2022-05-12 15:44:29 +03:00
|
|
|
model = SklearnClassifier(underlying_model, ModelOutputType.CLASSIFIER_PROBABILITIES)
|
2022-04-27 12:33:27 +03:00
|
|
|
train = ArrayDataset(x_train, y_train)
|
|
|
|
|
test = ArrayDataset(x_test, y_test)
|
|
|
|
|
model.fit(train)
|
2022-05-12 15:44:29 +03:00
|
|
|
pred = model.predict(test)
|
2022-04-27 12:33:27 +03:00
|
|
|
assert(pred.shape[0] == x_test.shape[0])
|
|
|
|
|
|
|
|
|
|
score = model.score(test)
|
|
|
|
|
assert(0.0 <= score <= 1.0)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_sklearn_regressor():
|
2022-05-12 15:44:29 +03:00
|
|
|
(x_train, y_train), (x_test, y_test) = dataset_utils.get_diabetes_dataset_np()
|
2022-04-27 12:33:27 +03:00
|
|
|
underlying_model = DecisionTreeRegressor()
|
|
|
|
|
model = SklearnRegressor(underlying_model)
|
|
|
|
|
train = ArrayDataset(x_train, y_train)
|
|
|
|
|
test = ArrayDataset(x_test, y_test)
|
|
|
|
|
model.fit(train)
|
2022-05-12 15:44:29 +03:00
|
|
|
pred = model.predict(test)
|
2022-04-27 12:33:27 +03:00
|
|
|
assert (pred.shape[0] == x_test.shape[0])
|
|
|
|
|
|
|
|
|
|
score = model.score(test)
|
2022-05-12 15:44:29 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_keras_classifier():
|
|
|
|
|
(x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset_np()
|
|
|
|
|
|
|
|
|
|
underlying_model = Sequential()
|
|
|
|
|
underlying_model.add(Input(shape=(4,)))
|
|
|
|
|
underlying_model.add(Dense(100, activation="relu"))
|
|
|
|
|
underlying_model.add(Dense(10, activation="relu"))
|
|
|
|
|
underlying_model.add(Dense(3, activation='softmax'))
|
|
|
|
|
|
|
|
|
|
underlying_model.compile(loss="categorical_crossentropy", optimizer="adam", metrics=["accuracy"])
|
|
|
|
|
|
|
|
|
|
model = KerasClassifier(underlying_model, ModelOutputType.CLASSIFIER_PROBABILITIES)
|
|
|
|
|
|
|
|
|
|
train = ArrayDataset(x_train, y_train)
|
|
|
|
|
test = ArrayDataset(x_test, y_test)
|
|
|
|
|
model.fit(train)
|
|
|
|
|
pred = model.predict(test)
|
|
|
|
|
assert(pred.shape[0] == x_test.shape[0])
|
|
|
|
|
|
|
|
|
|
score = model.score(test)
|
|
|
|
|
assert(0.0 <= score <= 1.0)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_blackbox_classifier():
|
|
|
|
|
(x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset_np()
|
|
|
|
|
|
|
|
|
|
train = ArrayDataset(x_train, y_train)
|
|
|
|
|
test = ArrayDataset(x_test, y_test)
|
|
|
|
|
data = Data(train, test)
|
|
|
|
|
model = BlackboxClassifier(data, ModelOutputType.CLASSIFIER_PROBABILITIES)
|
|
|
|
|
pred = model.predict(test)
|
|
|
|
|
assert(pred.shape[0] == x_test.shape[0])
|
|
|
|
|
|
|
|
|
|
score = model.score(test)
|
|
|
|
|
assert(0.0 <= score <= 1.0)
|