This repo/folder contains code used to generate all the results in the Comparative Study of Differentially Private Synthetic Data Algorithms from the NIST PSCR Differential Privacy Synthetic Data Challenge by Bowen and Snoke. Paper can be found in the Journal of Privacy and Confidentiality here.
Differentially private synthetic data generation offers a recent solution to release analytically useful data while preserving the privacy of individuals in the data. In order to utilize these algorithms for public policy decisions, policymakers need an accurate understanding of these algorithms’ comparative performance. Correspondingly, data practitioners also require standard metrics for evaluating the analytic qualities of the synthetic data. In this paper, we present an in-depth evaluation of several differentially private synthetic data algorithms using actual differentially private synthetic data sets created by contestants in the recent National Institute of Standards and Technology Public Safety Communications Research (NIST PSCR) ``Differential Privacy Synthetic Data Challenge.’’ We offer analyses of these algorithms based on both the accuracy of the data they create and their usability by potential data providers. We frame the methods used in the NIST PSCR data challenge within the broader differentially private synthetic data literature. We implement additional utility metrics, including two of our own, on the differentially private synthetic data and compare mechanism utility on three categories. Our comparative assessment of the differentially private data synthesis methods and the quality metrics shows the relative usefulness, general strengths and weaknesses, preferred choices of algorithms and metrics. Finally we describe the implications of our evaluation for policymakers seeking to implement differentially private synthetic data algorithms on future data products.
We recommend the following libraries to execute some of the code or additional functions.
- rpart is a package to apply recursive partitioning for classificaiton, regression and survival trees.
- synthpop is a “tool for producing synthetic versions of microdata containing confidential information so that they are safe to be released to users for exploratory analysis”. This library contains the code for calculating various utility metric such as pMSE-ratio.
- tidyverse is a suite of R packages by RStudio that help with data structure, data analysis, and data visualization.
This directory contains the .R
scripts for the used in the paper
except for some basic functions that we will list in the next section.
NOTE: We do not have the code that were used to calculate the NIST PSCR Data Challenge specific metrics. We only received the final agreggated results.
marginal_utility.R
is the R script to calculate the marginal distances based on p-values.pmse_CART_utility.R
is the R script to estimate pmse and null pmse using CART models.radarchart_function.R
is the R script “Really Useful Synthetic Data - A Framework to Evaluate the Quality of Differentially Private Synthetic Data” to generate the radarcharts.regression_utility.R
is the R script to calculate the mean and median standardized coefficient difference and confidence interval overlap for all regression coefficients.specks.R
is the R script to calculate the SPECKS metric using logistic regression main effect model.
The Urban Data Catalog contains the differentially private synthetic data generated for the NIST PSCR Data Challenge. The following are the data sets (original and the competitors’ differentially private synthetic data). We compressed the data by team and by match due to the file size.
NOTE: The data contains only a subset of the possible variables and the PUMS is the 1940 Decennial Census data.
- 2006 San Francisco Fire Department’s Call for Service Data
- 2017 San Francisco Fire Department’s Call for Service Data
- Arizona PUMS
- Vermont PUMS
The following is a list of R functions we used from other packages to generate our results.
glm()
from base R implements logistic regression.rpart()
fromrpart
implements CART.