/*
* ARX: Powerful Data Anonymization
* Copyright 2012 - 2017 Fabian Prasser, Florian Kohlmayer and contributors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.deidentifier.arx.test;
import static org.junit.Assert.fail;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import org.deidentifier.arx.ARXAnonymizer;
import org.deidentifier.arx.ARXConfiguration;
import org.deidentifier.arx.ARXLattice;
import org.deidentifier.arx.ARXLattice.ARXNode;
import org.deidentifier.arx.ARXResult;
import org.deidentifier.arx.AttributeType.Hierarchy;
import org.deidentifier.arx.Data;
import org.deidentifier.arx.DataSelector;
import org.deidentifier.arx.DataSubset;
import org.deidentifier.arx.criteria.Inclusion;
import org.deidentifier.arx.criteria.KAnonymity;
import org.deidentifier.arx.metric.Metric;
import org.junit.Test;
/**
* Tests the classification of the solution space.
*
* @author Fabian Prasser
* @author Florian Kohlmayer
*/
public class TestSolutionSpaceClassification extends AbstractTest {
/**
* Performs a test.
*
* @throws IllegalArgumentException
* @throws IOException
*/
@Test
public void testNMEntropy() throws IllegalArgumentException, IOException {
Data data = Data.create("data/adult.csv", StandardCharsets.UTF_8, ';');
data.getDefinition().setAttributeType("sex", Hierarchy.create("data/adult_hierarchy_sex.csv", StandardCharsets.UTF_8, ';'));
data.getDefinition().setAttributeType("age", Hierarchy.create("data/adult_hierarchy_age.csv", StandardCharsets.UTF_8, ';'));
data.getDefinition().setAttributeType("race", Hierarchy.create("data/adult_hierarchy_race.csv", StandardCharsets.UTF_8, ';'));
data.getDefinition().setAttributeType("education", Hierarchy.create("data/adult_hierarchy_education.csv", StandardCharsets.UTF_8, ';'));
data.getDefinition().setAttributeType("marital-status", Hierarchy.create("data/adult_hierarchy_marital-status.csv", StandardCharsets.UTF_8, ';'));
DataSelector selector = DataSelector.create(data).field("sex").equals("Male");
DataSubset subset = DataSubset.create(data, selector);
ARXConfiguration config = ARXConfiguration.create();
config.addPrivacyModel(new KAnonymity(5));
config.addPrivacyModel(new Inclusion(subset));
config.setMaxOutliers(0.02d);
config.setQualityModel(Metric.createEntropyMetric(false));
ARXAnonymizer anonymizer = new ARXAnonymizer();
ARXResult result = anonymizer.anonymize(data, config);
result.getOutput(false).sort(true, new int[] { 0, 1, 2, 3, 4 });
ARXLattice lattice = result.getLattice();
for (ARXNode[] level : lattice.getLevels()) {
for (ARXNode node : level) {
if (Double.compare((Double.valueOf(node.getLowestScore().toString())), Double.NaN) == 0 ||
Double.compare((Double.valueOf(node.getHighestScore().toString())), Double.NaN) == 0) {
fail();
}
}
}
}
}