{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Twitch social network data\n",
    "\n",
    "From: \n",
    "@misc{rozemberczki2019multiscale,\n",
    "\n",
    "            title={Multi-scale Attributed Node Embedding},\n",
    "            \n",
    "            author={Benedek Rozemberczki and Carl Allen and Rik Sarkar},\n",
    "            \n",
    "            year={2019},\n",
    "            \n",
    "            eprint={1909.13021},\n",
    "            \n",
    "            archivePrefix={arXiv},\n",
    "            \n",
    "            primaryClass={cs.LG}\n",
    "        }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Twitch social network dataimport numpy as np\n",
    "import pandas as pd\n",
    "from matplotlib import pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import itertools\n",
    "from sklearn.ensemble import RandomForestClassifier as RFC\n",
    "from sklearn.gaussian_process import GaussianProcessClassifier as GPC\n",
    "from sklearn.gaussian_process.kernels import RBF, Matern, WhiteKernel, DotProduct, RationalQuadratic\n",
    "from sklearn.ensemble import AdaBoostClassifier as ABC\n",
    "from sklearn.ensemble import GradientBoostingClassifier as GBC\n",
    "from sklearn import preprocessing\n",
    "from sklearn.tree import DecisionTreeClassifier as DTC\n",
    "from sklearn.neighbors import KNeighborsClassifier as KNC\n",
    "from sklearn.calibration import CalibratedClassifierCV as CCCV\n",
    "from scipy.stats import mode\n",
    "\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.stats import multivariate_normal\n",
    "from tqdm import tqdm_notebook as tqdm\n",
    "\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "\n",
    "def set_plot_defaults(): \n",
    "    \"\"\"Sets up default plotting values for our figures\n",
    "    \"\"\"\n",
    "    mpl.rcdefaults()\n",
    "    plt.rc('axes', labelsize=20)    # fontsize of the x and y labels\n",
    "    plt.rc('xtick', labelsize=20)    # fontsize of the tick labels\n",
    "    plt.rc('ytick', labelsize=20)    # fontsize of the tick labels\n",
    "    plt.rc('legend', fontsize=20)    # legend fontsize\n",
    "    plt.rc('figure', titlesize=20)  # fontsize of the figure title\n",
    "    plt.rc('legend', frameon = False) #don't add a box around legends\n",
    "    plt.rc('lines', linewidth = 4) #make lines thick enough to see \n",
    "    plt.rc('axes', titlesize = 30) #make titles big enough to read\n",
    "\n",
    "def shuffle_dataset_II(labels, alpha, Deltas, sig0): \n",
    "    sig_full = []\n",
    "    sig0_full = []\n",
    "    for sig0_, Delta in zip(sig0, Deltas): \n",
    "        if Delta > 1: \n",
    "            theta = 2 * alpha / (Delta * (Delta - 1))\n",
    "            sig_full = np.concatenate((sig_full, mallows(theta = theta, sig0 = sig0_)))\n",
    "        else: \n",
    "            sig_full = np.concatenate((sig_full, sig0_))\n",
    "            \n",
    "        sig0_full = np.concatenate((sig0_full, sig0_))\n",
    "      \n",
    "    sig_full = sig_full.astype(int)\n",
    "    sig0_full = sig0_full.astype(int)\n",
    "    labels_shuff = labels[sig_full[np.argsort(sig0_full)]]\n",
    "    return labels_shuff, sig_full, sig0_full\n",
    "  \n",
    "def mallows(theta, sig0 = []): \n",
    "  if len(sig0) == 0: \n",
    "    print('need a reference permutation')\n",
    "    return\n",
    "#   N = len(sig0) * (len(sig0) - 1) / 2\n",
    "#   if alpha > 0:\n",
    "#     theta = alpha / N\n",
    "#   print('theta is', theta)\n",
    "  phi = np.exp(-theta)\n",
    "  #get insertion probabilities \n",
    "  ws = []\n",
    "  ct = 0\n",
    "  for i in range(len(sig0)): \n",
    "    wi_ = []\n",
    "    #formula is given with index by 1\n",
    "    i = i+1\n",
    "    for j in range(i): \n",
    "      j = j+1\n",
    "      wij = phi**(i-j) * (1 - phi) / (1 - phi**i)\n",
    "      wi_.append(wij)\n",
    "      ct += 1\n",
    "    ws.append(wi_)\n",
    "\n",
    "  # sample from these ws \n",
    "  inserts = []\n",
    "  for i in range(len(sig0)): \n",
    "    #to ensure sum to 1\n",
    "    p_vals = ws[i] / np.sum(ws[i])\n",
    "    chosen_wij = np.random.choice(len(ws[i]), p = p_vals)\n",
    "    inserts.append(chosen_wij)\n",
    "    \n",
    "  #build the sampled permutation \n",
    "  pi = np.empty(0, dtype = int)\n",
    "  for i in range(len(sig0)): \n",
    "    pi = np.insert(pi, inserts[i], sig0[i])\n",
    "\n",
    "  return pi\n",
    "\n",
    "def get_sig0(T, R, Distmat, Distmat_corrs): \n",
    "    N = Distmat <= R\n",
    "    most_neighbs = np.max(np.sum(N, axis = 1))\n",
    "    print('most neighbs:', most_neighbs)\n",
    "    sig0 = []\n",
    "    n = N.shape[0]\n",
    "\n",
    "    # Visited vector \n",
    "    visited = [False] * int(n)\n",
    "\n",
    "    start = np.argmax(N.sum(axis = 1)) #start at node with largest group\n",
    "\n",
    "    while np.sum([len(sig0_) for sig0_ in sig0]) < n: \n",
    "        # Set source as visited \n",
    "        visited[start] = True\n",
    "        q = [start] \n",
    "        # Start a new sig0 for this graph: \n",
    "        sig0_ = []\n",
    "        while q: \n",
    "            vis = q[0] \n",
    "\n",
    "            # Print current node \n",
    "            sig0_.append(vis)\n",
    "            q.pop(0) \n",
    "\n",
    "            # Get every adjacent vertex to  \n",
    "            # the current vertex \n",
    "            neighbs = np.nonzero(N[vis,:])[0]\n",
    "            new_neighbs = neighbs[~np.in1d(neighbs, np.nonzero(visited)[0])]\n",
    "            if new_neighbs.any(): \n",
    "                # Sort unvisited neighbors by closest distance to the current vertex \n",
    "                dists = Distmat_corrs[vis, new_neighbs]\n",
    "#                 corrs = kernel(T[vis,:], T[new_neighbs,:]).squeeze()\n",
    "                dist_order = np.argsort(dists)\n",
    "#                 corr_order = np.argsort(corrs)[::-1]\n",
    "                new_neighbs = new_neighbs[dist_order] \n",
    "                for neighb in new_neighbs: \n",
    "                    # Push the adjacent node  \n",
    "                    # in the queue \n",
    "                    q.append(neighb) \n",
    "                    # set \n",
    "                    visited[neighb] = True\n",
    "        #if q finishes but haven't visited everyone, then we start a new graph\n",
    "        sig0.append(sig0_)\n",
    "        if np.concatenate(sig0).size < n: \n",
    "            start = np.argmax(~np.asarray(visited)) #get first non-visited index \n",
    "\n",
    "    Deltas = [] #records Delta for each subgraph \n",
    "    for sig0_ in sig0: \n",
    "        if np.size(sig0_) > 1: \n",
    "            deltas = []\n",
    "            for k in range(len(sig0_)): \n",
    "                neighbs = np.nonzero(N[sig0_[k],:])[0]\n",
    "                neighbs_idx = np.where(np.in1d(sig0_, neighbs))[0]\n",
    "                newdelt = (np.max(neighbs_idx ) - np.min(neighbs_idx)) + 1\n",
    "                deltas.append(newdelt)\n",
    "            Deltas.append(np.max(deltas))\n",
    "        else: \n",
    "            Deltas.append(1)\n",
    "    return sig0, Deltas\n",
    "  \n",
    "\n",
    "  \n",
    "def RR(labels, epsilon): \n",
    "    #apply randomized response to labels \n",
    "    k = len(np.unique(labels))\n",
    "    prob_flip = (k-1) / (np.exp(epsilon) + (k-1))\n",
    "    print('prob of flip:', prob_flip)\n",
    "    flip_idx = np.random.binomial(1, prob_flip, len(labels)) == 1\n",
    "    comp_idx = np.asarray([[True]*k]*len(labels))\n",
    "    comp_idx[np.arange(len(labels))[:,None],labels] = False\n",
    "    comp = np.tile(np.arange(k), [len(labels), 1])\n",
    "    comp = np.reshape(comp[comp_idx], (len(labels), k-1))\n",
    "    choices = np.random.choice(np.arange(k-1), len(labels))\n",
    "    randsamp = comp[np.arange(len(labels)), choices]\n",
    "    labels_z = labels.copy()\n",
    "    labels_z[flip_idx] = randsamp[:,None][flip_idx]\n",
    "    return labels_z\n",
    "  \n",
    "def kNN_pred(Y, Dmat, N, i, K): \n",
    "    neighb_idx = N[i,:]\n",
    "    m = np.sum(neighb_idx)\n",
    "    if K > m: #don't let the NN prediction be larger than the group \n",
    "        K = m\n",
    "    neighb_ids = np.where(neighb_idx)[0]\n",
    "    neighb_dists = Dmat[i, neighb_ids]\n",
    "    NNs = neighb_ids[np.argsort(neighb_dists)[:K]]\n",
    "    kNN_pred_trials = mode(Y[NNs,:].astype(int), axis = 0)[0]\n",
    "    #returns kNN prediction on i for each of the ldp trials Y\n",
    "    return kNN_pred_trials\n",
    "  \n",
    "def k_vs_grp_attack(X, Y, Dmat, Distmat, R, Rcorr, K = 20, t = 0.9):\n",
    "    N = Distmat <= R #neighborhood of group\n",
    "    Ncorr = Distmat <= Rcorr #neighborhood for correlating \n",
    "    \n",
    "    n = len(X)\n",
    "    vulnerable_k = [] #list of ids that can be inferred by K\n",
    "    vulnerable_grp = [] #list of ids that can be inferred by grp \n",
    "\n",
    "    for i in range(n):\n",
    "        m = N[i,:].sum() #num neighbors\n",
    "\n",
    "        K_preds = kNN_pred(Y, Dmat, Ncorr, i, K) #prediction by K NN's for each Y trial\n",
    "        K_pred_acc = np.mean(K_preds == X[i]) #accuracy across trials\n",
    "        if K_pred_acc >= t: \n",
    "            vulnerable_k.append(i)\n",
    "\n",
    "        grp_preds = kNN_pred(Y, Dmat, N, i, K = m) #prediction by whole group for each Y trial\n",
    "        grp_pred_acc = np.mean(grp_preds == X[i]) #accuracy across trials\n",
    "        if grp_pred_acc >= t: \n",
    "            vulnerable_grp.append(i)\n",
    "            \n",
    "    return vulnerable_k, vulnerable_grp\n",
    "  \n",
    "  \n",
    "def get_calibration_TVD(y_vals, x_vals, Distmat, R_calib):\n",
    "    noisy_probs = get_probs(Distmat, R_calib, y_vals)\n",
    "    true_probs = get_probs(Distmat, R_calib, x_vals)\n",
    "    ave_TV = np.mean(np.abs(noisy_probs - true_probs))\n",
    "    return ave_TV\n",
    "  \n",
    "def get_probs(Distmat, R_calib, x_vals): \n",
    "    #Get calibration neighbors \n",
    "    N = Distmat <= R_calib\n",
    "    #Get calibration hists\n",
    "    tgt_hists = np.zeros(len(x_vals))\n",
    "    for i in range(len(x_vals)): \n",
    "        neighb_idx = N[i,:]\n",
    "        labels = x_vals[neighb_idx]\n",
    "        hist = np.zeros(2)\n",
    "        prob = np.mean(labels)\n",
    "        tgt_hists[i] = prob\n",
    "        \n",
    "    return tgt_hists\n",
    "  \n",
    "def get_TVD(calib_hists, Distmat, R_calib, T_locat, x_vals): \n",
    "    #Get calibration neighbors \n",
    "    N = Distmat <= R_calib\n",
    "    #Get calibration hists\n",
    "    tgt_hists = np.zeros((len(x_vals), 2))\n",
    "    for i in range(len(x_vals)): \n",
    "        neighb_idx = N[i,:]\n",
    "        labels = x_vals[neighb_idx]\n",
    "        hist = np.zeros(2)\n",
    "        hist_cts = np.bincount(labels)\n",
    "        hist[:len(hist_cts)] = hist_cts / len(labels)\n",
    "        tgt_hists[i,:] = hist\n",
    "        \n",
    "    TVs = 0.5 * np.abs(calib_hists - tgt_hists).sum(axis = 1)\n",
    "    return TVs\n",
    "  \n",
    "  "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Twitch social network data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>id</th>\n",
       "      <th>days</th>\n",
       "      <th>mature</th>\n",
       "      <th>views</th>\n",
       "      <th>partner</th>\n",
       "      <th>new_id</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>37905227</td>\n",
       "      <td>2149</td>\n",
       "      <td>True</td>\n",
       "      <td>162078</td>\n",
       "      <td>False</td>\n",
       "      <td>5079</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>63102384</td>\n",
       "      <td>1574</td>\n",
       "      <td>True</td>\n",
       "      <td>1370</td>\n",
       "      <td>False</td>\n",
       "      <td>4281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>109414094</td>\n",
       "      <td>1034</td>\n",
       "      <td>True</td>\n",
       "      <td>6043</td>\n",
       "      <td>False</td>\n",
       "      <td>992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>84163849</td>\n",
       "      <td>1319</td>\n",
       "      <td>True</td>\n",
       "      <td>94298</td>\n",
       "      <td>True</td>\n",
       "      <td>9021</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>38240837</td>\n",
       "      <td>2137</td>\n",
       "      <td>True</td>\n",
       "      <td>2323</td>\n",
       "      <td>False</td>\n",
       "      <td>330</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          id  days  mature   views  partner  new_id\n",
       "0   37905227  2149    True  162078    False    5079\n",
       "1   63102384  1574    True    1370    False    4281\n",
       "2  109414094  1034    True    6043    False     992\n",
       "3   84163849  1319    True   94298     True    9021\n",
       "4   38240837  2137    True    2323    False     330"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nodes = pd.read_csv('./twitch/DE/musae_DE_target.csv')\n",
    "nodes.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from</th>\n",
       "      <th>to</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>9206</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>7787</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>2145</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>2684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>7275</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   from    to\n",
       "0     0  9206\n",
       "1     0  7787\n",
       "2     0  2145\n",
       "3     0  2684\n",
       "4     0  7275"
      ]
     },
     "execution_count": 81,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edges = pd.read_csv('./twitch/DE/musae_DE_edges.csv')\n",
    "edges.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/kc/anaconda3/envs/python3/lib/python3.8/site-packages/pandas/core/indexing.py:1676: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  self._setitem_single_column(ilocs[0], value, pi)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([0, 1, 1, 1, 1, 1, 0, 1, 1, 0])"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#get labels\n",
    "# index is id, value is label\n",
    "X = nodes[['new_id', 'mature']]\n",
    "X.loc[:,'mature'] = X['mature'].map({False: 0, True:1})\n",
    "X = X.to_numpy()\n",
    "X = X[np.argsort(X[:,0]), 1]\n",
    "X[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[   0, 9206],\n",
       "       [   0, 7787],\n",
       "       [   0, 2145],\n",
       "       [   0, 2684],\n",
       "       [   0, 7275],\n",
       "       [   0, 2498],\n",
       "       [   0, 5358],\n",
       "       [   1, 1578],\n",
       "       [   1,  116],\n",
       "       [   1, 4611]])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#get graph \n",
    "T = edges.to_numpy()\n",
    "T = T[np.argsort(T[:,0]), :]\n",
    "T[:10,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Make adjacency matrix: \n",
    "A = np.zeros((len(X), len(X)),dtype = int)\n",
    "for i in range(len(T)): \n",
    "    A[T[i,0], T[i,1]] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check correlations\n",
    "corrs = np.zeros((2,2))\n",
    "for i in range(2): \n",
    "    Xi_labs = X == i\n",
    "    A_labs = A[Xi_labs,:].sum(axis = 0)\n",
    "    for j in range(2):\n",
    "        Xj_labs = X == j\n",
    "        corrs[i,j] = A_labs[Xj_labs].sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[19217., 26762.],\n",
       "       [29557., 77602.]])"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corrs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ave num connections 16.12318382817435\n"
     ]
    }
   ],
   "source": [
    "print('ave num connections', np.mean(A.sum(axis = 1)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get LDP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "prob of flip: 0.18242552380635635\n",
      "Frac unperturbed 0.8204885238997683\n"
     ]
    }
   ],
   "source": [
    "#make multiple trials \n",
    "n_trials = 50\n",
    "Y = np.zeros((len(X), n_trials))\n",
    "for i in range(n_trials): \n",
    "    Y[:,i] = RR(X[:,None], epsilon = 1.5).squeeze()\n",
    "print('Frac unperturbed', np.mean( Y[:,0] == X) )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get distance matrices indicating path distance between individuals \n",
    "\n",
    "(we only end up using distance of 1 here)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making > 2 infty\n",
      "Making diagonal 0\n",
      "Getting second degree neighbors\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-91-a4c85fa258ec>:10: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for i in tqdm(range(len(X))):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eddf90e12e16413ea0268ecc53751a8a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/9498 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#get 2nd-degree distmat \n",
    "Distmat = A.copy().astype(float)\n",
    "print(\"Making > 2 infty\")\n",
    "Distmat[Distmat == 0.] = np.inf\n",
    "print(\"Making diagonal 0\")\n",
    "a = np.arange(len(X))\n",
    "Distmat[a,a] = 0.\n",
    "\n",
    "print(\"Getting second degree neighbors\")\n",
    "for i in tqdm(range(len(X))): \n",
    "    #get second degree neighbors \n",
    "    neighbs = np.where(A[i,:])[0]\n",
    "    for neighb in neighbs: \n",
    "        #get neighbor's neighbs who are not already neighbs\n",
    "        neighbneighb = np.where(A[neighb,:])[0]\n",
    "        new_neighb_idx = ~np.in1d(neighbneighb, neighbs)\n",
    "        new_neighbs = neighbneighb[new_neighb_idx]\n",
    "        Distmat[i, new_neighbs] = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "Dmat = Distmat\n",
    "Distmat_corrs = Distmat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Find individuals susceptible to KNN attack with just LDP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-48-4396c8166b69>:18: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for i in tqdm(range(n)):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5c603866db874a979cc65acb378c947d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/22470 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/kc/anaconda3/envs/python3/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3372: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/kc/anaconda3/envs/python3/lib/python3.8/site-packages/numpy/core/_methods.py:170: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " iter 0: KNN vuln: 0, GRP vuln 1\n",
      "\n",
      " iter 1000: KNN vuln: 650, GRP vuln 835\n",
      "\n",
      " iter 2000: KNN vuln: 1278, GRP vuln 1648\n",
      "\n",
      " iter 3000: KNN vuln: 1918, GRP vuln 2466\n",
      "\n",
      " iter 4000: KNN vuln: 2529, GRP vuln 3284\n",
      "\n",
      " iter 5000: KNN vuln: 3141, GRP vuln 4112\n",
      "\n",
      " iter 6000: KNN vuln: 3723, GRP vuln 4888\n",
      "\n",
      " iter 7000: KNN vuln: 4309, GRP vuln 5642\n",
      "\n",
      " iter 8000: KNN vuln: 4883, GRP vuln 6396\n",
      "\n",
      " iter 9000: KNN vuln: 5427, GRP vuln 7123\n",
      "\n",
      " iter 10000: KNN vuln: 5963, GRP vuln 7825\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-48-4396c8166b69>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     19\u001b[0m     \u001b[0mm\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mN\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;31m#num neighbors\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     20\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 21\u001b[0;31m     \u001b[0mK_preds\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mkNN_pred\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mY_tr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mDmat\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mN_corr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;31m#prediction by K NN's for each Y trial (only look at those close by)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     22\u001b[0m     \u001b[0mK_pred_acc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mK_preds\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mX_tr\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;31m#accuracy across trials\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     23\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-34-fc91da634214>\u001b[0m in \u001b[0;36mkNN_pred\u001b[0;34m(Y, Dmat, N, i, K)\u001b[0m\n\u001b[1;32m    176\u001b[0m     \u001b[0mneighb_dists\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mDmat\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mneighb_ids\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    177\u001b[0m     \u001b[0mNNs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mneighb_ids\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0margsort\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mneighb_dists\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 178\u001b[0;31m     \u001b[0mkNN_pred_trials\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mY\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mNNs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mastype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    179\u001b[0m     \u001b[0;31m#returns kNN prediction on i for each of the ldp trials Y\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    180\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mkNN_pred_trials\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/python3/lib/python3.8/site-packages/scipy/stats/stats.py\u001b[0m in \u001b[0;36mmode\u001b[0;34m(a, axis, nan_policy)\u001b[0m\n\u001b[1;32m    570\u001b[0m     \u001b[0mcounts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzeros\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma_view\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mint_\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    571\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mind\u001b[0m \u001b[0;32min\u001b[0m \u001b[0minds\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 572\u001b[0;31m         \u001b[0mmodes\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mind\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcounts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mind\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_mode1D\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma_view\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mind\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    573\u001b[0m     \u001b[0mnewshape\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    574\u001b[0m     \u001b[0mnewshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/python3/lib/python3.8/site-packages/scipy/stats/stats.py\u001b[0m in \u001b[0;36m_mode1D\u001b[0;34m(a)\u001b[0m\n\u001b[1;32m    557\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    558\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_mode1D\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 559\u001b[0;31m         \u001b[0mvals\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcnts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munique\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreturn_counts\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    560\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mvals\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mcnts\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0margmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcnts\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    561\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36munique\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/python3/lib/python3.8/site-packages/numpy/lib/arraysetops.py\u001b[0m in \u001b[0;36munique\u001b[0;34m(ar, return_index, return_inverse, return_counts, axis)\u001b[0m\n\u001b[1;32m    259\u001b[0m     \u001b[0mar\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masanyarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mar\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    260\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0maxis\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 261\u001b[0;31m         \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_unique1d\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreturn_index\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreturn_inverse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreturn_counts\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    262\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_unpack_tuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mret\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    263\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/python3/lib/python3.8/site-packages/numpy/lib/arraysetops.py\u001b[0m in \u001b[0;36m_unique1d\u001b[0;34m(ar, return_index, return_inverse, return_counts)\u001b[0m\n\u001b[1;32m    335\u001b[0m         \u001b[0mret\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0minv_idx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    336\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mreturn_counts\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 337\u001b[0;31m         \u001b[0midx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconcatenate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnonzero\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmask\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmask\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    338\u001b[0m         \u001b[0mret\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiff\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    339\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mret\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36mnonzero\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/python3/lib/python3.8/site-packages/numpy/core/fromnumeric.py\u001b[0m in \u001b[0;36m_nonzero_dispatcher\u001b[0;34m(a)\u001b[0m\n\u001b[1;32m   1810\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1811\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1812\u001b[0;31m \u001b[0;32mdef\u001b[0m \u001b[0m_nonzero_dispatcher\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1813\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1814\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "#Find which predictors are right >=t% of the time (if any), and record their indices\n",
    "\n",
    "#with K=20 and R = 20 should be getting about 10% vulnerable\n",
    "\n",
    "R = 2\n",
    "N = Distmat <= R\n",
    "\n",
    "#region within which we try to correlate for attack\n",
    "R_corr = 1\n",
    "N_corr = Distmat <= R_corr\n",
    "\n",
    "n = len(X_tr)\n",
    "t = 0.9 #threshold for being an inf. attack \n",
    "K = 25 #num neighbors in KNN\n",
    "vulnerable_knn = [] #list of ids that can be inferred by K but not by whole group\n",
    "vulnerable_grp = []\n",
    "\n",
    "for i in tqdm(range(n)):\n",
    "    m = N[i,:].sum() #num neighbors\n",
    "    \n",
    "    K_preds = kNN_pred(Y_tr, Dmat, N_corr, i, K) #prediction by K NN's for each Y trial (only look at those close by)\n",
    "    K_pred_acc = np.mean(K_preds == X_tr[i]) #accuracy across trials\n",
    "    \n",
    "    if K_pred_acc >= t: \n",
    "        vulnerable_knn.append(i)\n",
    "    \n",
    "    grp_preds = kNN_pred(Y_tr, Dmat, N, i, K = m) #prediction by whole group for each Y trial\n",
    "    grp_pred_acc = np.mean(grp_preds == X_tr[i]) #accuracy across trials\n",
    "    \n",
    "    if grp_pred_acc >= t: \n",
    "        vulnerable_grp.append(i)\n",
    "    \n",
    "    if K_pred_acc >= t and grp_pred_acc < t: \n",
    "        vulnerable_grp.append(i)\n",
    "    \n",
    "    #check progress: \n",
    "    if i%1000 == 0: \n",
    "#         print( '\\n iter {0:n}: {1:n} vulnerable'.format(i, len(vulnerable)) )\n",
    "        print( '\\n iter {0:n}: KNN vuln: {1:n}, GRP vuln {2:n}'\\\n",
    "              .format(i, len(vulnerable_knn), len(vulnerable_grp)) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sweep width $\\omega$\n",
    "\n",
    "written here as 'delta_vals', but do not confuse this with $\\Delta$ in the paper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for just LDP...\n",
      "getting result for uniform shuffling...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-165-7a98250cdfc8>:41: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for trial in tqdm(range(n_trials)):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b0ee194048ba4f95820e34822f3690b8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 1.555648734873435\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 2.177905221590257\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 3.0490631001065998\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 4.268682445989715\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 5.976147172573666\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 8.366594489082367\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 11.713216111208572\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 16.39847991281383\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 22.957840177953695\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 32.140931869216516\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 44.997242485102845\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 62.99605249474363\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 88.19435171464875\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 123.4719219115545\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 172.86045199197045\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 242.00429863133186\n",
      "getting result for partial shuffling...\n",
      "\n",
      "D: 338.8055502641131\n",
      "getting result for partial shuffling...\n"
     ]
    }
   ],
   "source": [
    "delta_vals = np.logspace(-2, np.log10(5000), 40)[15:32]\n",
    "\n",
    "shuff_idx = np.arange(Y.shape[0])\n",
    "np.random.shuffle(shuff_idx)\n",
    "Y_shuff = Y[shuff_idx, :]\n",
    "\n",
    "R = 1\n",
    "Rcorr = 1 #attack radius\n",
    "K = 30\n",
    "\n",
    "alpha = 4\n",
    "\n",
    "def print_stats(vuln_k, vuln_grp): \n",
    "    print(\"Num KNN'd:\", len(vuln_k))\n",
    "    print(\"Num Grp'd:\", len(vuln_grp))\n",
    "    gap = len(vuln_k) - np.in1d(vuln_k, vuln_grp).sum() #number KNN'd but not GRP'd\n",
    "    print(\"Num KNN'd not Grp'd:\", gap)\n",
    "  \n",
    "#key is radius, value is (vuln_k_*, vuln_grp_*)\n",
    "vuln_pshuff = {}\n",
    "\n",
    "print(\"getting result for just LDP...\")\n",
    "vuln_k_LDP, vuln_grp_LDP = k_vs_grp_attack(X, Y, Dmat, Distmat, \n",
    "                                                   R, Rcorr, K = K, t = 0.9)\n",
    "    \n",
    "print(\"getting result for uniform shuffling...\")\n",
    "vuln_k_shuff, vuln_grp_shuff = k_vs_grp_attack(X, Y_shuff, Dmat, Distmat, \n",
    "                                                   R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "gen_perms = False\n",
    "n_trials = 10\n",
    "\n",
    "attack_pshuff = np.zeros((len(delta_vals), n_trials))\n",
    "\n",
    "for trial in tqdm(range(n_trials)): \n",
    "    for D in delta_vals: \n",
    "        print(\"\\nD:\", D)\n",
    "        Deltas = np.ones(len(deltas0)) * D\n",
    "        if gen_perms:  \n",
    "            print(\"Applying Mallows...\")\n",
    "            labels_pshuff, sig_full, sig0_full = shuffle_dataset_II(Y[:,0], alpha, \n",
    "                                                                    Deltas, sig0)\n",
    "\n",
    "            #save shufflings\n",
    "            np.save('./permutations_experiment/sigma0_R{0:.3f}'.format(R), sig0_full)\n",
    "            np.save('./permutations_experiment/sigmasamp_D{0:.3f}_n{1:n}'.format(D, trial), sig_full)\n",
    "        else: \n",
    "            sig0_full = np.load('./permutations_experiment/sigma0_R{0:.3f}.npy'.format(R))\n",
    "            sig_full = np.load('./permutations_experiment/sigmasamp_D{0:.3f}_n{1:n}.npy'.format(D, trial))\n",
    "\n",
    "        Y_pshuff = Y[sig_full[np.argsort(sig0_full)], :]\n",
    "\n",
    "        print(\"getting result for partial shuffling...\")\n",
    "        vuln_k_pshuff, vuln_grp_pshuff = k_vs_grp_attack(X, Y_pshuff, Distmat_corrs, Distmat, \n",
    "                                                       R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "\n",
    "        attack_pshuff[delta_vals == D, trial] = len(vuln_k_pshuff) / len(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_pshuff = np.load('./attack_pshuff.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnEAAAHOCAYAAAD3+V8FAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAA9hAAAPYQGoP6dpAACHTUlEQVR4nO3dd3hTZfsH8O/JbNN00E3ZewjI9mVbRNAXGSJDRQVExb1QfOGnDBcO8HXiAGQpskREUURBlqAUROCVISCzlO6dnZzfHzWhpUmatCfN6PdzXb1Ic55zzt3SNHefcT+CKIoiiIiIiCioyPwdABERERF5j0kcERERURBiEkdEREQUhJjEEREREQUhJnFEREREQYhJHBEREVEQYhJHREREFIQU/g6AfMNms+HSpUuIjIyEIAj+DoeIiIg8IIoiiouLkZKSApnMfV8bk7gQdenSJTRq1MjfYRAREVE1XLhwAQ0bNnTbhklciIqMjARQ9kMQFRXl52iIiIjIE0VFRWjUqJHjfdwdJnEhyj6EGhUVxSSOiIgoyHgyFYoLG4iIiIiCEJM4IiIioiDEJI6IiIgoCDGJIyIiIgpCTOKIiIiIghCTOCIiIqIgxCSOiIiIKAgxiSMiIiIKQkziiIiIiIIQkzgiIiKiIMQkjoiIiCgIce9Uqp6MC9JeLyISiIpx36aoACgtlva+9Ru5P261AlmXpL1nZAygrWJj4/wcwKCX7p4yOZCU4r6NyQjkZkl3TwCoFweEady3yc0ETCbp7qlSAXFJ7tsYdEB+rnT3BIC4RECldt8m8xJgs0p3z7BwoF68+zYlxUBxgXT3BIDEFEAud9+GvyOqj78jKgrU3xFV/WzUAiZxVD1Gg7TXU4dV3cZilv6+VRFt0t9TY6m6jdRfa1VvuAAgitJ/rVYPEhaTqfb/X61W6e8pilW3MRk8+554SuHBr3CrxQdfqw1AFT9T/B1RffwdUVGo/I7wAQ6nEhEREQUhJnFEREREQYhJHBEREVEQ4pw4qh5P5qd4Q6H0rI3U962KIJP+nnIPXnZSf60yD+a7CIIPvlYP7qtSSXtPT64nl0v/tQpC1W1UYdIubPDkdSNX+OBr9eDvf/6OqD7+jqgoVH5H+IAgip7MxqVgU1RUhOjoaBQWFiIqKsrf4RAREZEHvHn/5nAqERERURBiEkdEREQUhJjEEREREQUhJnFEREREQYhJHBEREVEQYhJHREREFISYxBEREREFISZxREREREGISRwRERFREGISR0RERBSEmMQRERERBSEmcURERERBiEkcERERURAKySTu/PnzeOaZZ9CuXTtEREQgNjYWPXv2xLx586DT6Wp07f3792P+/Pm4/fbb0alTJ9SvXx9qtRqRkZFo06YNJkyYgJ9//rnK6zRt2hSCIFT50bRp0xrFS0RERKFJEEVR9HcQUtq0aRPGjx+PwsJCp8fbtGmD7777Ds2bN6/W9fv27YtffvmlynZjxozB8uXLERYW5vR406ZNce7cuSqv06RJE5w9e9bbMFFUVITo6GgUFhYiKirK6/OJiIio9nnz/q2opZhqxaFDhzB27FjodDpotVpMnz4dqamp0Ov1WLVqFRYuXIgTJ05g6NChSEtLg1ar9foearUaAwYMQO/evdGuXTskJycjLi4O2dnZOHToED766COcOXMGa9euhUwmw6pVq9xeb8SIEXj55ZddHlepVF7HSERERKEvpHriUlNTsX37digUCuzcuRO9evWqcPzNN9/EtGnTAABz5szBzJkzvb6HxWKBQuE699Xr9bjhhhuwd+9eAMDhw4fRsWPHSu3sPXETJkzA0qVLvY6jKuyJIyIiCj7evH+HzJy4tLQ0bN++HQAwefLkSgkcAEydOhXt2rUDALz99tswm81e38ddAgcA4eHheOKJJxyf79y50+t7EBEREVUlZJK4DRs2OB5PmjTJaRuZTIZ77rkHAJCfn+9I+qQWERHheGwwGHxyDyIiIqrbQiaJ27VrF4CyBKpbt24u2w0YMMDxePfu3T6J5YsvvnA8btu2rU/uQURERHVbyCRxx44dAwC0bNnS7ZBn+aTKfk5N2Ww2ZGZmYtu2bbj11luxcuVKAGUrYYcMGeL23J07d6JTp06IiIiARqNBs2bNMG7cOGzYsAEhNF2RiIiIJBYSq1MNBgNycnIAAA0bNnTbtl69eoiIiEBpaSkuXLhQo/u6KxPSpEkTfPnll1XOoTtz5kyFz8+ePYuzZ89izZo16NOnD1avXo0GDRpUGYvRaITRaHR8XlRU5MFXQERERMEqJHriiouLHY89KRtin7NWUlIieSwKhQIvvvgiDh8+jGuuucZlO5VKheHDh+P999/H9u3bcfDgQfz888949dVX0ahRIwDAL7/8ghtvvNFl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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "attack_mn = np.mean(attack_pshuff, axis = 1)\n",
    "attack_st = np.std(attack_pshuff, axis = 1)\n",
    "plt.semilogx(delta_vals, attack_mn, '-o', color = 'black')\n",
    "plt.fill_between(delta_vals, attack_mn + attack_st, attack_mn - attack_st, alpha = 0.2)\n",
    "plt.semilogx(delta_vals, np.ones(len(delta_vals))*len(vuln_k_LDP) / len(X), '--', color = 'tomato', alpha = 0.2)\n",
    "plt.semilogx(delta_vals, np.ones(len(delta_vals))*len(vuln_k_shuff) / len(X), '--', color = 'seagreen', alpha = 0.2)\n",
    "plt.xlabel(\"width\")\n",
    "plt.ylabel(\"Pct. Inferred, $\\\\rho$\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./attack_twitch_mean.npy', attack_mn)\n",
    "np.save('./attack_twitch_std.npy', attack_st)\n",
    "np.save('./twitch_widths.npy', delta_vals)\n",
    "np.save('./attack_twitch_LDP.npy', np.ones(len(delta_vals))*len(vuln_k_LDP) / len(X))\n",
    "np.save('./attack_twitch_Unif.npy', np.ones(len(delta_vals))*len(vuln_k_shuff) / len(X))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Calibration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LDP TV: 0.07140548241550898\n",
      "Unif. shuff. TV: 0.14892807141524453\n",
      "Oblivious TV: 0.2019650148424171\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-169-16c71ebeb1a2>:32: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for trial in tqdm(range(n_trials)):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "562cdc3e127d4e2aadb9f708e7e2d9d9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Get LDP utility:\n",
    "\n",
    "delta_vals = np.logspace(-2, np.log10(5000), 40)[15:32]\n",
    "\n",
    "set_plot_defaults()\n",
    "r_vals = np.arange(6)\n",
    "r_vals[0] = 0.01\n",
    "\n",
    "R_calib = 2\n",
    "\n",
    "lr = 0.01\n",
    "\n",
    "LDP_TV = get_calibration_TVD(Y[:,0], X, Distmat, R_calib)\n",
    "\n",
    "print('LDP TV:', LDP_TV)\n",
    "\n",
    "Y_unishuffle_idx = np.arange(len(Y[:,0]))\n",
    "np.random.shuffle(Y_unishuffle_idx)\n",
    "Y_unishuffle = Y[Y_unishuffle_idx,0]\n",
    "\n",
    "Unif_shuff_TV = get_calibration_TVD(Y_unishuffle, X, Distmat, R_calib)\n",
    "\n",
    "print('Unif. shuff. TV:', Unif_shuff_TV)\n",
    "\n",
    "oblivious = np.ones((len(X))) * 0.5\n",
    "oblivious_TV = get_calibration_TVD(oblivious, X, Distmat, R_calib).mean()\n",
    "print('Oblivious TV:', oblivious_TV)\n",
    "\n",
    "d_shuff_TV = np.zeros((len(delta_vals), n_trials))\n",
    "r = 1\n",
    "n_trials = 10\n",
    "for trial in tqdm(range(n_trials)): \n",
    "    for D in delta_vals: \n",
    "        ref_perm = np.load('./permutations_experiment/sigma0_R{:.3f}.npy'.format(r))\n",
    "        samp_perm = np.load('./permutations_experiment/sigmasamp_D{0:.3f}_n{1:n}.npy'.format(D, trial))\n",
    "        Y_shuffle = Y[samp_perm[np.argsort(ref_perm)], 0]\n",
    "\n",
    "        d_shuff_TV[delta_vals == D, trial] = get_calibration_TVD(Y_shuffle, X, Distmat, R_calib)\n",
    "    \n",
    "# print('AUC:', np.trapz(r_shuff_TV/oblivious_TV, r_vals))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ut_mn = (d_shuff_TV / oblivious_TV).mean(axis = 1)\n",
    "ut_st = (d_shuff_TV / oblivious_TV).std(axis = 1)\n",
    "\n",
    "plt.semilogx(delta_vals, ut_mn, '-o', label = \"Mallows\", color = 'black')\n",
    "plt.fill_between(delta_vals, ut_mn - ut_st, ut_mn + ut_st, alpha = 0.2)\n",
    "plt.semilogx(delta_vals, np.ones(len(delta_vals))*LDP_TV/oblivious_TV, '--', label = \"LDP\", color = 'tomato', alpha = 0.5)\n",
    "plt.semilogx(delta_vals, np.ones(len(delta_vals))*Unif_shuff_TV/oblivious_TV,'--', label = \"Unif.\", color = 'seagreen', alpha = 0.5)\n",
    "plt.legend(loc = 'lower right')\n",
    "plt.xlabel('width')\n",
    "plt.ylabel('Ave TV')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./utility_twitch_mean.npy', ut_mn)\n",
    "np.save('./utility_twitch_std.npy', ut_st)\n",
    "np.save('./utility_twitch_LDP.npy', np.ones(len(delta_vals))*LDP_TV/oblivious_TV)\n",
    "np.save('./utility_twitch_Unif.npy', np.ones(len(delta_vals))*Unif_shuff_TV/oblivious_TV)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
