Python Version: 3.11.5

Targeted Fingerprinting
-------------------------------
We note that in our algorithm for targeted fingerprinting we utilize parts of the implementation from https://github.com/gaborgulyas/constrainted_fingerprinting. We will refer to this implementation in the following as the one from the PET paper. 

The dataset is from https://archive.ics.uci.edu/dataset/2/adult. We use the code from the PET paper implementation to load the dataset, giving us n = 32,561 and d = 80 features. We view the dataset as a n x d matrix called A. 

Note that the original dataset has 14 attributes. However, in line with our paper, we look at each value for each attribute and call that a feature. For example, each potential value for Age is a different feature. So, A[i][j] = 1 indicates that user i has feature j. A[i][j] indicates that user i does not have feature j. 

Notes and comments on how to run the code for targeted fingerprinting, general fingerprinting, and feature selection are in the beginning of the .ipynb notebook. 