{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Functions & Packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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, 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",
    "def RR(labels, epsilon): \n",
    "    #apply randomized response to labels \n",
    "    prob_flip = 1 / (np.exp(epsilon) + 1)\n",
    "    print('prob of flip:', prob_flip)\n",
    "    flip_idx = np.random.binomial(1, prob_flip, len(labels))\n",
    "    labels_z = 1*np.logical_xor(labels,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, 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), 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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(30162, 103)\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(seed = 0) #for replicating\n",
    "cols, T = np.load('./raw_adult_dataset.npy', allow_pickle=True)\n",
    "x_col = cols == 'income'\n",
    "X = T[:, x_col].squeeze()\n",
    "T = T[:, ~x_col]\n",
    "cols = cols[~x_col]\n",
    "\n",
    "#shuffle order\n",
    "shuff_idx = np.arange(len(X))\n",
    "np.random.shuffle(shuff_idx)\n",
    "X = X[shuff_idx]\n",
    "T = T[shuff_idx, :]\n",
    "\n",
    "print(T.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Preprocess\n",
    "\n",
    "Since a large share of individuals have the same age in Adult (esp. in 40's), the group size grows rapidly with radius. By stripping out specific ages, we aid the mechanism by keeping groups small with minimal utility loss. While not ideal (ideally we have other features to make smaller groups), this preprocessing is perfectly accessible in practice. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([17, 18, 19, 20, 21, 23, 24, 25, 26, 29, 30, 31, 33, 34, 35, 36, 40,\n",
       "       41, 43, 44, 45, 46, 49, 50, 51, 53, 54, 55, 56, 60, 61, 63, 64, 65,\n",
       "       66, 69, 70, 71, 73, 74, 75, 76, 80, 81, 83, 84, 85, 86, 89, 90])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#break ages into groups\n",
    "T_age = T[:, cols == 'age']\n",
    "ages = np.sort(np.unique(T_age))\n",
    "age_rng = np.arange(ages.min(), ages.max()+1)\n",
    "rmv_indices = []\n",
    "for i in range(1, len(age_rng)): \n",
    "    if i%20 == 0: \n",
    "        rmv_indices.append([i, i+1, i+2])\n",
    "    elif i%10 == 0: \n",
    "        rmv_indices.append([i, i+1])\n",
    "    elif i%5 == 0: \n",
    "        rmv_indices.append([i])\n",
    "rmv_indices = np.concatenate(rmv_indices)\n",
    "age_keeps = age_rng[~np.in1d(age_rng, age_rng[rmv_indices])]\n",
    "age_keeps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20769, 103)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "T_age = T[:, cols == 'age']\n",
    "keep_idx = np.in1d(T_age, age_keeps)\n",
    "T = T[keep_idx, :]\n",
    "X = X[keep_idx]\n",
    "T.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# balance dataset\n",
    "A large share of Adult dataset is labeled 0. Here we balance the dataset such that a naive guess will be 50% accurate. This significantly reduces the dataset size to ~10k. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train shape: (9716, 103)\n",
      "Test shape: (0, 103)\n"
     ]
    }
   ],
   "source": [
    "n_test = 0 #even number \n",
    "n_test_class = int(n_test / 2)\n",
    "\n",
    "one_idx = np.where(X == 1)[0]\n",
    "num_ones = len(one_idx)\n",
    "one_idx_train = one_idx[:(num_ones - n_test_class)]\n",
    "one_idx_test = one_idx[(num_ones - n_test_class):num_ones]\n",
    "\n",
    "zero_idx = np.where(X == 0)[0]\n",
    "zero_idx_train = zero_idx[:(num_ones - n_test_class)]\n",
    "zero_idx_test = zero_idx[(num_ones - n_test_class):num_ones]\n",
    "\n",
    "train_idx = np.concatenate((one_idx_train, zero_idx_train), axis = 0)\n",
    "test_idx = np.concatenate((one_idx_test, zero_idx_test), axis = 0)\n",
    "\n",
    "T_tr = T[train_idx, :]\n",
    "X_tr = X[train_idx]\n",
    "T_te = T[test_idx, :]\n",
    "X_te = X[test_idx]\n",
    "\n",
    "#shuffle order\n",
    "shuff_idx = np.arange(len(X_tr))\n",
    "np.random.shuffle(shuff_idx)\n",
    "X_tr = X_tr[shuff_idx]\n",
    "T_tr = T_tr[shuff_idx, :]\n",
    "\n",
    "#shuffle order\n",
    "shuff_idx = np.arange(len(X_te))\n",
    "np.random.shuffle(shuff_idx)\n",
    "X_te = X_te[shuff_idx]\n",
    "T_te = T_te[shuff_idx, :]\n",
    "\n",
    "print('Train shape:', T_tr.shape)\n",
    "print('Test shape:', T_te.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check feature importances using GBDT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "marital.status_Married-civ-spouse: 0.621\n",
      "education.num: 0.167\n",
      "capital.gain: 0.135\n",
      "age: 0.050\n",
      "hours.per.week: 0.025\n",
      "education_HS-grad: 0.001\n",
      "relationship_Own-child: 0.000\n",
      "relationship_Wife: 0.000\n",
      "occupation_Craft-repair: 0.000\n",
      "marital.status_Married-AF-spouse: 0.000\n",
      "marital.status_Married-spouse-absent: 0.000\n",
      "marital.status_Never-married: 0.000\n",
      "marital.status_Separated: 0.000\n",
      "marital.status_Widowed: 0.000\n",
      "occupation_Adm-clerical: 0.000\n",
      "occupation_Armed-Forces: 0.000\n",
      "occupation_Handlers-cleaners: 0.000\n",
      "occupation_Exec-managerial: 0.000\n",
      "occupation_Farming-fishing: 0.000\n",
      "education_Some-college: 0.000\n",
      "occupation_Machine-op-inspct: 0.000\n",
      "occupation_Other-service: 0.000\n",
      "occupation_Priv-house-serv: 0.000\n",
      "occupation_Prof-specialty: 0.000\n",
      "occupation_Protective-serv: 0.000\n",
      "occupation_Sales: 0.000\n",
      "occupation_Tech-support: 0.000\n",
      "marital.status_Divorced: 0.000\n",
      "education_Preschool: 0.000\n",
      "education_Prof-school: 0.000\n",
      "education_11th: 0.000\n",
      "capital.loss: 0.000\n",
      "workclass_Federal-gov: 0.000\n",
      "workclass_Local-gov: 0.000\n",
      "workclass_Private: 0.000\n",
      "workclass_Self-emp-inc: 0.000\n",
      "workclass_Self-emp-not-inc: 0.000\n",
      "workclass_State-gov: 0.000\n",
      "workclass_Without-pay: 0.000\n",
      "education_10th: 0.000\n",
      "education_12th: 0.000\n",
      "relationship_Husband: 0.000\n",
      "education_1st-4th: 0.000\n",
      "education_5th-6th: 0.000\n",
      "education_7th-8th: 0.000\n",
      "education_9th: 0.000\n",
      "education_Assoc-acdm: 0.000\n",
      "education_Assoc-voc: 0.000\n",
      "education_Bachelors: 0.000\n",
      "education_Doctorate: 0.000\n",
      "education_Masters: 0.000\n",
      "occupation_Transport-moving: 0.000\n",
      "native.country_Yugoslavia: 0.000\n",
      "relationship_Not-in-family: 0.000\n",
      "native.country_Outlying-US(Guam-USVI-etc): 0.000\n",
      "native.country_Hungary: 0.000\n",
      "native.country_India: 0.000\n",
      "native.country_Iran: 0.000\n",
      "native.country_Ireland: 0.000\n",
      "native.country_Italy: 0.000\n",
      "native.country_Jamaica: 0.000\n",
      "native.country_Japan: 0.000\n",
      "native.country_Laos: 0.000\n",
      "native.country_Mexico: 0.000\n",
      "native.country_Nicaragua: 0.000\n",
      "native.country_Peru: 0.000\n",
      "native.country_Vietnam: 0.000\n",
      "native.country_Philippines: 0.000\n",
      "native.country_Poland: 0.000\n",
      "native.country_Portugal: 0.000\n",
      "native.country_Puerto-Rico: 0.000\n",
      "native.country_Scotland: 0.000\n",
      "native.country_South: 0.000\n",
      "native.country_Taiwan: 0.000\n",
      "native.country_Thailand: 0.000\n",
      "native.country_Trinadad&Tobago: 0.000\n",
      "native.country_United-States: 0.000\n",
      "native.country_Hong: 0.000\n",
      "native.country_Honduras: 0.000\n",
      "native.country_Holand-Netherlands: 0.000\n",
      "native.country_Haiti: 0.000\n",
      "relationship_Unmarried: 0.000\n",
      "race_Amer-Indian-Eskimo: 0.000\n",
      "race_Asian-Pac-Islander: 0.000\n",
      "race_Black: 0.000\n",
      "race_Other: 0.000\n",
      "race_White: 0.000\n",
      "sex_Female: 0.000\n",
      "sex_Male: 0.000\n",
      "native.country_Cambodia: 0.000\n",
      "native.country_Canada: 0.000\n",
      "native.country_China: 0.000\n",
      "native.country_Columbia: 0.000\n",
      "native.country_Cuba: 0.000\n",
      "native.country_Dominican-Republic: 0.000\n",
      "native.country_Ecuador: 0.000\n",
      "native.country_El-Salvador: 0.000\n",
      "native.country_England: 0.000\n",
      "native.country_France: 0.000\n",
      "native.country_Germany: 0.000\n",
      "native.country_Greece: 0.000\n",
      "native.country_Guatemala: 0.000\n",
      "relationship_Other-relative: 0.000\n"
     ]
    }
   ],
   "source": [
    "clf = GBC(learning_rate = 0.01, min_samples_leaf = 50).fit(T_tr, X_tr)\n",
    "impts = clf.feature_importances_\n",
    "impt_idx = np.argsort(impts)[::-1]\n",
    "\n",
    "for feat, impt in zip(cols[impt_idx], impts[impt_idx]):\n",
    "    print('{0}: {1:.3f}'.format(feat, impt))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get LDP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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.8202964182791272\n"
     ]
    }
   ],
   "source": [
    "#make multiple trials \n",
    "n_trials = 50\n",
    "Y_tr = np.zeros((len(X_tr), n_trials))\n",
    "for i in range(n_trials): \n",
    "    Y_tr[:,i] = RR(X_tr, epsilon = 1.5).squeeze()\n",
    "print('Frac unperturbed', np.mean( Y_tr[:,0] == X_tr) )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get distance matrices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Get pairwise distances that allows constructing adjacency matrix of group graph \\mathcal{G} for different r values\n",
    "\n",
    "T_tr_age = T_tr[:, cols == 'age'].squeeze()\n",
    "Distmat = np.abs(T_tr_age[:,None] - T_tr_age[:,None].T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2700"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "N = Distmat <= 4\n",
    "np.max(N.sum(axis = 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "#For correlating in attack\n",
    "T_tr_mg = T_tr[:, cols == 'marital.status_Married-civ-spouse'].squeeze()\n",
    "Dmat = np.abs(T_tr_mg[:,None] - T_tr_mg[:,None].T, dtype = float)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate several trial permutations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "get reference perms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-11-8fcb22d6808c>:9: TqdmDeprecationWarning: This function will be removed in tqdm==5.0.0\n",
      "Please use `tqdm.notebook.tqdm` instead of `tqdm.tqdm_notebook`\n",
      "  for R in tqdm(r_vals):\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b2f12672eb85446d9b88a3beee4f2cee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/6 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "most neighbs: 422\n",
      "most neighbs: 1237\n",
      "most neighbs: 1653\n",
      "most neighbs: 2483\n",
      "most neighbs: 2700\n",
      "most neighbs: 3146\n",
      "sample perms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-11-8fcb22d6808c>:15: 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": "67ebdf10d6e34567841c73cde65b0be6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "r_vals = np.arange(6)\n",
    "r_vals[0] = 0.01\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_tr_age, 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_tr[:,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": "markdown",
   "metadata": {},
   "source": [
    "# Run attack for each $r$ and each trial "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "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-11-fd58a92f7cd2>:46: 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": "2f72f527bbe34d47a85a07da219403c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "r_vals = np.arange(6)\n",
    "r_vals[0] = 0.01\n",
    "\n",
    "shuff_idx = np.arange(Y_tr.shape[0])\n",
    "np.random.shuffle(shuff_idx)\n",
    "Y_shuff = Y_tr[shuff_idx, :]\n",
    "\n",
    "Rcorr = 2 #attack radius\n",
    "K = 35 #rcorr = 2\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_tr, Y_tr, 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_tr, Y_shuff, Dmat, Distmat, \n",
    "                                                   R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "\n",
    "n_trials = 10\n",
    "vuln_pshuff_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{:.3f}.npy'.format(R))\n",
    "        sig_full = np.load('./permutations_trials/sigmasamp_R{0:.3f}_n{1:n}.npy'\\\n",
    "                .format(R, trial))\n",
    "\n",
    "        Y_pshuff = Y_tr[sig_full[np.argsort(sig0_full)], :]\n",
    "\n",
    "        vuln_k_pshuff, vuln_grp_pshuff = k_vs_grp_attack(X_tr, Y_pshuff, Dmat, Distmat, \n",
    "                                                       R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "\n",
    "        vuln_pshuff[R] = (vuln_k_pshuff, vuln_grp_pshuff)\n",
    "        \n",
    "    vuln_pshuff_trials.append(vuln_pshuff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "#unpack, plot, and save data  \n",
    "attack_stats = np.zeros((len(r_vals), n_trials))\n",
    "\n",
    "n = len(X_tr)\n",
    "tr_ct = 0\n",
    "\n",
    "for vuln_pshuff in vuln_pshuff_trials: \n",
    "    r_ct = 0\n",
    "    for R in vuln_pshuff.keys(): \n",
    "        vuln_k_pshuff = vuln_pshuff[R][0]\n",
    "        attack_stats[r_ct, tr_ct] = len(vuln_k_pshuff) / n\n",
    "        r_ct += 1\n",
    "    tr_ct += 1\n",
    "    \n",
    "LDP_attack = len(vuln_k_LDP) / n\n",
    "shuff_attack = len(vuln_k_shuff) / n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_mn = attack_stats.mean(axis = 1)\n",
    "attack_st = attack_stats.std(axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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u3btMrtlmJCQgO7duzuVd8KECWavK/a780XVcY315LXPmvLL6gHAgAEDLPr4uQuDuWrSokUL/P7772Zruy1atAi//PKL3XzGpll3Kn+Br6hv375IS0vDypUr8cgjj9i8HVxUVIQlS5aga9euePzxx836SbnKF+pQ0Zw5c7BixQqzbffccw8++OADbN68GWfPnjWtHSsaRombHr7OnZ1/q/t8rU4V6+GOv5s7//YV+8sNHjzY7PVHH33k8wvJG82YMcPsduLcuXNx7ty5WlM+YBmAnT171mKQna3Ho48+apZ3w4YNyMjIqM7qV5o3rrGeHvjQp08fs+/8FStW4LHHHoNWq3V7WQzmqlGbNm3w9ttvm217+eWX7QYhMTExZq937dplcSJX9mFvNBRgWHFh6NChWLp0KTIzM3HmzBksWrQIEydOtLpaxfz58zF69Gjn/xBO8IU6GKnVarz77rum14IgYMGCBdi9ezdeeeUVJCcno3nz5ggLC7No9SgoKPBInVxR8ZxyZ+uQN87X6lJxIIqtPon2VMzjzpaBisHcl19+iTfeeMP0+vr16+jXrx8yMzMrfezK/H+5Q8OGDfH888+bXms0GrP34mneLr+oqAg//fST246n1+uxYMECtx3P3arrGuvJa581PXv2xJ9//mn2OV+8eDEefvhh02Akd2EwV82ef/55s1uIly9fxhdffGEzfcVWqdOnT3usbrYkJCRg7Nix+Oabb3Du3DkcPHjQ4pffr7/+io0bN9bIOmzdutXsS3js2LEWI8Zsqc7lxpxVv359s9cnTpxw27F94Xz1lDp16pi9rux7y8nJQXZ2tul1REQE5HK5W+oGmAdzdevWRcOGDTFz5kw8+eSTpu3p6en4xz/+UaVAtLpNnjzZ7Etw+fLlFksh1tTyly9f7vZRtPPmzfOZVu6Kqusa68lrny1JSUnYunWrWdlr1qxB//793dqFhMFcNZPL5ZgxY4bZttmzZ9v8T604Am7Dhg0eq5uzOnTogCVLluCZZ54x2/7rr7/6bB1caU4/c+aM2euK87nZU9l55apDxX43W7ZscduxffF8Lc+V86Bz585mryv7f1sxfZcuXapcl4oKCwvNztPydf36668xZMgQ0+vDhw9j0KBBbm8ZcLeIiAhMnjzZ9FoURbz++uu1ovyKt1h/+OEHpKenV/pRfm3W9PR0bN68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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_plot_defaults()\n",
    "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": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save data: \n",
    "np.save('./adult_attack_means_trials.npy', attack_mn)\n",
    "np.save('./adult_attack_std_trials.npy', attack_st)\n",
    "np.save('./adult_attack_r_vals.npy', r_vals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check utility at each $r$ across trials "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LDP TV: 0.06693379117171937\n",
      "Unif. shuff. TV: 0.1768667156860756\n",
      "Oblivious TV: 0.17525803104430762\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-40-c9f8546db6f4>:34: 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": "34c54a8a48aa4ceb9a00970fc233542f",
       "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.arange(6)\n",
    "r_vals[0] = 0.01\n",
    "\n",
    "R_calib = 2\n",
    "cv = 2\n",
    "msl = 10\n",
    "\n",
    "lr = 0.01\n",
    "\n",
    "LDP_TV = get_calibration_TVD(Y_tr[:,0], X_tr, Distmat, R_calib, T_tr_age[:,None], 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_tr[:,0]))\n",
    "np.random.shuffle(Y_unishuffle_idx)\n",
    "Y_unishuffle = Y_tr[Y_unishuffle_idx,0]\n",
    "\n",
    "Unif_shuff_TV = get_calibration_TVD(Y_unishuffle, X_tr, Distmat, R_calib, T_tr_age[:,None], 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_tr), 2)) / 2\n",
    "oblivious_TV = get_TVD(oblivious, Distmat, R_calib, T_tr_age[:,None], X_tr).mean()\n",
    "print('Oblivious TV:', oblivious_TV)\n",
    "\n",
    "n_trials = 10\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{:.3f}.npy'.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_tr[samp_perm[np.argsort(ref_perm)], 0]\n",
    "\n",
    "        r_shuff_TV[r_vals == r, trial] = get_calibration_TVD(Y_shuffle, X_tr, Distmat, R_calib, T_tr_age[:,None], cv = cv, \n",
    "                            base_clf=GBC(min_samples_leaf = msl, learning_rate = lr)).mean()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "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": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ihXh5+eHxYsX46+//sLVq1dx7tw5bN68GU2aNMHVq1cBAF999VW2z5T8UMZ6LUdHR/EqHJExYekHIipQOnfuDBsbGyQlJYlTTQVhYbw63333HX7++WekpqZi3rx56NOnj7jYXCKRYPv27WjRogWio6Oxe/dupbssgfQ1Wfv27cvymZNAeoLx559/4tNPP0V4eLja8wwcOBBNmzZV+2xFTW3evBnNmjVDZGQktm7dqnI1bty4cahevTouXLiQ5TkUCgXOnDkjXsFSp2vXrtk+dFudjCtbNWvWLDBTyUS5wStbRFSg2NnZoVOnTuJrExOTbBeYG5K3tzcGDBgAIP3uww/XNNWsWRPXr1/HN998g9KlS8Pc3BzOzs6oV68elixZgkuXLilVXs9K1apVcefOHUyaNAkVKlSApaUlXFxc0Lx5c+zatQubNm3K93upVKkSrl69imHDhqF06dKwsLCAq6sr2rZtiyNHjqidXsxs0qRJ+OOPPzB27Fh88sknKFWqFKysrGBlZYUyZcqgR48eOHLkCPbv3y9Ov2oqc7JFZIwkQkEozkJERERUSPHKFhEREZEOMdkiIiIi0iEmW0REREQ6xGSLiIiISIeYbBERERHpEJMtIiIiIh1iskVERESkQ0y2iIiIiHSIyRYRERGRDjHZIiIiItIhJltEREREOsRki4iIiEiHmGwRERER6RCTLSIiIiId+j/d/77syPITvAAAAABJRU5ErkJggg==\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": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "# save data \n",
    "np.save('./adult_utility_means_trials.npy', TV_shuff_mn)\n",
    "np.save('./adult_utility_std_trials.npy', TV_shuff_st)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sweep $\\alpha$\n",
    "\n",
    "For this test, we use a different grouping in which each individual has a group of the 100 people closest in age. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 777,
   "metadata": {},
   "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-777-6bf22a6d285b>:37: 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": "da2daa891aae48d6bd9d7e2644914570",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4009\n",
      "Num Grp'd: 5783\n",
      "Num KNN'd not Grp'd: 95\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4895\n",
      "Num Grp'd: 5586\n",
      "Num KNN'd not Grp'd: 84\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4454\n",
      "Num Grp'd: 5875\n",
      "Num KNN'd not Grp'd: 20\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3445\n",
      "Num Grp'd: 6030\n",
      "Num KNN'd not Grp'd: 35\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3611\n",
      "Num Grp'd: 6055\n",
      "Num KNN'd not Grp'd: 3\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3405\n",
      "Num Grp'd: 5760\n",
      "Num KNN'd not Grp'd: 35\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4313\n",
      "Num Grp'd: 5818\n",
      "Num KNN'd not Grp'd: 188\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1785\n",
      "Num Grp'd: 4886\n",
      "Num KNN'd not Grp'd: 290\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1311\n",
      "Num Grp'd: 4024\n",
      "Num KNN'd not Grp'd: 859\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 449\n",
      "Num Grp'd: 641\n",
      "Num KNN'd not Grp'd: 407\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4356\n",
      "Num Grp'd: 6135\n",
      "Num KNN'd not Grp'd: 99\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4233\n",
      "Num Grp'd: 5832\n",
      "Num KNN'd not Grp'd: 37\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3977\n",
      "Num Grp'd: 5686\n",
      "Num KNN'd not Grp'd: 57\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4134\n",
      "Num Grp'd: 5977\n",
      "Num KNN'd not Grp'd: 210\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4342\n",
      "Num Grp'd: 6281\n",
      "Num KNN'd not Grp'd: 134\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3776\n",
      "Num Grp'd: 5563\n",
      "Num KNN'd not Grp'd: 149\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2692\n",
      "Num Grp'd: 5177\n",
      "Num KNN'd not Grp'd: 96\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3278\n",
      "Num Grp'd: 5197\n",
      "Num KNN'd not Grp'd: 176\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1728\n",
      "Num Grp'd: 3088\n",
      "Num KNN'd not Grp'd: 775\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 870\n",
      "Num Grp'd: 1252\n",
      "Num KNN'd not Grp'd: 838\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4343\n",
      "Num Grp'd: 6370\n",
      "Num KNN'd not Grp'd: 219\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4115\n",
      "Num Grp'd: 5970\n",
      "Num KNN'd not Grp'd: 326\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3935\n",
      "Num Grp'd: 5503\n",
      "Num KNN'd not Grp'd: 146\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4021\n",
      "Num Grp'd: 6250\n",
      "Num KNN'd not Grp'd: 9\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3984\n",
      "Num Grp'd: 5785\n",
      "Num KNN'd not Grp'd: 395\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3820\n",
      "Num Grp'd: 5964\n",
      "Num KNN'd not Grp'd: 435\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3894\n",
      "Num Grp'd: 6223\n",
      "Num KNN'd not Grp'd: 155\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1897\n",
      "Num Grp'd: 5628\n",
      "Num KNN'd not Grp'd: 197\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 690\n",
      "Num Grp'd: 3634\n",
      "Num KNN'd not Grp'd: 298\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 844\n",
      "Num Grp'd: 1751\n",
      "Num KNN'd not Grp'd: 273\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 5131\n",
      "Num Grp'd: 5836\n",
      "Num KNN'd not Grp'd: 137\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4528\n",
      "Num Grp'd: 5955\n",
      "Num KNN'd not Grp'd: 240\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4130\n",
      "Num Grp'd: 6003\n",
      "Num KNN'd not Grp'd: 95\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3333\n",
      "Num Grp'd: 5716\n",
      "Num KNN'd not Grp'd: 118\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3928\n",
      "Num Grp'd: 5861\n",
      "Num KNN'd not Grp'd: 12\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3962\n",
      "Num Grp'd: 6053\n",
      "Num KNN'd not Grp'd: 44\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3130\n",
      "Num Grp'd: 6033\n",
      "Num KNN'd not Grp'd: 131\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2234\n",
      "Num Grp'd: 5453\n",
      "Num KNN'd not Grp'd: 541\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1899\n",
      "Num Grp'd: 4305\n",
      "Num KNN'd not Grp'd: 577\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 693\n",
      "Num Grp'd: 1644\n",
      "Num KNN'd not Grp'd: 648\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4585\n",
      "Num Grp'd: 6207\n",
      "Num KNN'd not Grp'd: 72\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3519\n",
      "Num Grp'd: 5996\n",
      "Num KNN'd not Grp'd: 10\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3650\n",
      "Num Grp'd: 5998\n",
      "Num KNN'd not Grp'd: 26\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4853\n",
      "Num Grp'd: 5800\n",
      "Num KNN'd not Grp'd: 456\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3824\n",
      "Num Grp'd: 5924\n",
      "Num KNN'd not Grp'd: 123\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4604\n",
      "Num Grp'd: 6042\n",
      "Num KNN'd not Grp'd: 66\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4466\n",
      "Num Grp'd: 5556\n",
      "Num KNN'd not Grp'd: 290\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1030\n",
      "Num Grp'd: 905\n",
      "Num KNN'd not Grp'd: 967\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4479\n",
      "Num Grp'd: 5627\n",
      "Num KNN'd not Grp'd: 133\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3999\n",
      "Num Grp'd: 5970\n",
      "Num KNN'd not Grp'd: 119\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4221\n",
      "Num Grp'd: 6004\n",
      "Num KNN'd not Grp'd: 256\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4621\n",
      "Num Grp'd: 6235\n",
      "Num KNN'd not Grp'd: 0\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 5254\n",
      "Num Grp'd: 5773\n",
      "Num KNN'd not Grp'd: 594\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4056\n",
      "Num Grp'd: 5911\n",
      "Num KNN'd not Grp'd: 270\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3966\n",
      "Num Grp'd: 6138\n",
      "Num KNN'd not Grp'd: 104\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2066\n",
      "Num Grp'd: 4368\n",
      "Num KNN'd not Grp'd: 241\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1028\n",
      "Num Grp'd: 3927\n",
      "Num KNN'd not Grp'd: 624\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 453\n",
      "Num Grp'd: 217\n",
      "Num KNN'd not Grp'd: 453\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4529\n",
      "Num Grp'd: 6177\n",
      "Num KNN'd not Grp'd: 69\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 5114\n",
      "Num Grp'd: 5988\n",
      "Num KNN'd not Grp'd: 117\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3376\n",
      "Num Grp'd: 5797\n",
      "Num KNN'd not Grp'd: 75\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4048\n",
      "Num Grp'd: 5832\n",
      "Num KNN'd not Grp'd: 57\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4740\n",
      "Num Grp'd: 5576\n",
      "Num KNN'd not Grp'd: 141\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2633\n",
      "Num Grp'd: 6078\n",
      "Num KNN'd not Grp'd: 107\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3257\n",
      "Num Grp'd: 5950\n",
      "Num KNN'd not Grp'd: 100\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2556\n",
      "Num Grp'd: 5127\n",
      "Num KNN'd not Grp'd: 248\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1737\n",
      "Num Grp'd: 3192\n",
      "Num KNN'd not Grp'd: 484\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 873\n",
      "Num Grp'd: 326\n",
      "Num KNN'd not Grp'd: 873\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4826\n",
      "Num Grp'd: 5944\n",
      "Num KNN'd not Grp'd: 275\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3932\n",
      "Num Grp'd: 6055\n",
      "Num KNN'd not Grp'd: 194\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4686\n",
      "Num Grp'd: 5877\n",
      "Num KNN'd not Grp'd: 454\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4490\n",
      "Num Grp'd: 6384\n",
      "Num KNN'd not Grp'd: 108\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4109\n",
      "Num Grp'd: 6048\n",
      "Num KNN'd not Grp'd: 38\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4408\n",
      "Num Grp'd: 5791\n",
      "Num KNN'd not Grp'd: 46\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3774\n",
      "Num Grp'd: 5760\n",
      "Num KNN'd not Grp'd: 440\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2330\n",
      "Num Grp'd: 5199\n",
      "Num KNN'd not Grp'd: 139\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3469\n",
      "Num Grp'd: 4291\n",
      "Num KNN'd not Grp'd: 1362\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1304\n",
      "Num Grp'd: 888\n",
      "Num KNN'd not Grp'd: 1110\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3970\n",
      "Num Grp'd: 5747\n",
      "Num KNN'd not Grp'd: 146\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4080\n",
      "Num Grp'd: 5942\n",
      "Num KNN'd not Grp'd: 200\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4174\n",
      "Num Grp'd: 6223\n",
      "Num KNN'd not Grp'd: 227\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3898\n",
      "Num Grp'd: 5843\n",
      "Num KNN'd not Grp'd: 19\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4187\n",
      "Num Grp'd: 6002\n",
      "Num KNN'd not Grp'd: 55\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2988\n",
      "Num Grp'd: 5869\n",
      "Num KNN'd not Grp'd: 48\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3849\n",
      "Num Grp'd: 5340\n",
      "Num KNN'd not Grp'd: 412\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2598\n",
      "Num Grp'd: 4853\n",
      "Num KNN'd not Grp'd: 39\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1669\n",
      "Num Grp'd: 3418\n",
      "Num KNN'd not Grp'd: 416\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 792\n",
      "Num Grp'd: 709\n",
      "Num KNN'd not Grp'd: 549\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4024\n",
      "Num Grp'd: 5491\n",
      "Num KNN'd not Grp'd: 157\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4564\n",
      "Num Grp'd: 5955\n",
      "Num KNN'd not Grp'd: 15\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4398\n",
      "Num Grp'd: 6047\n",
      "Num KNN'd not Grp'd: 21\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4456\n",
      "Num Grp'd: 5872\n",
      "Num KNN'd not Grp'd: 42\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3628\n",
      "Num Grp'd: 5272\n",
      "Num KNN'd not Grp'd: 112\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4112\n",
      "Num Grp'd: 5758\n",
      "Num KNN'd not Grp'd: 100\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3650\n",
      "Num Grp'd: 5586\n",
      "Num KNN'd not Grp'd: 786\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2160\n",
      "Num Grp'd: 4967\n",
      "Num KNN'd not Grp'd: 278\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1523\n",
      "Num Grp'd: 3694\n",
      "Num KNN'd not Grp'd: 493\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 636\n",
      "Num Grp'd: 851\n",
      "Num KNN'd not Grp'd: 636\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3683\n",
      "Num Grp'd: 5767\n",
      "Num KNN'd not Grp'd: 257\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3916\n",
      "Num Grp'd: 5996\n",
      "Num KNN'd not Grp'd: 112\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2790\n",
      "Num Grp'd: 5680\n",
      "Num KNN'd not Grp'd: 230\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4338\n",
      "Num Grp'd: 5787\n",
      "Num KNN'd not Grp'd: 39\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4234\n",
      "Num Grp'd: 5884\n",
      "Num KNN'd not Grp'd: 66\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4226\n",
      "Num Grp'd: 5807\n",
      "Num KNN'd not Grp'd: 591\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3265\n",
      "Num Grp'd: 5524\n",
      "Num KNN'd not Grp'd: 169\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2939\n",
      "Num Grp'd: 5042\n",
      "Num KNN'd not Grp'd: 288\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2027\n",
      "Num Grp'd: 3415\n",
      "Num KNN'd not Grp'd: 1593\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 342\n",
      "Num Grp'd: 250\n",
      "Num KNN'd not Grp'd: 342\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3981\n",
      "Num Grp'd: 6199\n",
      "Num KNN'd not Grp'd: 27\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3847\n",
      "Num Grp'd: 5973\n",
      "Num KNN'd not Grp'd: 166\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3580\n",
      "Num Grp'd: 6271\n",
      "Num KNN'd not Grp'd: 125\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4408\n",
      "Num Grp'd: 6018\n",
      "Num KNN'd not Grp'd: 78\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3799\n",
      "Num Grp'd: 6021\n",
      "Num KNN'd not Grp'd: 410\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3667\n",
      "Num Grp'd: 6054\n",
      "Num KNN'd not Grp'd: 11\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4244\n",
      "Num Grp'd: 5820\n",
      "Num KNN'd not Grp'd: 393\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3305\n",
      "Num Grp'd: 5301\n",
      "Num KNN'd not Grp'd: 441\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2490\n",
      "Num Grp'd: 4383\n",
      "Num KNN'd not Grp'd: 489\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 524\n",
      "Num Grp'd: 969\n",
      "Num KNN'd not Grp'd: 441\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4160\n",
      "Num Grp'd: 5938\n",
      "Num KNN'd not Grp'd: 1\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3996\n",
      "Num Grp'd: 5810\n",
      "Num KNN'd not Grp'd: 7\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3962\n",
      "Num Grp'd: 5746\n",
      "Num KNN'd not Grp'd: 108\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3516\n",
      "Num Grp'd: 5384\n",
      "Num KNN'd not Grp'd: 53\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4362\n",
      "Num Grp'd: 5594\n",
      "Num KNN'd not Grp'd: 337\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4322\n",
      "Num Grp'd: 5999\n",
      "Num KNN'd not Grp'd: 432\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2257\n",
      "Num Grp'd: 5713\n",
      "Num KNN'd not Grp'd: 58\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1647\n",
      "Num Grp'd: 4881\n",
      "Num KNN'd not Grp'd: 214\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1047\n",
      "Num Grp'd: 2339\n",
      "Num KNN'd not Grp'd: 370\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 158\n",
      "Num Grp'd: 1021\n",
      "Num KNN'd not Grp'd: 119\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4914\n",
      "Num Grp'd: 5979\n",
      "Num KNN'd not Grp'd: 85\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3786\n",
      "Num Grp'd: 6274\n",
      "Num KNN'd not Grp'd: 38\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3803\n",
      "Num Grp'd: 5798\n",
      "Num KNN'd not Grp'd: 11\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4160\n",
      "Num Grp'd: 5618\n",
      "Num KNN'd not Grp'd: 224\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3143\n",
      "Num Grp'd: 5964\n",
      "Num KNN'd not Grp'd: 87\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4015\n",
      "Num Grp'd: 5742\n",
      "Num KNN'd not Grp'd: 431\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2260\n",
      "Num Grp'd: 5684\n",
      "Num KNN'd not Grp'd: 51\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2501\n",
      "Num Grp'd: 5635\n",
      "Num KNN'd not Grp'd: 232\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 739\n",
      "Num Grp'd: 3537\n",
      "Num KNN'd not Grp'd: 329\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 475\n",
      "Num Grp'd: 944\n",
      "Num KNN'd not Grp'd: 475\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3816\n",
      "Num Grp'd: 6241\n",
      "Num KNN'd not Grp'd: 246\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3500\n",
      "Num Grp'd: 5898\n",
      "Num KNN'd not Grp'd: 30\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4432\n",
      "Num Grp'd: 5558\n",
      "Num KNN'd not Grp'd: 142\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3836\n",
      "Num Grp'd: 5982\n",
      "Num KNN'd not Grp'd: 81\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2984\n",
      "Num Grp'd: 5764\n",
      "Num KNN'd not Grp'd: 106\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4603\n",
      "Num Grp'd: 5825\n",
      "Num KNN'd not Grp'd: 252\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3360\n",
      "Num Grp'd: 5761\n",
      "Num KNN'd not Grp'd: 280\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2899\n",
      "Num Grp'd: 5206\n",
      "Num KNN'd not Grp'd: 271\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1715\n",
      "Num Grp'd: 3813\n",
      "Num KNN'd not Grp'd: 433\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 994\n",
      "Num Grp'd: 466\n",
      "Num KNN'd not Grp'd: 825\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4999\n",
      "Num Grp'd: 5747\n",
      "Num KNN'd not Grp'd: 118\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4717\n",
      "Num Grp'd: 6073\n",
      "Num KNN'd not Grp'd: 116\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3491\n",
      "Num Grp'd: 6256\n",
      "Num KNN'd not Grp'd: 177\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4115\n",
      "Num Grp'd: 5954\n",
      "Num KNN'd not Grp'd: 58\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3732\n",
      "Num Grp'd: 6079\n",
      "Num KNN'd not Grp'd: 15\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3502\n",
      "Num Grp'd: 5581\n",
      "Num KNN'd not Grp'd: 383\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2942\n",
      "Num Grp'd: 5521\n",
      "Num KNN'd not Grp'd: 45\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1883\n",
      "Num Grp'd: 4937\n",
      "Num KNN'd not Grp'd: 199\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3233\n",
      "Num Grp'd: 2947\n",
      "Num KNN'd not Grp'd: 1733\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1058\n",
      "Num Grp'd: 629\n",
      "Num KNN'd not Grp'd: 861\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4602\n",
      "Num Grp'd: 5832\n",
      "Num KNN'd not Grp'd: 117\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3861\n",
      "Num Grp'd: 6173\n",
      "Num KNN'd not Grp'd: 45\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3880\n",
      "Num Grp'd: 6059\n",
      "Num KNN'd not Grp'd: 10\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3135\n",
      "Num Grp'd: 6063\n",
      "Num KNN'd not Grp'd: 2\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3169\n",
      "Num Grp'd: 5865\n",
      "Num KNN'd not Grp'd: 227\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3534\n",
      "Num Grp'd: 6078\n",
      "Num KNN'd not Grp'd: 43\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1827\n",
      "Num Grp'd: 5783\n",
      "Num KNN'd not Grp'd: 246\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3205\n",
      "Num Grp'd: 4651\n",
      "Num KNN'd not Grp'd: 820\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1054\n",
      "Num Grp'd: 4069\n",
      "Num KNN'd not Grp'd: 28\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 768\n",
      "Num Grp'd: 1323\n",
      "Num KNN'd not Grp'd: 421\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4490\n",
      "Num Grp'd: 6195\n",
      "Num KNN'd not Grp'd: 88\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3836\n",
      "Num Grp'd: 5984\n",
      "Num KNN'd not Grp'd: 90\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4450\n",
      "Num Grp'd: 6013\n",
      "Num KNN'd not Grp'd: 278\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4358\n",
      "Num Grp'd: 6168\n",
      "Num KNN'd not Grp'd: 39\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3772\n",
      "Num Grp'd: 6000\n",
      "Num KNN'd not Grp'd: 33\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3951\n",
      "Num Grp'd: 5885\n",
      "Num KNN'd not Grp'd: 55\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1896\n",
      "Num Grp'd: 5537\n",
      "Num KNN'd not Grp'd: 65\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2487\n",
      "Num Grp'd: 5036\n",
      "Num KNN'd not Grp'd: 382\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1665\n",
      "Num Grp'd: 4291\n",
      "Num KNN'd not Grp'd: 758\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1235\n",
      "Num Grp'd: 447\n",
      "Num KNN'd not Grp'd: 1189\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4282\n",
      "Num Grp'd: 5822\n",
      "Num KNN'd not Grp'd: 33\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4709\n",
      "Num Grp'd: 5996\n",
      "Num KNN'd not Grp'd: 220\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3534\n",
      "Num Grp'd: 6047\n",
      "Num KNN'd not Grp'd: 82\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3946\n",
      "Num Grp'd: 6214\n",
      "Num KNN'd not Grp'd: 118\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4206\n",
      "Num Grp'd: 5434\n",
      "Num KNN'd not Grp'd: 167\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4094\n",
      "Num Grp'd: 6016\n",
      "Num KNN'd not Grp'd: 74\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3415\n",
      "Num Grp'd: 6051\n",
      "Num KNN'd not Grp'd: 33\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1724\n",
      "Num Grp'd: 5180\n",
      "Num KNN'd not Grp'd: 115\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1863\n",
      "Num Grp'd: 3515\n",
      "Num KNN'd not Grp'd: 421\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 904\n",
      "Num Grp'd: 1298\n",
      "Num KNN'd not Grp'd: 510\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 8.0\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4455\n",
      "Num Grp'd: 5800\n",
      "Num KNN'd not Grp'd: 237\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 7.122222222222222\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4248\n",
      "Num Grp'd: 5727\n",
      "Num KNN'd not Grp'd: 134\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 6.244444444444444\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4153\n",
      "Num Grp'd: 5920\n",
      "Num KNN'd not Grp'd: 137\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 5.366666666666666\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4849\n",
      "Num Grp'd: 6263\n",
      "Num KNN'd not Grp'd: 14\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 4.488888888888889\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3921\n",
      "Num Grp'd: 5803\n",
      "Num KNN'd not Grp'd: 28\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 3.611111111111111\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 4098\n",
      "Num Grp'd: 6230\n",
      "Num KNN'd not Grp'd: 32\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 2.7333333333333334\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 3723\n",
      "Num Grp'd: 5498\n",
      "Num KNN'd not Grp'd: 658\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 1.8555555555555556\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 2265\n",
      "Num Grp'd: 4534\n",
      "Num KNN'd not Grp'd: 576\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.9777777777777777\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 1643\n",
      "Num Grp'd: 4675\n",
      "Num KNN'd not Grp'd: 314\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n",
      "\n",
      "alpha: 0.1\n",
      "Applying Mallows...\n",
      "getting result for partial shuffling...\n",
      "\n",
      "LDP\n",
      "Num KNN'd: 6353\n",
      "Num Grp'd: 5741\n",
      "Num KNN'd not Grp'd: 1602\n",
      "\n",
      "Pshuffed\n",
      "Num KNN'd: 995\n",
      "Num Grp'd: 412\n",
      "Num KNN'd not Grp'd: 873\n",
      "\n",
      "Uni Shuffed\n",
      "Num KNN'd: 426\n",
      "Num Grp'd: 880\n",
      "Num KNN'd not Grp'd: 397\n"
     ]
    }
   ],
   "source": [
    "# Choose reference permutation and Delta \n",
    "alphas = np.linspace(0.1, 8, 10, dtype = float)\n",
    "\n",
    "shuff_idx = np.arange(Y_tr.shape[0])\n",
    "np.random.shuffle(shuff_idx)\n",
    "Y_shuff = Y_tr[shuff_idx, :]\n",
    "\n",
    "Rcorr = 2 #attack radius\n",
    "K = 35\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",
    "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_tr, Y_tr, 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_tr, Y_shuff, Dmat, Distmat, \n",
    "                                                   R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "gen_perms = True\n",
    "sigma0 = np.argsort(T_tr[:, cols == 'age'].squeeze())\n",
    "Delta = 100\n",
    "n_trials = 20 \n",
    "for trial in tqdm(range(n_trials)): \n",
    "    for alpha in alphas[::-1]: \n",
    "        print(\"\\nalpha:\", alpha)\n",
    "        if gen_perms:  \n",
    "            print(\"Applying Mallows...\")\n",
    "            theta = (2 * alpha)/(Delta * (Delta - 1))\n",
    "            sig = mallows(theta, sigma0)\n",
    "\n",
    "            #save shufflings\n",
    "            np.save('./permutations_alpha_sweep/sigmasamp_alph{0:.3f}.npy'.format(alpha), sig)\n",
    "        else: \n",
    "            sig = np.load('./permutations_alpha_sweep/sigmasamp_alph{0:.3f}.npy'.format(alpha))\n",
    "\n",
    "        Y_pshuff = Y_tr[sig[np.argsort(sigma0)], :]\n",
    "\n",
    "        print(\"getting result for partial shuffling...\")\n",
    "        vuln_k_pshuff, vuln_grp_pshuff = k_vs_grp_attack(X_tr, Y_pshuff, Dmat, Distmat, \n",
    "                                                       R, Rcorr, K = K, t = 0.9)\n",
    "\n",
    "\n",
    "        vuln_pshuff[(trial, alpha)] = (vuln_k_pshuff, vuln_grp_pshuff)\n",
    "\n",
    "        print('\\nLDP')\n",
    "        print_stats(vuln_k_LDP, vuln_grp_LDP)\n",
    "        print('\\nPshuffed')\n",
    "        print_stats(vuln_k_pshuff, vuln_grp_pshuff)\n",
    "        print('\\nUni Shuffed')\n",
    "        print_stats(vuln_k_shuff, vuln_grp_shuff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 781,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('./alpha_sweep_results_adult.npy', vuln_pshuff)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 794,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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5/eRSqV29Y16/PixWR8YoVBo9Q9k48aNDlcPF2er/5S9wZwvlMGWO3fuOJT+3LlzZhfXmjVrWr1QcEpeDLj/t7L6heTl5bFVqlQx22/fvn1W01++fJkViURm6d97770yy8cpKChgc3NzLW7zxPlaXs6eByV/jAmFQnbLli0290lNTS3VF61///5OfArrcnNzWYZh+Hws9cfVarXsu+++a1YemUzGfvvtt24pE8dWAGQ0Gkv1B123bl25juWr+ZeXwWAwa4YTCATs/fv3LaZ94403zMr1/fff25WHq66P/nCNdee1z55grqioiB05cqRZuvDwcLuaxW2hYK6c7AnmjEYjm5WVxR4+fJgdPXo0q1AozPYRCATszp07y8zrvffeM9vPkYvuyZMnzfb94IMPLKb773//a5bu4sWLdudRFnv/yH2hDK42f/58s3yPHDliM72lYG7ChAl25fXNN9/YvV/JQTgvvPCCy/pHeeJ8LS9nz4P27dub7T927Fi79jt58qTZr3CBQODyQJVlnwwcKl6+Tz/91Gz7xYsX2YYNG5qlqV+/PnvhwgWXl6WksgKg7du3m22vWbMmW1RUVK5j+WL+5bVjxw6zvJ577jmraf/++2+ztC1btrQrD18J5srD0WusO699ZQVzOTk5bKdOnczSJCYmsjdu3HA6b5pnzkU6duxotsgwwzAQCoUIDw9Hu3bt8OWXX5q1i8vlcqxevRrdu3e3edz8/HyzSSBr1qyJt956y+5ytWjRAu3ateNfc32vypKenm53Hu7iC2VwVr9+/cxe//333w7tL5fLMXbsWLvSvvjii2avz549azFddnY2Nm7cyL8WCARYvHix4300LPDW+eoJd+/eNeu3JJfLMXnyZLv2bdGiBV566SX+tclkwurVq11eRlsrPyxZsgQtWrTA5cuX+fdGjBiB06dPo3Hjxi4vi6N69uxp9n9/+/ZtfP/995Umf2sszS1nTXJyMurWrcu/PnnyJC5duuSuovkER66x7rz2leXWrVto1aqVWf/UDh064Pjx4y6ZVoqCOQ8LDg7GO++8g6tXr+KVV14pM/2RI0eg1Wr51/379y+1xmtZOnbsyD+/d+8e39G3uHr16pm9njhxIjQajUP5OMsXylAeRqMReXl5SElJwd27d80eRqPRLO3Vq1cdOnZycjLCwsLsSlutWjUoFAr+tbVg+ODBg2bl6tKlC2rVquVQuazx1PnqDUeOHDF7/eKLLzo0z9Wrr75q83iuYGnwQ2ZmJnr16oX3338fhYWFAIDAwECsW7cOP/30k9k5421z5841ez1z5kyPXgO8nX9J6enp2LlzJ/86KCjI7EeBJa+99prZ64qwIoSrrrHuvPbZcvjwYSQlJeHff//l3xs+fDj27NmD0NBQl+The0PFKriCggIIBAJER0fblb7kBT8uLg537951KE+JRGL2+vbt26hatarZe507d0ZUVBQfABw/fhx16tTB66+/jr59+6Jp06YO35Qd5QtlsEdOTg5+++037Ny5ExcuXMDt27dLjcKyta8jHJ1wNiQkhK8BzsvLs5im5C/XDh06OJSHLZ46X73h9OnTZq9LjiYsS8n0p06dcrpMJRUP5oKDg3Hnzh28+uqrZisCNG/eHBs2bHDoJubI/2H16tXtTltScnIyevfujW3btgF4EszMnz8f06ZNK/cx/Sn/klatWmU2anPgwIFmq1ZY8uqrr2LSpEn8NWn16tWYM2dOqb8rX+aua6w7r33WrF69GiNHjkRRURGAJyP6Z82ahQkTJrg2I6cbaiupkn0m1q9fX2q0zqVLl9jt27ez7777rlmHcABs+/bt7Zp09bXXXivVh8rZx6+//moxry1btlid/DQkJIR94YUX2BkzZrD79+93aA4cR/pS+EIZrDEYDOwXX3xRrnmJuEfHjh1t5lGyz8XkyZMdKmPx87JatWoW0wwZMsQsj+3btzuUhy2ePF/Lw5nz4OWXXzbb157+riVxo5O5h7U+WeWRl5dnNvhBKpWavWYYhv3oo4/KNYefI/9f1tjbz+zKlStmk4UHBASUmjzVHX3m3J1/edSvX98sn7L6g3G6du1qtt+mTZtspveVPnPuvsa689rHsqWv3zVr1jR7LZfLy/y/KC/vV3NUEDExMahevbrZo2HDhujZsyeWLFmC8+fPo0aNGnz6Q4cO4e233y7zuFlZWS4vq1qttvh+37598ccff1hsv8/NzcXu3bsxZcoUdOzYEZGRkRgyZIjLaxd8oQyWGAwGDB48GOPHj3eq2cXeX5ccd9REljynXFXNb+nYrmDtfPW0kr/4y7OUUMl9srOznSpTcSXnG9TpdGav58yZgy+//NLna2jq169v1i9Mo9GUmq+wIufP+fvvv82aDGvXro02bdrY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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_plot_defaults()\n",
    "\n",
    "trials_alphas = list(vuln_pshuff.keys())\n",
    "# alpha_vals = np.array(alpha_vals)[[0,1,2,4]]\n",
    "\n",
    "total_LDP = []\n",
    "total_pshuff = []\n",
    "total_shuff = []\n",
    "\n",
    "n = len(X_tr)\n",
    "data = np.zeros((len(alphas), n_trials))\n",
    "total_LDP.append(len(vuln_k_LDP)/n)\n",
    "total_shuff.append(len(vuln_k_shuff)/n)\n",
    "\n",
    "attck_ldp = len(vuln_k_LDP)/n\n",
    "attck_shf = len(vuln_k_shuff)/n\n",
    "\n",
    "for trial_alpha in trials_alphas: \n",
    "    alpha_idx = trial_alpha[1] == alphas\n",
    "    data[alpha_idx, trial_alpha[0]] = len(vuln_pshuff[(trial_alpha[0], trial_alpha[1])][0])/n\n",
    "#     total_pshuff.append(len(vuln_pshuff[r][0])/n)\n",
    "    \n",
    "attck_mn = data.mean(axis = 1)\n",
    "attck_st = data.std(axis = 1)\n",
    "\n",
    "plt.plot(alphas, attck_mn, '-o', label = \"Mallows\", color = 'black')\n",
    "plt.plot(alphas, np.ones(len(alphas))*attck_ldp, '--', label = \"LDP\", alpha = 0.5, color = 'tomato')\n",
    "plt.plot(alphas, np.ones(len(alphas))*attck_shf, '--', label = \"Unif. Shuff.\", alpha = 0.5, color = 'seagreen')\n",
    "plt.fill_between(alphas, attck_mn + attck_st, attck_mn - attck_st, color = 'gray', alpha = 0.2)\n",
    "# plt.plot(np.ones(10)*4, np.linspace(total_shuff[0], total_LDP[0], 10), '--', \n",
    "#          alpha = 0.5, color = 'gray', linewidth = 2)\n",
    "plt.legend(loc = 'lower left')\n",
    "plt.title('Resistance to $k$-NN Attack')\n",
    "plt.xlabel('$\\\\alpha$')\n",
    "plt.ylabel('Frac. Inferred')\n",
    "plt.gca().invert_xaxis()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 796,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./adult_alpha_sweep_alpha_vals.npy', alphas)\n",
    "np.save('./adult_alpha_sweep_attck_mean.npy', attck_mn)\n",
    "np.save('./adult_alpha_sweep_attck_std.npy', attck_st)\n",
    "np.save('./adult_alpha_sweep_LDP.npy', np.ones(len(alphas))*attck_ldp)\n",
    "np.save('./adult_alpha_sweep_uniform_shuff.npy', np.ones(len(alphas))*attck_shf)"
   ]
  },
  {
   "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
}
