mirror of
https://github.com/IBM/ai-privacy-toolkit.git
synced 2026-05-06 18:42:37 +02:00
Create initial version of wrappers for models (#1)
* New wrapper classes for models
This commit is contained in:
parent
9de078f937
commit
b0c6c4d28e
8 changed files with 325 additions and 4 deletions
|
|
@ -4,7 +4,7 @@ from sklearn.tree import DecisionTreeClassifier, DecisionTreeRegressor
|
|||
from sklearn.preprocessing import OneHotEncoder
|
||||
|
||||
from apt.anonymization import Anonymize
|
||||
from apt.utils import get_iris_dataset, get_adult_dataset, get_nursery_dataset
|
||||
from apt.utils.dataset_utils import get_iris_dataset, get_adult_dataset, get_nursery_dataset
|
||||
from sklearn.datasets import load_diabetes
|
||||
from sklearn.model_selection import train_test_split
|
||||
|
||||
|
|
|
|||
|
|
@ -12,7 +12,7 @@ from sklearn.preprocessing import OneHotEncoder, StandardScaler
|
|||
|
||||
from apt.minimization import GeneralizeToRepresentative
|
||||
from sklearn.tree import DecisionTreeClassifier, DecisionTreeRegressor
|
||||
from apt.utils import get_iris_dataset, get_adult_dataset, get_nursery_dataset, get_german_credit_dataset
|
||||
from apt.utils.dataset_utils import get_iris_dataset, get_adult_dataset, get_nursery_dataset, get_german_credit_dataset
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
|
|
|
|||
44
tests/test_model.py
Normal file
44
tests/test_model.py
Normal file
|
|
@ -0,0 +1,44 @@
|
|||
import pytest
|
||||
|
||||
from apt.utils.models import SklearnClassifier, SklearnRegressor
|
||||
from apt.utils import dataset_utils
|
||||
|
||||
from sklearn.tree import DecisionTreeRegressor
|
||||
from sklearn.ensemble import RandomForestClassifier
|
||||
|
||||
def test_sklearn_classifier():
|
||||
(x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset()
|
||||
underlying_model = RandomForestClassifier()
|
||||
model = SklearnClassifier(underlying_model)
|
||||
model.fit(x_train, y_train)
|
||||
pred = model.predict(x_test)
|
||||
assert(pred.shape[0] == x_test.shape[0])
|
||||
|
||||
score = model.score(x_test, y_test)
|
||||
assert(0.0 <= score <= 1.0)
|
||||
|
||||
def test_sklearn_regressor():
|
||||
(x_train, y_train), (x_test, y_test) = dataset_utils.get_diabetes_dataset()
|
||||
underlying_model = DecisionTreeRegressor()
|
||||
model = SklearnRegressor(underlying_model)
|
||||
model.fit(x_train, y_train)
|
||||
pred = model.predict(x_test)
|
||||
assert (pred.shape[0] == x_test.shape[0])
|
||||
|
||||
score = model.score(x_test, y_test)
|
||||
|
||||
losses = model.loss(x_test, y_test)
|
||||
assert (losses.shape[0] == x_test.shape[0])
|
||||
|
||||
|
||||
# Probably not needed for now, as we will not be using these wrappers directly in ART.
|
||||
# def test_sklearn_decision_tree():
|
||||
# (x_train, y_train), (x_test, y_test) = dataset_utils.get_iris_dataset()
|
||||
# underlying_model = DecisionTreeClassifier()
|
||||
# model = SklearnDecisionTreeClassifier(underlying_model)
|
||||
# model.fit(x_train, y_train)
|
||||
# pred = model.predict(x_test)
|
||||
# assert(pred.shape[0] == x_test.shape[0])
|
||||
#
|
||||
# score = model.score(x_test, y_test)
|
||||
# assert(0.0 <= score <= 1.0)
|
||||
Loading…
Add table
Add a link
Reference in a new issue