ai-privacy-toolkit/tests/test_model.py

36 lines
1.2 KiB
Python
Raw Normal View History

import pytest
2022-03-15 11:42:57 +02:00
from apt.utils.models import SklearnClassifier, SklearnRegressor, ModelOutputType
2022-03-07 19:09:31 +02:00
from apt.utils.datasets import ArrayDataset
from apt.utils import dataset_utils
from sklearn.tree import DecisionTreeRegressor
from sklearn.ensemble import RandomForestClassifier
2022-03-07 19:09:31 +02:00
def test_sklearn_classifier():
(x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset()
underlying_model = RandomForestClassifier()
2022-03-15 11:42:57 +02:00
model = SklearnClassifier(underlying_model, ModelOutputType.CLASSIFIER_VECTOR)
2022-03-07 19:09:31 +02:00
train = ArrayDataset(x_train, y_train)
test = ArrayDataset(x_test, y_test)
model.fit(train)
pred = model.predict(x_test)
assert(pred.shape[0] == x_test.shape[0])
2022-03-07 19:09:31 +02:00
score = model.score(test)
assert(0.0 <= score <= 1.0)
2022-03-07 19:09:31 +02:00
def test_sklearn_regressor():
(x_train, y_train), (x_test, y_test) = dataset_utils.get_diabetes_dataset()
underlying_model = DecisionTreeRegressor()
model = SklearnRegressor(underlying_model)
2022-03-07 19:09:31 +02:00
train = ArrayDataset(x_train, y_train)
test = ArrayDataset(x_test, y_test)
model.fit(train)
pred = model.predict(x_test)
assert (pred.shape[0] == x_test.shape[0])
2022-03-07 19:09:31 +02:00
score = model.score(test)