2022-02-10 15:36:41 +02:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
|
|
from apt.utils.models import SklearnClassifier, SklearnRegressor
|
2022-03-07 19:09:31 +02:00
|
|
|
from apt.utils.datasets import ArrayDataset
|
2022-02-10 15:36:41 +02:00
|
|
|
from apt.utils import dataset_utils
|
|
|
|
|
|
|
|
|
|
from sklearn.tree import DecisionTreeRegressor
|
|
|
|
|
from sklearn.ensemble import RandomForestClassifier
|
|
|
|
|
|
2022-03-07 19:09:31 +02:00
|
|
|
|
2022-02-10 15:36:41 +02:00
|
|
|
def test_sklearn_classifier():
|
2022-03-10 13:49:05 +02:00
|
|
|
dataset = dataset_utils.get_iris_dataset()
|
2022-02-10 15:36:41 +02:00
|
|
|
underlying_model = RandomForestClassifier()
|
|
|
|
|
model = SklearnClassifier(underlying_model)
|
2022-03-10 13:49:05 +02:00
|
|
|
model.fit(dataset.train)
|
|
|
|
|
pred = model.predict(dataset.get_test_samples())
|
|
|
|
|
assert(pred.shape[0] == dataset.get_test_samples().shape[0])
|
2022-02-10 15:36:41 +02:00
|
|
|
|
2022-03-10 13:49:05 +02:00
|
|
|
score = model.score(dataset.test)
|
2022-02-10 15:36:41 +02:00
|
|
|
assert(0.0 <= score <= 1.0)
|
|
|
|
|
|
2022-03-07 19:09:31 +02:00
|
|
|
|
2022-02-10 15:36:41 +02:00
|
|
|
def test_sklearn_regressor():
|
2022-03-10 13:49:05 +02:00
|
|
|
dataset = dataset_utils.get_diabetes_dataset()
|
2022-02-10 15:36:41 +02:00
|
|
|
underlying_model = DecisionTreeRegressor()
|
|
|
|
|
model = SklearnRegressor(underlying_model)
|
2022-03-10 13:49:05 +02:00
|
|
|
model.fit(dataset.train)
|
|
|
|
|
pred = model.predict(dataset.get_test_samples())
|
|
|
|
|
assert (pred.shape[0] == dataset.get_test_samples().shape[0])
|
2022-02-10 15:36:41 +02:00
|
|
|
|
2022-03-10 13:49:05 +02:00
|
|
|
score = model.score(dataset.test)
|
2022-03-07 19:09:31 +02:00
|
|
|
assert (0 <= score <= 1)
|