{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "https://www.dshs.state.tx.us/THCIC/Hospitals/Download.shtm\n",
    "\n",
    "# Necessary packages and functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\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\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\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim \n",
    "import torchbnn as bnn\n",
    "from torch.utils.data import DataLoader, TensorDataset\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 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 knn_attack(T_i, T_neighb, Y_neighb, K=10):\n",
    "\n",
    "    feat_idxs = [\n",
    "      T_cols == 'PAT_AGE',\n",
    "      T_cols == 'TOTAL_CHARGES',\n",
    "      T_cols == 'ADMIT_WEEKDAY',\n",
    "      T_cols == 'LENGTH_OF_STAY',\n",
    "      (T_cols == 'KM_LAT')|(T_cols == 'KM_LON'),\n",
    "      (T_cols == 'TYPE_OF_ADMISSION_1') | (T_cols == 'TYPE_OF_ADMISSION_2') |\n",
    "      (T_cols == 'TYPE_OF_ADMISSION_3') | (T_cols == 'TYPE_OF_ADMISSION_5'),\n",
    "      (T_cols == 'SEX_CODE_F') | (T_cols == 'SEX_CODE_M')\n",
    "      ]\n",
    "    feat_names = [\n",
    "      'age',\n",
    "      'charges',\n",
    "      'weekday',\n",
    "      'length of stay',  \n",
    "      'location',  \n",
    "      'type of admission',\n",
    "      'gender'\n",
    "    ]\n",
    "    \n",
    "    if T_neighb.shape[0] < K: \n",
    "        K = T_neighb.shape[0]\n",
    "\n",
    "    #make prediction for each feature KNN clf \n",
    "    predictions = np.zeros(len(feat_idxs) + 1, dtype = int)\n",
    "        \n",
    "    for i in range(len(feat_idxs)): \n",
    "        clf = KNC(n_neighbors=K) #NN model \n",
    "        clf.fit(T_neighb[:,feat_idxs[i]], Y_neighb)\n",
    "        predictions[i] = clf.predict(T_i[feat_idxs[i]][None, :])\n",
    "\n",
    "    #make ensemble prediction: \n",
    "    predictions[-1] = np.argmax(np.bincount(predictions))\n",
    "    \n",
    "    return predictions\n",
    "\n",
    "  \n",
    "def shuffle_dataset(labels, alpha, Deltas, sig0): \n",
    "    labels_shuff = np.zeros(len(labels))\n",
    "    for sig0_, Delta in zip(sig0, Deltas): \n",
    "        labels_ = labels[sig0_]\n",
    "        if Delta > 1: \n",
    "            theta = 2 * alpha / (Delta * (Delta - 1))\n",
    "            shff_ = shuffle_graph(labels_, theta, np.argsort(np.argsort(sig0_)))\n",
    "        else: \n",
    "            shff_ = labels_\n",
    "      \n",
    "        labels_shuff[sig0_] = shff_.squeeze()\n",
    "    return labels_shuff\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 shuffle_graph(labels, theta = 0, sig0_ = np.array([])): \n",
    "    n_pts = len(labels)\n",
    "    if sig0_.size == 0: \n",
    "        sig0_ = np.arange(n_pts)\n",
    "    sig = mallows(theta = theta, sig0 = sig0_)[np.argsort(sig0_)]\n",
    "    return labels[sig]\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",
    "def county_error(labels, T, T_cols, X): \n",
    "    cnty = T_cols == 'COUNTY'\n",
    "    counties = np.unique(T[:,cnty])\n",
    "    count_diffs = []\n",
    "    for county in counties: \n",
    "        cnty_idx = (T[:,cnty] == county).squeeze()\n",
    "        label_cts = np.zeros(4)\n",
    "        label_cty = labels[cnty_idx]\n",
    "        label_bcts = np.bincount(label_cty.astype(int))\n",
    "        label_cts[0:len(label_bcts)] = label_bcts\n",
    "\n",
    "        true_cts = np.zeros(4)\n",
    "        true_cty = X[cnty_idx]\n",
    "        true_bcts = np.bincount(true_cty.astype(int))\n",
    "        true_cts[0:len(true_bcts)] = true_bcts\n",
    "\n",
    "        count_diffs.append( np.abs(label_cts - true_cts).sum()/np.sum(true_cts) )\n",
    "        \n",
    "    return np.asarray(count_diffs)\n",
    "  \n",
    "def get_calibration_TVD(y_vals, x_vals, Distmat, R_calib, T_locat, cv,\n",
    "                        base_clf = RFC()):\n",
    "    #Train calib model on noisy data, and predict\n",
    "#     base_clf = RFC(min_samples_leaf=min_samples_leaf)\n",
    "    calib = CCCV(base_estimator=base_clf, cv=cv)\n",
    "    calib.fit(T_locat, y_vals)\n",
    "    calib_hists = calib.predict_proba(T_locat)\n",
    "\n",
    "#     #Get calibration neighbors \n",
    "#     N = Distmat <= R_calib\n",
    "#     #Get calibration hists\n",
    "#     tgt_hists = np.zeros((len(x_vals), 4))\n",
    "#     for i in range(len(x_vals)): \n",
    "#         neighb_idx = N[i,:]\n",
    "#         labels = x_vals[neighb_idx]\n",
    "#         hist = np.zeros(4)\n",
    "#         hist_cts = np.bincount(labels)\n",
    "#         hist[:len(hist_cts)] = hist_cts / len(labels)\n",
    "#         tgt_hists[i,:] = hist\n",
    "\n",
    "#     #total variation distance is half sum of difference across label probs\n",
    "#     TV = np.abs(calib_hists - tgt_hists).sum(axis = 1)\n",
    "\n",
    "    TV = get_TVD(calib_hists, Distmat, R_calib, T_locat, x_vals)\n",
    "    return TV\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), 4))\n",
    "    for i in range(len(x_vals)): \n",
    "        neighb_idx = N[i,:]\n",
    "        labels = x_vals[neighb_idx]\n",
    "        hist = np.zeros(4)\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "set_plot_defaults()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "#get data:\n",
    "#as reminder of X codes: \n",
    "#0) CHARITY/INDIGENT\n",
    "#1) MEDICARE\n",
    "#2) MEDICAID/GOVT PRGRM (VA/CHAMPUS/nonfederal)\n",
    "#3) COMMERCIAL INSRNC/POS/PPO/HMO/Workers Comp/Automobile/indemnity/EPO\n",
    "\n",
    "np.random.seed(seed = 0)\n",
    "\n",
    "T_tr = np.load('./X_tr_lg_county.npy')\n",
    "X_tr = np.load('./Y_tr_lg_county.npy')\n",
    "T_te = np.load('./X_te_lg_county.npy')\n",
    "X_te = np.load('./Y_te_lg_county.npy')\n",
    "\n",
    "T_cols = np.load('./featnames_lg_county.npy', allow_pickle=True)\n",
    "\n",
    "\n",
    "X = np.concatenate((X_tr, X_te), axis = 0)\n",
    "T = np.concatenate((T_tr, T_te), axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmUAAAGrCAYAAACBheB+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA/70lEQVR4nO3de1RVdd7H8Q+IXI/gBbMhmPFC4GmaeXKFpA8m2mRNoiFM+tg0pjOGOaOWTWLZWOmaMbyVpjNpKI42Y5SV2pN4aTLvQoramI6YmD6Kri42CHIRPHGeP1jsOXguYKJnC+/XWqz1g99vf/eP01ny6ffbZ28fu91uFwAAALzK19sTAAAAAKEMAADAFAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAAT8PP2BNB4NTU1Onv2rNq0aSMfHx9vTwcAADSC3W7XhQsXFBERIV9f9+thhLIbyNmzZxUVFeXtaQAAgO/h9OnTioyMdNtPKLuBtGnTRlLtf9TQ0FAvzwYAADRGaWmpoqKijL/j7hDKbiB1W5ahoaGEMgAAbjANXXrEhf4AAAAmQCgDAAAwAUIZAACACRDKAAAATIBQBgAAYAKEMgAAABMglAEAAJgAoQwAAMAECGUAAAAmQCgDAAAwAUIZAACACRDKAAAATIBQBgAAYAKEMgAAABPw8/YEYA6dn83x9hSu2MmZSd6eAgAATeZ7rZR9/fXXWrdunV544QU98MADCg8Pl4+Pj3x8fDRq1Kgrrrdx40alpqYqMjJSAQEBioyMVGpqqjZu3NjoGhUVFZozZ47i4+PVvn17WSwWWa1WTZo0SadOnWp0ncOHD2vs2LGKjo5WUFCQOnbsqL59++r111+XzWZrdJ233npL999/v37wgx8oMDBQnTt31ogRI5SXl9foGgAAoOXwsdvt9is+yMfHbd/IkSO1fPnyRtWx2+0aO3asMjMz3Y4ZM2aMFi9e7PGcx48fV1JSko4ePeqyPywsTG+++aYGDhzocT5ZWVkaN26cqqqqXPb36tVL69atU4cOHdzWuHjxooYOHap169a57Pf19dW0adP0/PPPe5yLK6WlpQoLC1NJSYlCQ0Ov+HhPWCkDAODaaOzf76u+piwqKkr33Xff9zp26tSpRiDr0aOHsrOztWfPHmVnZ6tHjx6SpMzMTI8BpqysTIMGDTICWVpamjZv3qzdu3drxowZslgsKikp0dChQ3Xw4EG3dTZt2qQxY8aoqqpKnTp10oIFC/TJJ59ow4YNSk1NlSTl5eUpNTVVNTU1buuMHj3aCGT9+/fX2rVrtWfPHmVlZalbt26qqanRCy+8oKVLl17ZiwUAAJq177VS9uKLL6pnz57q2bOnOnXqpJMnT6pLly6SGr9SVlhYKKvVKpvNpri4OG3fvl1BQUFGf0VFhRITE5Wfny8/Pz8VFBSoW7duTnWmTZum6dOnS5Jmz56t9PT0ev25ubnq27evbDab+vfvr48//tiphs1mk9VqVWFhoUJDQ7V//36nc40bN06vvfaaJGnFihV69NFHneps27ZN/fr1kyQNHjxYa9asUatWrYz+c+fO6c4779SpU6fUrl07ffHFF2rbtm2Dr1UdVsrqY6UMAHAjuKYrZdOnT9egQYPUqVOn7z3BefPmGddoLVy4sF4gk6Tg4GAtXLhQUm1omj9/vlONS5cu6dVXX5UkWa1WPf30005jevfurdGjR0uStmzZon379jmNWbNmjQoLCyVJU6ZMcRn+5syZo3bt2hltV2bPni1JatWqlV577bV6gUySwsPDNWvWLElScXGxsrKyXNYBAAAtj1duiWG32/X+++9Lkrp3765evXq5HNerVy/FxsZKktauXavLF/W2bt2q8+fPS6pdofP1df3rOH74YPXq1U79a9eudTnWUXBwsIYNGyZJOnTokI4dO1avv6ysTJs3b5YkDRgwQJGRkS7rpKamGinZ1VwAAEDL5JVQduLECZ05c0aSlJiY6HFsXX9RUZFOnjxZr2/Hjh1O41yJi4tTSEiIJGnnzp1O/XV1YmNjdfPNNzc4F1d19uzZY3xAwNNc/P39jRC6Z88eXbp0ye1YAADQcngllB05csRod+/e3eNYx37H466kjp+fn7EleXmNsrIyFRUVXbe5OPbbbDanFTcAANAyeSWUnT592mi72+arExUV5fI4x+9DQkIavGC+rs4333xT75YXRUVFxrZoU8zlausAAICWySt39L9w4YLRtlgsHsfWbTtKtataruo0VMNVnYCAgGsyl6ut46iqqqpegCwtLfVYFwAA3Li8slJ28eJFo+3v7+9xbF14kqTKykqXdRqq4alOU8/laus4ysjIUFhYmPHluMIGAACaF6+EssDAQKNdXV3tcazjStHl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fPlyo+1qa3XIkCEuxzqqqKjQqlWrJNWu0MXExLgcBwAAWhavhbLq6mqlpKRo165dkqQnn3xSf/rTn664zsSJE+XnV/t5hQkTJjjdYqKyslITJkyQVHtH/okTJzrV8Pf31xNPPCGp9g77c+fOdRqTm5urrKwsSbWPSerZs6fTmJSUFOOO/xkZGS6f15menq7i4mKjDQAAIHnx05cPP/ywPvzwQ0nSPffco9GjR+vQoUNux/v7+7tcVYqJidGkSZM0c+ZM5efnKyEhQc8884y6deum48ePa9asWTpw4ICk2hB06623uqyfnp6ut99+W59//rkmT56swsJCDR8+XEFBQdqyZYteeukl2Ww2BQUFaf78+S5rtG7dWgsWLNDgwYNVWlqqhIQETZ06VfHx8SouLtaSJUv03nvvSard6hwxYsSVvGQAAKAZ87G726u71ie+bAuxIT/60Y+cHiRep6amRmlpaVq2bJnb40ePHq3MzEyXDzavU1hYqIEDB+rYsWMu+0NDQ7Vy5UoNGjTI41yXLFmi8ePHu71fWXx8vHJychQeHu6xzuVKS0sVFhamkpIShYaGXtGxDen8bE6T1rseTs5M8vYUWgzeH3CH9wbc4b3xH439++31C/2bgq+vr7KyspSTk6Pk5GRFRETI399fERERSk5O1vr167V06VKPgUySoqOjdeDAAc2aNUtxcXFq27atgoODFRsbq6eeekoHDx5sMJBJUlpamvbt26e0tDR17dpVgYGB6tChg/r06aNFixZp165dVxzIAABA8+a17ctrsUA3cOBADRw48KpqhISEaPLkyZo8efJV1bn99tuVmZl5VTUAAEDL0SxWygAAAG50hDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQyq6RU6dOadKkSbJarQoJCVH79u0VHx+vuXPnqqKiwtvTAwAAJuPn7Qk0Rzk5OXrkkUdUUlJi/KyiokJ79+7V3r17tXTpUq1fv15du3b14iwBAICZsFLWxP75z39q2LBhKikpkcVi0YwZM7R7925t3rxZaWlpkqSjR48qKSlJZWVlXp4tAAAwC1bKmtjEiRNVUVEhPz8/ffjhh+rdu7fRd8899+jWW2/V5MmTVVBQoFdeeUUvvPCCF2cLAADMgpWyJrR3715t3bpVkjR69Oh6gazO008/LavVKkmaP3++Ll26dD2nCAAATIpQ1oTWrl1rtH/961+7HOPr66tHH31UklRcXGyEOAAA0LIRyprQjh07JEkhISG688473Y5LTEw02jt37rzm8wIAAOZHKGtCR44ckSRFR0fLz8/95Xrdu3d3OgYAALRsXOjfRC5evKhz585JkiIjIz2ObdeunUJCQlReXq7Tp0+7HVdVVaWqqirj+7pbbJSWljbBjOurqbrx7p12LV4HuMb7A+7w3oA7vDec69rtdo/jCGVN5MKFC0bbYrE0OL4ulHm6LUZGRoamT5/u9POoqKjvN8lmJmy+t2cAM+P9AXd4b8Cda/3euHDhgsLCwtz2E8qayMWLF422v79/g+MDAgIkSZWVlW7HTJkyRb///e+N72tqavTvf/9bHTp0kI+Pz1XMtr7S0lJFRUXp9OnTCg0NbbK6AO8tXAu8r3AtXMv3ld1u14ULFxQREeFxHKGsiQQGBhrt6urqBsfXbUsGBQW5HRMQEGCEtzpt27b9fhNshNDQUP6BwzXBewvXAu8rXAvX6n3laYWsDhf6N5E2bdoY7cbcqb+8vFxS47Y6AQBA80coayKBgYEKDw+XJBUVFXkcW1xcbIQyrg8DAAASoaxJ1d2pv7CwUDabze24goICp2O8KSAgQC+++KLTVilwtXhv4VrgfYVrwQzvKx97Q5/PRKM999xzysjIkCTl5eXprrvucjlu5syZmjJliiRp06ZNuu+++67bHAEAgDmxUtaEhgwZYrT/+te/uhxTU1OjN954Q1LtRfv9+/e/HlMDAAAmRyhrQvHx8br77rslSVlZWcrNzXUa8/LLLxt38X/yySfVunXr6zpHAABgTmxfNrEDBw4oISFBlZWVslgseu6559S/f39VVlbqrbfeUmZmpiQpJiZG+fn59T61CQAAWi5C2TXwwQcf6Fe/+pXbxzXExMQoJydH0dHR13lmAADArNi+vAYGDx6sgwcP6qmnnlJMTIyCg4PVtm1bxcXFadasWTpw4IApAtmpU6c0adIkWa1WhYSEqH379oqPj9fcuXNVUXHjPbMM3vX1119r3bp1euGFF/TAAw8oPDxcPj4+8vHx0ahRo7w9Pdyg9u/fr5deekkPPPCAoqKiFBAQIIvFopiYGI0aNUo7duzw9hRxAyotLdVbb72lp59+WomJiYqOjlZYWJj8/f110003qV+/fpo9e7a+/fbb6zovVspaqJycHD3yyCPGQ84vFxsbq/Xr16tr167XeWa4UXl69NfIkSO1fPny6zcZNAuJiYnavn17g+NGjBihpUuXNuoRd4AkffTRRxowYECD48LDw/X3v/9d999//3WYFY9ZapH++c9/atiwYaqoqJDFYtGUKVPqXfe2ZMkSHT16VElJSdq7dy9PHcAVi4qKktVq1YcffujtqeAGdubMGUlSRESEhg4dqrvvvls//OEP9d133yk3N1cvv/yyzpw5o7/97W+y2Wx68803vTxj3EiioqLUv39/3XnnnYqKitIPfvAD1dTUqKioSO+++65Wr16tc+fO6cEHH9TevXv105/+9NpPyo4Wp1+/fnZJdj8/P/vu3bud+mfPnm2XZJdknz59uhdmiBvRCy+8YP/ggw/sX375pd1ut9tPnDhhvI9Gjhzp3cnhhpSUlGR/++237TabzWX/N998Y4+JiTHeZ9u3b7/OM8SNyt17ytGaNWuM91Zqaup1mJXdzvZlC7N3717Fx8dLkh5//HEtXrzYaUxNTY1uv/12HTlyRO3atdNXX33FrTtwxU6ePKkuXbpIYvsS1866des0ePBgSdITTzyhV1991cszQnNitVpVUFCg8PBwffPNN9f8fFzo38KsXbvWaP/61792OcbX11ePPvqopNrndG7duvU6zAwArly/fv2M9vHjx703ETRLISEhkqSLFy9el/MRylqYuk8qhYSE6M4773Q7LjEx0Wjv3Lnzms8LAL6P6upqo+3ry580NJ0jR47o008/lSR17979upyTd3ALU/c0gejoaPn5uf+ch+MbsO4YADCbbdu2Ge3r9YcTzVdFRYWOHTumV155Rf3799d3330nqfYJPNcDn75sQS5evKhz585JkiIjIz2ObdeunUJCQlReXq7Tp09fj+kBwBWpqanRzJkzje+HDRvmxdngRrV8+XK3l/NI0qRJk/TII49cl7kQylqQCxcuGO3G3OaiLpSVlZVdy2kBwPcyb9487dmzR5KUkpKiuLg4L88Izckdd9yhxYsX66677rpu52T7sgVxvFCxMTdZDAgIkCRVVlZeszkBwPexbds2Pfvss5Kkm266SYsWLfLyjHCjGjJkiD777DN99tln2rNnj7Kzs5WSkqJPP/1UjzzyiNatW3fd5kIoa0ECAwONtuPFse5UVVVJkoKCgq7ZnADgSh0+fFgpKSmy2WwKCAjQqlWr1KlTJ29PCzeotm3b6vbbb9ftt9+unj17avjw4Vq9erXeeOMNffHFF0pOTr5ut/QhlLUgbdq0MdqN2ZIsLy+X1LitTgC4Hk6cOKH77rtPxcXFatWqlbKzs+t9WhxoKiNGjNDQoUNVU1Oj8ePHq7i4+Jqfk1DWggQGBio8PFySVFRU5HFscXGxEcqioqKu+dwAoCFnz57Vvffeq7Nnz8rHx0fLli1TSkqKt6eFZiw5OVlS7SLFhg0brvn5CGUtjNVqlSQVFhbKZrO5HVdQUOB0DAB4y7lz5zRgwAB98cUXkqSFCxcaN7kGrpWOHTsa7f/7v/+75ucjlLUwffr0kVSb+vft2+d2nOO9fxISEq75vADAnZKSEt1///3617/+JUmaOXOmxo0b5+VZoSU4c+aM0b4el/IQylqYIUOGGO2//vWvLsfU1NTojTfekFR7AWT//v2vx9QAwElFRYWSkpK0f/9+SdIf/vAHPfPMM16eFVqKd955x2j/5Cc/uebnI5S1MPHx8br77rslSVlZWcrNzXUa8/LLLxt38X/yySd5GDkAr6iurlZKSop27dolqfbfoz/96U9enhWag+XLlzf4PMt58+Zp/fr1kqTOnTsbO03Xko/dbrdf87PAVA4cOKCEhARVVlbKYrHoueeeU//+/VVZWam33npLmZmZkqSYmBjl5+fX+9Qm4M7OnTtVWFhofH/u3Dmlp6dLqt0Cf+yxx+qNHzVq1PWcHm5Av/jFL7R69WpJ0j333KP58+fLx8fH7Xh/f3/FxMRcr+nhBta5c2dduHBBv/jFL9SnTx9169ZNFotFFy5c0GeffaaVK1ca/zPg7++vnJwc3Xvvvdd8XoSyFuqDDz7Qr371K5WWlrrsj4mJUU5OjqKjo6/zzHCjGjVqlFasWNHo8fzTg4Z4CmCu/OhHP9LJkyevzWTQrHTu3LlRF+5HRkZq2bJlGjBgwHWYFY9ZarEGDx6sgwcP6tVXX1VOTo6Kiork7++v6OhoDR06VOPHj1dwcLC3pwkAQJPbvHmzPvroI23ZskVHjhzRV199pW+//VaBgYHq1KmT7rjjDg0aNEjDhg27rn8LWSkDAAAwAS70BwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABAhlAAAAJkAoAwAAMAFCGQAAgAkQygAAAEyAUAYAAGAChDIAAAATIJQBAACYAKEMAADABP4fiSo2cdar+04AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(X)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "prob of flip: 0.19759599495081878\n",
      "Frac unperturbed 0.8032615513276187\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 = 2.5).squeeze()\n",
    "print('Frac unperturbed', np.mean( Y[:,0] == X) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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nm5tD7qaMWOGioqKrDYAAICTn93bso4P+fn5uuOOO1ReXi5JGj58uMaOHasePXro0qVLysnJ0eLFi3X69GlJ0n/913/p448/dqsza9YszZ07V5LjeqwnnnhCPXv21IkTJzRv3jwdOnTIGvfCCy94nEtpaani4uL0r3/9S5I0YcIEjR49WsHBwdq2bZteeOEFXbx4UcHBwdq7d69uv/12j3U2btyo4cOHq7q6Wl27dtXTTz+t+Ph4FRUV6fXXX9f7778vybE9uH37drVp06bev6+SkhJFRESouLj4qnzir9uTWY1e82o7NTepuacAAIBPDfn7fUWBSpI+/vhjPfjggzp//rzPcXfffbfee+89dejQwa2vurpaaWlpWrFihdfjx48fr4yMDPn7e19MKygo0NChQ3X8+HGP/eHh4XrzzTfdVslqe/311zV58mSv96OKj49XVlaWOnfu7LNObQQqdwQqAMC1rkkClSR9++23yszM1KZNm3T06FFduHBBAQEBuummm9SvXz/9z//8jx544AG3a59q27hxozIyMrR//36dP39enTt3Vr9+/fTII4/o/vvvr9dcysrK9Oc//1nvvvuuCgoKVFVVpejoaA0dOlSPPfaYfvCDH9SrzpEjR7RkyRJt3bpV586dU2hoqGJjY/XQQw/p17/+dY2L6+uLQOWOQAUAuNY1WaBC/RCo3BGoAADXuob8/b7iZ/kBAADAgUAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgKKC5JwAAAK4t3Z7Mau4pNNipuUnN+v6sUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgiUAEAABgyDlTnz5/X/PnzlZCQoJtuuklBQUGKjIzUnXfe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MdnZ2crMzJTkeHRMv3793MakpKRYD0ROT0/3uPI2Y8YMFRUVWW0AAACnBgcqSZo9e7a+//3vS5LGjBmjKVOmaNu2bTpw4IBWrlyp+Ph4ffbZZ5Kk3/zmNx5DTExMjKZPny7JsSWXkJCgd955R7m5uXrnnXeUkJCg3NxcSY4Ac8stt3icy4wZM6zVopkzZ+qRRx7Rtm3blJOTo/T0dN13332y2WwKDg7W4sWLPda44YYbtGTJEvn7+6ukpEQJCQn605/+pH379mnLli36+c9/rldeeUWSY3twzJgxV/JrAwAA1yk/u7d9sjrk5eXpgQceUEFBgdcxv/rVr7Rs2TJri7C26upqpaWlacWKFV5rjB8/XhkZGfL39579CgoKNHToUB0/ftxjf3h4uN58800NGzbMaw1Jev311zV58mSv96OKj49XVlaWOnfu7LNObSUlJYqIiFBxcfFVuScVz2uDN5wb8IZzA75wfjg05O/3Fa1QSY5PuX322WdasGCB7rzzTnXs2FGBgYGKiorSf//3f+uTTz5RZmam1zAlOW4AmpmZqaysLCUnJysyMlKBgYGKjIxUcnKyNm7cqOXLl/sMU5LUq1cvHTp0SPPmzVNcXJzat2+vkJAQ9e7dW48//rgOHz5cZ5iSpLS0NB04cEBpaWnq0aOH2rZtq06dOmngwIF69dVXtWfPngaHKQAAcP274hUq1B8rVO74P82mwbkBbzg34Avnh0OTrFABAADAgUAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgiEAFAABgqFED1cyZM+Xn52d9bd++vc5jNm/erNTUVEVFRSkoKEhRUVFKTU3V5s2b6/2+5eXlWrBggeLj49WxY0eFhYUpNjZW06dP1+nTp+td5+jRo5o4caJ69eql4OBgdenSRYMGDdJrr70mm81W7zoAAKB1CWisQv/4xz+0aNGieo+32+2aOHGiMjIyarx+9uxZrVu3TuvWrdOECRO0bNky+fn5ea1z4sQJJSUl6dixYzVez8/PV35+vpYvX6633npLQ4cO9TmfzMxMTZo0SZWVldZrly5d0q5du7Rr1y6tXLlSGzZsUKdOner9MwIAgNahUVaoqqurlZaWJpvNphtvvLFexzz99NNWmOrbt69Wr16tffv2afXq1erbt68kKSMjQ88884zXGhcvXtSwYcOsMJWWlqatW7dq7969mjNnjsLCwlRcXKyRI0fq8OHDXuts2bJFEyZMUGVlpbp27aolS5bo008/1aZNm5SamipJysnJUWpqqqqrq+v18wEAgNajUQLVkiVLtH//fvXp00fjx4+vc3xBQYHmz58vSYqLi9OePXs0evRo9evXT6NHj9bu3bsVFxcnSZo3b55OnDjhsc7ChQuVn58vSZo/f74yMjJ09913a8CAAXrqqaf00UcfKSAgQOXl5Zo6darHGjabTZMnT1Z1dbXCw8O1Z88eTZkyRfHx8frpT3+q999/X7/97W8lSTt37tTf/va3hv56AADAdc44UJ05c8ZaRXr11VcVGBhY5zGLFi2yrklaunSpgoODa/SHhIRo6dKlkhyBZ/HixW41Ll++rJdfflmSFBsbq2nTprmNGTBggBXwtm3bpgMHDriNWbdunQoKCiRJs2bNUs+ePd3GLFiwQB06dLDaAAAArowD1W9/+1tdvHhRY8eO1eDBg+scb7fb9cEHH0iS+vTpo/79+3sc179/f/Xu3VuStH79etnt9hr927dv14ULFyRJY8eOlb+/5x9l3LhxVnvt2rVu/evXr/c41lVISIhGjRolSTpy5IiOHz/ucRwAAGidjALVmjVrtGHDBnXs2LHeKzcnT57U2bNnJUmJiYk+xzr7CwsLderUqRp9u3btchvnSVxcnEJDQyVJu3fvdut31undu7duuummOufirQ4AAGi9rjhQXbhwQY899pgkx3VOXbp0qddxeXl5VrtPnz4+x7r2ux7XkDoBAQHWNl7tGhcvXlRhYaHxXAAAQOt2xYFq5syZ+vLLL/X//t//q9eF6E5nzpyx2lFRUT7HRkdHezzO9fvQ0FC1b9++XnW++eabGrdFKCwstLYSTeYCAABatyu6D9Xu3bu1fPlyBQQE1HmfqNpKS0utdlhYmM+xzq06ybGa5KlOXTU81QkKCmrUudRWWVlZI7iVlJTUOUcAANByNXiFqqqqShMmTJDdbtfjjz+uH/3oRw06/tKlS1a7rk8EOoOPJFVUVHisU59PFXqr01hzqS09PV0RERHWl+vqFgAAuP40OFC98MILysvL0/e//30999xzDX7Dtm3bWu2qqiqfY11XeWrfWsFZp64avuo01lxqmzVrloqLi60vtggBALi+NWjLLz8/X+np6ZIc949y3Qarr3bt2lnturbOysrKrHbtLTlnnbpq+KrTWHOpLSgoqMaKFgAAuL41KFAtWrRIVVVV6tGjh8rLy/X222+7jTly5IjV/uSTT/Tll19KkoYPH67Q0NAaF387P2HnjevKTu1ts6ioKH366acqKyvThQsXfF6Y7qzTpUuXGkGnseYCAABatwYFKue21xdffKEHH3ywzvF/+MMfrPbJkycVGhqqW2+91XrN+dgYb1z7Y2Nja/Tdeuutev/9961x3m4QarPZrEfX1K4RFham6OhonTlzxmguAACgdWuUZ/k1RPfu3RUZGSlJ2rFjh8+xO3fulCTdfPPN6tatW42+gQMHWm1fdXJzc63tuoSEBLd+Z51jx45Zq2meuL6HpzoAAKD1alCgWrlypex2u88v1wvVt23bZr3uDER+fn5KTk6W5Fj1ycnJ8fheOTk51qpQcnKy260ZBg8erIiICEnSqlWr3B5N4zpnp5SUFLf+ESNGeBzrqry8XGvWrJHkWBmLiYnxOA4AALROTb5CJUlTp05VQIBjt3HKlClutyGoqKjQlClTJDnudD516lS3GoGBgXr00UclOe5cvnDhQrcx2dnZyszMlOR4dEy/fv3cxqSkpFh3Uk9PT7e2B13NmDFDRUVFVhsAAMBVswSqmJgYTZ8+XZJjSy4hIUHvvPOOcnNz9c477yghIUG5ubmSHAHmlltu8VhnxowZ1mrRzJkz9cgjj2jbtm3KyclRenq67rvvPtlsNgUHB2vx4sUea9xwww1asmSJ/P39VVJSooSEBP3pT3/Svn37tGXLFv385z/XK6+8IsmxPThmzJhG/m0AAICW7orulN4Y5syZo6+//lorVqzQoUOH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f2VmZiorK0vJycmKjIxUYGCgIiMjlZycrI0bN2r58uU+w5Qk9erVS4cOHdK8efMUFxen9u3bKyQkRL1799bjjz+uw4cP1xmmJCktLU0HDhxQWlqaevToobZt26pTp04aOHCgXn31Ve3Zs6fBYQoAAFz/Grzl18AFrXoZOnSohg4dalQjNDRUM2fO1MyZM43q3HbbbcrIyDCqAQAAWpdmXaECAAC4HhCoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoPDh9+rSmT5+u2NhYhYaGqmPHjoqPj9fChQtVXl7e3NMDAADXmIDmnsC1JisrSw899JCKi4ut18rLy7V//37t379fy5cv18aNG9WjR49mnCUAALiWsELl4h//+IdGjRql4uJihYWFac6cOdq7d6+2bt2qtLQ0SdKxY8eUlJSkixcvNvNsAQDAtYIVKhdTp05VeXm5AgIC9NFHH2nAgAFW3913361bbrlFM2fOVH5+vl566SU9++yzzThbAABwrWCF6j/279+v7du3S5LGjx9fI0w5TZs2TbGxsZKkxYsX6/Lly005RQAAcI0iUP3H+vXrrfYvf/lLj2P8/f318MMPS5KKioqsAAYAAFo3AtV/7Nq1S5IUGhqqO+64w+u4xMREq7179+6rPi8AAHDtI1D9R15eniSpV69eCgjwfmlZnz593I4BAACtGxelS7p06ZLOnz8vSYqKivI5tkOHDgoNDVVZWZnOnDnjcUxlZaUqKyut7523YCgpKWmkGddUXdny7o11tX4XqIlzA95wbsAXzo+aNe12e51jCVSSSktLrXZYWFid452BytutE9LT0zV79my316Ojo698kteZiMXNPQNcqzg34A3nBny5mudHaWmpIiIifI4hUMmxQuUUGBhY5/igoCBJUkVFhcf+WbNm6Xe/+531fXV1tf7973+rU6dO8vPzM5xtTSUlJYqOjtaZM2cUHh7eqLXRenFe4WrgvMLVcrXOLbvdrtLSUkVGRtY5lkAlqW3btla7qqqqzvHO7bzg4GCP/UFBQVbocmrfvv2VT7AewsPD+QcKjY7zClcD5xWulqtxbtW1MuXERemS2rVrZ7Xrcwf0srIySfXbHgQAANc/ApUcK1SdO3eWJBUWFvocW1RUZAUqrokCAAASgcrivAN6QUGBbDab13H5+fluxzSnoKAgPffcc25bjIAJzitcDZxXuFquhXPLz16fzwK2Ak899ZTS09MlSTk5Obrzzjs9jps7d65mzZolSdqyZYvuu+++JpsjAAC4NrFC9R8jRoyw2n/5y188jqmurtYbb7whyXGR+ZAhQ5piagAA4BpHoPqP+Ph43XXXXZKkzMxMZWdnu4158cUXrbujP/bYY7rhhhuadI4AAODaxJafi0OHDikhIUEVFRUKCwvTU089pSFDhqiiokJvv/22MjIyJEkxMTHKzc2t8elAAADQehGoavnwww/1i1/8wust7GNiYpSVlaVevXo18cwAAMC1ii2/WoYPH67Dhw/r8ccfV0xMjEJCQtS+fXvFxcVp3rx5OnTo0DURpk6fPq3p06crNjZWoaGh6tixo+Lj47Vw4UKVl7e8ZzCh+Xz99dfasGGDnn32Wd1///3q3Lmz/Pz85Ofnp3HjxjX39NCCHTx4UC+88ILuv/9+RUdHKygoSGFhYYqJidG4ceO0a9eu5p4iWpiSkhK9/fbbmjZtmhITE9WrVy9FREQoMDBQN954owYPHqz58+fr22+/bfK5sULVAmVlZemhhx6yHrpcW+/evbVx40b16NGjiWeGlsjX45DGjh2rlStXNt1kcN1ITEzUzp076xw3ZswYLV++vF6P/QI+/vhj3XvvvXWO69y5s/72t7/pJz/5SRPMyoFHz7Qw//jHPzRq1CiVl5crLCxMs2bNqnGd1+uvv65jx44pKSlJ+/fv527uaJDo6GjFxsbqo48+au6poIU7e/asJCkyMlIjR47UXXfdpe9///v67rvvlJ2drRdffFFnz57VX//6V9lsNr311lvNPGO0FNHR0RoyZIjuuOMORUdH63vf+56qq6tVWFio9957T2vXrtX58+f1wAMPaP/+/frxj3/cNBOzo0UZPHiwXZI9ICDAvnfvXrf++fPn2yXZJdlnz57dDDNES/Pss8/aP/zwQ/uXX35pt9vt9pMnT1rn0NixY5t3cmixkpKS7O+8847dZrN57P/mm2/sMTEx1rm2c+fOJp4hWiJv55OrdevWWedVampqE8zKgS2/FmT//v2Kj4+XJD3yyCNatmyZ25jq6mrddtttysvLU4cOHfTVV19xewc0yKlTp9S9e3dJbPnh6tqwYYOGDx8uSXr00Uf18ssvN/OMcL2IjY1Vfn6+OnfurG+++aZJ3pOL0luQ9evXW+1f/vKXHsf4+/vr4YcfluR47uD27dubYGYA0HCDBw+22idOnGi+ieC6ExoaKkm6dOlSk70ngaoFcX4iJjQ0VHfccYfXcYmJiVZ79+7dV31eAHAlqqqqrLa/P3+O0Djy8vL02WefSZL69OnTZO/LGdyCOO/S3qtXLwUEeP88gesJ5DwGAK41O3bssNpN+YcP15/y8nIdP35cL730koYMGaLvvvtOkuOpJk2FT/m1EJcuXdL58+clSVFRUT7HdujQQaGhoSorK9OZM2eaYnoA0CDV1dWaO3eu9f2oUaOacTZoiVauXOn18hdJmj59uh566KEmmw+BqoUoLS212vW5FYIzUF28ePFqTgsArsiiRYu0b98+SVJKSori4uKaeUa4Xtx+++1atmyZ7rzzziZ9X7b8WgjXC+vqcwO8oKAgSVJFRcVVmxMAXIkdO3boySeflCTdeOONevXVV5t5RmiJRowYoc8//1yff/659u3bp9WrVyslJUWfffaZHnroIW3YsKFJ50OgaiHatm1rtV0v5PSmsrJSkhQcHHzV5gQADXX06FGlpKTIZrMpKChIa9asUdeuXZt7WmiB2rdvr9tuu0233Xab+vXrp9GjR2vt2rV644039MUXXyg5OblJb/tCoGoh2rVrZ7Xrs41XVlYmqX7bgwDQFE6ePKn77rtPRUVFatOmjVavXl3jU8lAYxgzZoxGjhyp6upqTZ48WUVFRU3yvgSqFqJt27bq3LmzJKmwsNDn2KKiIitQRUdHX/W5AUBdzp07p3vuuUfnzp2Tn5+fVqxYoZSUlOaeFq5TycnJkhyLC5s2bWqS9yRQtSCxsbGSpIKCAtlsNq/j8vPz3Y4BgOZy/vx53Xvvvfriiy8kSUuXLrVuQAxcDV26dLHa//u//9sk70mgakEGDhwoyZG4Dxw44HWc671dEhISrvq8AMCb4uJi/eQnP9E///lPSdLcuXM1adKkZp4VrnfOh3NLTXfpC4GqBRkxYoTV/stf/uJxTHV1td544w1Jjgv2hgwZ0hRTAwA35eXlSkpK0sGDByVJv//97/XEE08086zQGrz77rtW+0c/+lGTvCeBqgWJj4/XXXfdJUnKzMxUdna225gXX3zRujv6Y489xoORATSLqqoqpaSkaM+ePZIc/x798Y9/bOZZoaVbuXJlnc/nW7RokTZu3ChJ6tatm7W7c7X52e12e5O8ExrFoUOHlJCQoIqKCoWFhempp57SkCFDVFFRobffflsZGRmSpJiYGOXm5tb4dCDgye7du1VQUGB9f/78ec2YMUOSY8v417/+dY3x48aNa8rpoYX62c9+prVr10qS7r77bi1evFh+fn5exwcGBiomJqappocWqlu3biotLdXPfvYzDRw4UD179lRYWJhKS0v1+eef680337RCfGBgoLKysnTPPfc0ydwIVC3Qhx9+qF/84hcqKSnx2B8TE6OsrCz16tWriWeGlmjcuHFatWpVvcfzTwbqw1d48uQHP/iBTp06dXUmg+tGt27d6nWReVRUlFasWKF77723CWblwKNnWqDhw4fr8OHDevnll5WVlaXCwkIFBgaqV69eGjlypCZPnqyQkJDmniYAAI1q69at+vjjj7Vt2zbl5eXpq6++0rfffqu2bduqa9euuv322zVs2DCNGjWqyf8OskIFAABgiIvSAQAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADBGoAAAADP1/DVU03Yq5xrEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(Y[:,0])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Find groups $\\mathcal{G}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(28698, 2)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "T_locs = np.concatenate((T[:,T_cols == 'KM_LAT'], T[:,T_cols == 'KM_LON']), axis = 1)\n",
    "T_locs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "R = 20 #km\n",
    "Dx = T_locs[:,0][:,None] - T_locs[:,0][:,None].T\n",
    "Dy = T_locs[:,1][:,None] - T_locs[:,1][:,None].T\n",
    "Distmat = np.sqrt(Dx**2 + Dy**2)\n",
    "N = Distmat <= R #adjacency matrix of group graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3280\n",
      "1\n",
      "976.8793644156387\n",
      "771.0\n",
      "860.8677639871621\n"
     ]
    }
   ],
   "source": [
    "#neighbor statistics \n",
    "n_neighbs = np.sum(N, axis = 1)\n",
    "print(n_neighbs.max())\n",
    "print(n_neighbs.min())\n",
    "print(n_neighbs.mean())\n",
    "print(np.median(n_neighbs))\n",
    "print(np.std(n_neighbs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "#For each individual, \n",
    "#For each noisy sample, \n",
    "#Get predictions\n",
    "feat = 'TOTAL_CHARGES' #feature used to make NN prediction \n",
    "T_feat = T[:,T_cols == feat]\n",
    "Dmat = np.abs(T_feat - T_feat.T) #distance matrix of feature between individuals\n",
    "assert Dmat.shape[0] == Dmat.shape[1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate permutations for several trials and radii"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sample perms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-28-e88c3cf5d4d4>:14: 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": "e71f5885141c46968173dc470d740d9f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "r_vals = np.asarray([0., 10., 20., 30., 40., 50., 60., 70., 80.])\n",
    "n_trials = 10        \n",
    "alpha = 4\n",
    "\n",
    "print('get reference perms')\n",
    "sig0s = {}\n",
    "delts = {}\n",
    "for R in tqdm(r_vals): \n",
    "    sig0, Deltas = get_sig0(T_locs, R, Distmat, Distmat)\n",
    "    sig0s[R] = sig0\n",
    "    delts[R] = Deltas\n",
    "\n",
    "print('sample perms')\n",
    "for trial in tqdm(range(n_trials)): \n",
    "    for R in r_vals:\n",
    "        Deltas = delts[R]\n",
    "        sig0 = sig0s[R]\n",
    "        labels_pshuff, sig_full, sig0_full = shuffle_dataset_II(Y[:,0], alpha, \n",
    "                                                                Deltas, sig0)\n",
    "        np.save('./permutations_trials/sigmasamp_R{0:.3f}_n{1:n}'\\\n",
    "                .format(R, trial), sig_full)\n",
    "        \n",
    "    np.save('./permutations_trials/sigma0_R{0:.3f}_n{1:n}'\\\n",
    "                .format(R, trial), sig0_full)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "get reference perms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-35-13cdf8cc2e9c>:43: 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": "a5fdf875410b4f29a175df5c94314d88",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# r_vals = np.linspace(0, 1000, 5)\n",
    "r_vals = np.asarray([0., 10., 20., 30., 40., 50., 60., 70., 80.])\n",
    "n_trials = 10  \n",
    "\n",
    "shuff_idx = np.arange(Y.shape[0])\n",
    "np.random.shuffle(shuff_idx)\n",
    "Y_shuff = Y[shuff_idx, :]\n",
    "\n",
    "Rcorr = 20 #attack radius\n",
    "K = 20 \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",
    "\n",
    "\n",
    "R = 0.01 #Doesn't matter -- just for running LDP and uniform shuff, which only care abt R_corr\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",
    "n_trials = 10\n",
    "vuln_pshuff_trials = np.zeros((len(r_vals), n_trials))\n",
    "for trial in tqdm(range(n_trials)): \n",
    "    vuln_pshuff = {}\n",
    "    for R in r_vals: \n",
    "        sig0_full = np.load('./permutations_trials/sigma0_R{0:.3f}.npy'\\\n",
    "                .format(R, trial))\n",
    "        sig_full = np.load('./permutations_trials/sigmasamp_R{0:.3f}_n{1:n}.npy'\\\n",
    "                .format(R, trial))\n",
    "\n",
    "        Y_pshuff = Y[sig_full[np.argsort(sig0_full)], :]\n",
    "\n",
    "        vuln_k_pshuff, vuln_grp_pshuff = k_vs_grp_attack(X, Y_pshuff, Dmat, Distmat, \n",
    "                                                       R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "\n",
    "        vuln_pshuff_trials[r_vals == R, trial] = len(vuln_k_pshuff) / len(T) #fraction inferred\n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_mn = vuln_pshuff_trials.mean(axis = 1)\n",
    "attack_st = vuln_pshuff_trials.std(axis = 1)\n",
    "\n",
    "LDP_attack = len(vuln_k_LDP) / len(T)\n",
    "shuff_attack = len(vuln_k_shuff) / len(T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./Texas_attack_mean_trials.npy', attack_mn)\n",
    "np.save('./Texas_attack_std_trials.npy', attack_st)\n",
    "np.save('./Texas_radii_trials.npy', r_vals)\n",
    "np.save('./Texas_attack_LDP_trials.npy', np.ones(len(r_vals)) * LDP_attack)\n",
    "np.save('./Texas_attack_shuff_trials.npy', np.ones(len(r_vals)) * shuff_attack)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(r_vals, attack_mn, '-o', label = \"Mallows\", color = 'black')\n",
    "plt.fill_between(r_vals, attack_mn + attack_st, attack_mn - attack_st, alpha = 0.2)\n",
    "plt.plot(r_vals, np.ones(len(r_vals)) * LDP_attack, '--', label = \"LDP\", alpha = 0.5, color = 'tomato')\n",
    "plt.plot(r_vals, np.ones(len(r_vals)) * shuff_attack, '--', label = \"Unif. Shuff.\", alpha = 0.5, color = 'seagreen')\n",
    "plt.plot(np.ones(10)*Rcorr, np.linspace(shuff_attack, LDP_attack, 10), '--', \n",
    "         alpha = 0.5, color = 'gray', linewidth = 2)\n",
    "plt.legend(loc = 'right')\n",
    "plt.title('Resistance to $k$-NN Attack')\n",
    "plt.xlabel('Priv. Radius $r$')\n",
    "plt.ylabel('Frac. Inferred')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get TV utility over trials "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LDP TV: 0.11054783220383387\n",
      "Unif. shuff. TV: 0.18981278474103286\n",
      "Oblivious TV: 0.21881090718958396\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-43-72a190801855>:33: 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": "23240136762f44bcbefaa87f4059247f",
       "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",
    "set_plot_defaults()\n",
    "r_vals = np.asarray([0., 10., 20., 30., 40., 50., 60., 70., 80.])\n",
    "n_trials = 10  \n",
    "\n",
    "#Get LDP utility: \n",
    "R_calib = 20\n",
    "cv = 3\n",
    "msl = 100\n",
    "\n",
    "lr = 0.1\n",
    "\n",
    "LDP_TV = get_calibration_TVD(Y[:,0], X, Distmat, R_calib, T_locs, cv = cv, \n",
    "                        base_clf=GBC(min_samples_leaf = msl, learning_rate = lr)).mean()\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, T_locs, cv = cv, \n",
    "                        base_clf=GBC(min_samples_leaf = msl, learning_rate = lr)).mean()\n",
    "\n",
    "print('Unif. shuff. TV:', Unif_shuff_TV)\n",
    "\n",
    "oblivious = np.ones((len(X), 4)) / 4\n",
    "oblivious_TV = get_TVD(oblivious, Distmat, R_calib, T_locs, X).mean()\n",
    "print('Oblivious TV:', oblivious_TV)\n",
    "\n",
    "r_shuff_TV = np.zeros((len(r_vals), n_trials))\n",
    "\n",
    "for trial in tqdm(range(n_trials)): \n",
    "    for r in r_vals: \n",
    "        ref_perm = np.load('./permutations_trials/sigma0_R{0:.3f}.npy'\\\n",
    "                .format(r))\n",
    "        samp_perm = np.load('./permutations_trials/sigmasamp_R{0:.3f}_n{1:n}.npy'\\\n",
    "                .format(r, trial))\n",
    "        Y_shuffle = Y[samp_perm[np.argsort(ref_perm)], 0]\n",
    "\n",
    "        r_shuff_TV[r_vals == r, trial] = get_calibration_TVD(Y_shuffle, X, Distmat, R_calib, T_locs, cv = cv, \n",
    "                            base_clf=GBC(min_samples_leaf = msl, learning_rate = lr)).mean()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "TV_shuff_mn = (r_shuff_TV/oblivious_TV).mean(axis = 1)\n",
    "TV_shuff_st = (r_shuff_TV/oblivious_TV).std(axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./Texas_utility_mean_trials.npy', TV_shuff_mn)\n",
    "np.save('./Texas_utility_std_trials.npy', TV_shuff_st)\n",
    "np.save('./Texas_radii_trials.npy', r_vals)\n",
    "np.save('./Texas_utility_LDP_trials.npy', np.ones(len(r_vals)) * LDP_TV / oblivious_TV)\n",
    "np.save('./Texas_utility_shuff_trials.npy', np.ones(len(r_vals)) * Unif_shuff_TV / oblivious_TV)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(r_vals, TV_shuff_mn, '-o', label = \"Mallows\", color = 'black')\n",
    "plt.fill_between(r_vals, TV_shuff_mn + TV_shuff_st, TV_shuff_mn - TV_shuff_st, alpha = 0.2)\n",
    "plt.plot(r_vals, np.ones(len(r_vals)) * LDP_TV / oblivious_TV, '--', label = \"LDP\", alpha = 0.5, color = 'tomato')\n",
    "plt.plot(r_vals, np.ones(len(r_vals)) * Unif_shuff_TV / oblivious_TV, '--', label = \"Unif. Shuff.\", alpha = 0.5, color = 'seagreen')\n",
    "plt.legend(loc = 'right')\n",
    "plt.title('TV_utility')\n",
    "plt.xlabel('Priv. Radius $r$')\n",
    "plt.ylabel('Ave TV')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
