{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from sympy import * \n",
    "\n",
    "import math\n",
    "\n",
    "def nCr(n,r):\n",
    "    f = math.factorial\n",
    "    return f(n) / f(r) / f(n-r)\n",
    "\n",
    "def rref(A, tol=1.0e-12):\n",
    "    m, n = A.shape\n",
    "    i, j = 0, 0\n",
    "    jb = []\n",
    "\n",
    "    while i < m and j < n:\n",
    "        # Find value and index of largest element in the remainder of column j\n",
    "        k = np.argmax(np.abs(A[i:m, j])) + i\n",
    "        p = np.abs(A[k, j])\n",
    "        if p <= tol:\n",
    "            # The column is negligible, zero it out\n",
    "            A[i:m, j] = 0.0\n",
    "            j += 1\n",
    "        else:\n",
    "            # Remember the column index\n",
    "            jb.append(j)\n",
    "            if i != k:\n",
    "                # Swap the i-th and k-th rows\n",
    "                A[[i, k], j:n] = A[[k, i], j:n]\n",
    "            # Divide the pivot row i by the pivot element A[i, j]\n",
    "            A[i, j:n] = A[i, j:n] / A[i, j]\n",
    "            # Subtract multiples of the pivot row from all the other rows\n",
    "            for k in range(m):\n",
    "                if k != i:\n",
    "                    A[k, j:n] -= A[k, j] * A[i, j:n]\n",
    "            i += 1\n",
    "            j += 1\n",
    "    # Finished\n",
    "    return A"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 1. CodedBookDesign\n",
    "\n",
    "## 1.1. Proposed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coded Size= 45\n"
     ]
    }
   ],
   "source": [
    "N   = 40\n",
    "K   = 8\n",
    "T_0 = 4\n",
    "\n",
    "Bin_num = int(40/T_0)\n",
    "\n",
    "Bin_Sel_num = int(K/T_0)\n",
    "Bin_size = T_0\n",
    "\n",
    "B = int(nCr(Bin_num, Bin_Sel_num))\n",
    "\n",
    "print('Coded Size=', B)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(45, 2)\n"
     ]
    }
   ],
   "source": [
    "import itertools\n",
    "\n",
    "#defines the array of numbers and the two columns\n",
    "number = range(Bin_num)\n",
    "col_one = []\n",
    "\n",
    "#creates an array that holds the first four\n",
    "results = itertools.combinations(number,Bin_Sel_num)\n",
    "\n",
    "for x in results:\n",
    "#     print(x)\n",
    "    col_one.append(list(x))\n",
    "    \n",
    "col_one = np.array(col_one)\n",
    "print(np.shape(col_one))\n",
    "\n",
    "Codebook_tmp = np.zeros((B,Bin_num), dtype='int')\n",
    "Codebook = np.zeros((B,N), dtype='int')\n",
    "\n",
    "for b in range(B):    \n",
    "    for sel in col_one[b,:]:\n",
    "        stt_pos = sel * Bin_size\n",
    "        end_pos = (sel+1) * Bin_size\n",
    "        Codebook_tmp[b,sel] = 1\n",
    "        Codebook[b,stt_pos:end_pos] = 1\n",
    "    \n",
    "Codebook_Proposed = Codebook\n",
    "# print(Codebook_tmp)\n",
    "# print(Codebook[4,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coded Size= 4845\n",
      "(4845, 4)\n"
     ]
    }
   ],
   "source": [
    "N   = 40\n",
    "K   = 8\n",
    "T_0 = 2\n",
    "\n",
    "Bin_num = int(40/T_0)\n",
    "\n",
    "Bin_Sel_num = int(K/T_0)\n",
    "Bin_size = T_0\n",
    "\n",
    "B = int(nCr(Bin_num, Bin_Sel_num))\n",
    "\n",
    "print('Coded Size=', B)\n",
    "\n",
    "import itertools\n",
    "\n",
    "#defines the array of numbers and the two columns\n",
    "number = range(Bin_num)\n",
    "col_one = []\n",
    "\n",
    "#creates an array that holds the first four\n",
    "results = itertools.combinations(number,Bin_Sel_num)\n",
    "\n",
    "for x in results:\n",
    "#     print(x)\n",
    "    col_one.append(list(x))\n",
    "    \n",
    "col_one = np.array(col_one)\n",
    "print(np.shape(col_one))\n",
    "\n",
    "Codebook_tmp = np.zeros((B,Bin_num), dtype='int')\n",
    "Codebook = np.zeros((B,N), dtype='int')\n",
    "\n",
    "for b in range(B):    \n",
    "    for sel in col_one[b,:]:\n",
    "        stt_pos = sel * Bin_size\n",
    "        end_pos = (sel+1) * Bin_size\n",
    "        Codebook_tmp[b,sel] = 1\n",
    "        Codebook[b,stt_pos:end_pos] = 1\n",
    "    \n",
    "Codebook_Proposed_T2 = Codebook\n",
    "# print(Codebook_tmp)\n",
    "# print(Codebook[4,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4845\n"
     ]
    }
   ],
   "source": [
    "print(15*19*17)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1.2. Partition Codebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n",
      "  0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n",
      "  0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0\n",
      "  0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0\n",
      "  0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1\n",
      "  1 1 1 1]]\n"
     ]
    }
   ],
   "source": [
    "B_Partition = int(N/K)\n",
    "\n",
    "Codebook_Partition = np.zeros((B_Partition,N), dtype='int')\n",
    "\n",
    "for b in range(B_Partition):\n",
    "    stt_pos = b * K\n",
    "    end_pos = (b+1) * K\n",
    "    Codebook_Partition[b,stt_pos:end_pos] = 1\n",
    "print(Codebook_Partition)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Main Simulation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 0\n",
      "trial_idx= 1\n",
      "trial_idx= 2\n",
      "trial_idx= 3\n",
      "trial_idx= 4\n",
      "trial_idx= 5\n",
      "trial_idx= 6\n",
      "trial_idx= 7\n",
      "trial_idx= 8\n",
      "trial_idx= 9\n",
      "trial_idx= 10\n",
      "trial_idx= 11\n",
      "trial_idx= 12\n",
      "trial_idx= 13\n",
      "trial_idx= 14\n",
      "trial_idx= 15\n",
      "trial_idx= 16\n",
      "trial_idx= 17\n",
      "trial_idx= 18\n",
      "trial_idx= 19\n",
      "trial_idx= 20\n",
      "trial_idx= 21\n",
      "trial_idx= 22\n",
      "trial_idx= 23\n",
      "trial_idx= 24\n",
      "trial_idx= 25\n",
      "trial_idx= 26\n",
      "trial_idx= 27\n",
      "trial_idx= 28\n",
      "trial_idx= 29\n",
      "trial_idx= 30\n",
      "trial_idx= 31\n",
      "trial_idx= 32\n",
      "trial_idx= 33\n",
      "trial_idx= 34\n",
      "trial_idx= 35\n",
      "trial_idx= 36\n",
      "trial_idx= 37\n",
      "trial_idx= 38\n",
      "trial_idx= 39\n",
      "trial_idx= 40\n",
      "trial_idx= 41\n",
      "trial_idx= 42\n",
      "trial_idx= 43\n",
      "trial_idx= 44\n",
      "trial_idx= 45\n",
      "trial_idx= 46\n",
      "trial_idx= 47\n",
      "trial_idx= 48\n",
      "trial_idx= 49\n",
      "trial_idx= 50\n",
      "trial_idx= 51\n",
      "trial_idx= 52\n",
      "trial_idx= 53\n",
      "trial_idx= 54\n",
      "trial_idx= 55\n",
      "trial_idx= 56\n",
      "trial_idx= 57\n",
      "trial_idx= 58\n",
      "trial_idx= 59\n",
      "trial_idx= 60\n",
      "trial_idx= 61\n",
      "trial_idx= 62\n",
      "trial_idx= 63\n",
      "trial_idx= 64\n",
      "trial_idx= 65\n",
      "trial_idx= 66\n",
      "trial_idx= 67\n",
      "trial_idx= 68\n",
      "trial_idx= 69\n",
      "trial_idx= 70\n",
      "trial_idx= 71\n",
      "trial_idx= 72\n",
      "trial_idx= 73\n",
      "trial_idx= 74\n",
      "trial_idx= 75\n",
      "trial_idx= 76\n",
      "trial_idx= 77\n",
      "trial_idx= 78\n",
      "trial_idx= 79\n",
      "trial_idx= 80\n",
      "trial_idx= 81\n",
      "trial_idx= 82\n",
      "trial_idx= 83\n",
      "trial_idx= 84\n",
      "trial_idx= 85\n",
      "trial_idx= 86\n",
      "trial_idx= 87\n",
      "trial_idx= 88\n",
      "trial_idx= 89\n",
      "trial_idx= 90\n",
      "trial_idx= 91\n",
      "trial_idx= 92\n",
      "trial_idx= 93\n",
      "trial_idx= 94\n",
      "trial_idx= 95\n",
      "trial_idx= 96\n",
      "trial_idx= 97\n",
      "trial_idx= 98\n",
      "trial_idx= 99\n",
      "trial_idx= 100\n",
      "trial_idx= 101\n",
      "trial_idx= 102\n",
      "trial_idx= 103\n",
      "trial_idx= 104\n",
      "trial_idx= 105\n",
      "trial_idx= 106\n",
      "trial_idx= 107\n",
      "trial_idx= 108\n",
      "trial_idx= 109\n",
      "trial_idx= 110\n",
      "trial_idx= 111\n",
      "trial_idx= 112\n",
      "trial_idx= 113\n",
      "trial_idx= 114\n",
      "trial_idx= 115\n",
      "trial_idx= 116\n",
      "trial_idx= 117\n",
      "trial_idx= 118\n",
      "trial_idx= 119\n",
      "trial_idx= 120\n",
      "trial_idx= 121\n",
      "trial_idx= 122\n",
      "trial_idx= 123\n",
      "trial_idx= 124\n",
      "trial_idx= 125\n",
      "trial_idx= 126\n",
      "trial_idx= 127\n",
      "trial_idx= 128\n",
      "trial_idx= 129\n",
      "trial_idx= 130\n",
      "trial_idx= 131\n",
      "trial_idx= 132\n",
      "trial_idx= 133\n",
      "trial_idx= 134\n",
      "trial_idx= 135\n",
      "trial_idx= 136\n",
      "trial_idx= 137\n",
      "trial_idx= 138\n",
      "trial_idx= 139\n",
      "trial_idx= 140\n",
      "trial_idx= 141\n",
      "trial_idx= 142\n",
      "trial_idx= 143\n",
      "trial_idx= 144\n",
      "trial_idx= 145\n",
      "trial_idx= 146\n",
      "trial_idx= 147\n",
      "trial_idx= 148\n",
      "trial_idx= 149\n",
      "trial_idx= 150\n",
      "trial_idx= 151\n",
      "trial_idx= 152\n",
      "trial_idx= 153\n",
      "trial_idx= 154\n",
      "trial_idx= 155\n",
      "trial_idx= 156\n",
      "trial_idx= 157\n",
      "trial_idx= 158\n",
      "trial_idx= 159\n",
      "trial_idx= 160\n",
      "trial_idx= 161\n",
      "trial_idx= 162\n",
      "trial_idx= 163\n",
      "trial_idx= 164\n",
      "trial_idx= 165\n",
      "trial_idx= 166\n",
      "trial_idx= 167\n",
      "trial_idx= 168\n",
      "trial_idx= 169\n",
      "trial_idx= 170\n",
      "trial_idx= 171\n",
      "trial_idx= 172\n",
      "trial_idx= 173\n",
      "trial_idx= 174\n",
      "trial_idx= 175\n",
      "trial_idx= 176\n",
      "trial_idx= 177\n",
      "trial_idx= 178\n",
      "trial_idx= 179\n",
      "trial_idx= 180\n",
      "trial_idx= 181\n",
      "trial_idx= 182\n",
      "trial_idx= 183\n",
      "trial_idx= 184\n",
      "trial_idx= 185\n",
      "trial_idx= 186\n",
      "trial_idx= 187\n",
      "trial_idx= 188\n",
      "trial_idx= 189\n",
      "trial_idx= 190\n",
      "trial_idx= 191\n",
      "trial_idx= 192\n",
      "trial_idx= 193\n",
      "trial_idx= 194\n",
      "trial_idx= 195\n",
      "trial_idx= 196\n",
      "trial_idx= 197\n",
      "trial_idx= 198\n",
      "trial_idx= 199\n",
      "trial_idx= 200\n",
      "trial_idx= 201\n",
      "trial_idx= 202\n",
      "trial_idx= 203\n",
      "trial_idx= 204\n",
      "trial_idx= 205\n",
      "trial_idx= 206\n",
      "trial_idx= 207\n",
      "trial_idx= 208\n",
      "trial_idx= 209\n",
      "trial_idx= 210\n",
      "trial_idx= 211\n",
      "trial_idx= 212\n",
      "trial_idx= 213\n",
      "trial_idx= 214\n",
      "trial_idx= 215\n",
      "trial_idx= 216\n",
      "trial_idx= 217\n",
      "trial_idx= 218\n",
      "trial_idx= 219\n",
      "trial_idx= 220\n",
      "trial_idx= 221\n",
      "trial_idx= 222\n",
      "trial_idx= 223\n",
      "trial_idx= 224\n",
      "trial_idx= 225\n",
      "trial_idx= 226\n",
      "trial_idx= 227\n",
      "trial_idx= 228\n",
      "trial_idx= 229\n",
      "trial_idx= 230\n",
      "trial_idx= 231\n",
      "trial_idx= 232\n",
      "trial_idx= 233\n",
      "trial_idx= 234\n",
      "trial_idx= 235\n",
      "trial_idx= 236\n",
      "trial_idx= 237\n",
      "trial_idx= 238\n",
      "trial_idx= 239\n",
      "trial_idx= 240\n",
      "trial_idx= 241\n",
      "trial_idx= 242\n",
      "trial_idx= 243\n",
      "trial_idx= 244\n",
      "trial_idx= 245\n",
      "trial_idx= 246\n",
      "trial_idx= 247\n",
      "trial_idx= 248\n",
      "trial_idx= 249\n",
      "trial_idx= 250\n",
      "trial_idx= 251\n",
      "trial_idx= 252\n",
      "trial_idx= 253\n",
      "trial_idx= 254\n",
      "trial_idx= 255\n",
      "trial_idx= 256\n",
      "trial_idx= 257\n",
      "trial_idx= 258\n",
      "trial_idx= 259\n",
      "trial_idx= 260\n",
      "trial_idx= 261\n",
      "trial_idx= 262\n",
      "trial_idx= 263\n",
      "trial_idx= 264\n",
      "trial_idx= 265\n",
      "trial_idx= 266\n",
      "trial_idx= 267\n",
      "trial_idx= 268\n",
      "trial_idx= 269\n",
      "trial_idx= 270\n",
      "trial_idx= 271\n",
      "trial_idx= 272\n",
      "trial_idx= 273\n",
      "trial_idx= 274\n",
      "trial_idx= 275\n",
      "trial_idx= 276\n",
      "trial_idx= 277\n",
      "trial_idx= 278\n",
      "trial_idx= 279\n",
      "trial_idx= 280\n",
      "trial_idx= 281\n",
      "trial_idx= 282\n",
      "trial_idx= 283\n",
      "trial_idx= 284\n",
      "trial_idx= 285\n",
      "trial_idx= 286\n",
      "trial_idx= 287\n",
      "trial_idx= 288\n",
      "trial_idx= 289\n",
      "trial_idx= 290\n",
      "trial_idx= 291\n",
      "trial_idx= 292\n",
      "trial_idx= 293\n",
      "trial_idx= 294\n",
      "trial_idx= 295\n",
      "trial_idx= 296\n",
      "trial_idx= 297\n",
      "trial_idx= 298\n",
      "trial_idx= 299\n",
      "trial_idx= 300\n",
      "trial_idx= 301\n",
      "trial_idx= 302\n",
      "trial_idx= 303\n",
      "trial_idx= 304\n",
      "trial_idx= 305\n",
      "trial_idx= 306\n",
      "trial_idx= 307\n",
      "trial_idx= 308\n",
      "trial_idx= 309\n",
      "trial_idx= 310\n",
      "trial_idx= 311\n",
      "trial_idx= 312\n",
      "trial_idx= 313\n",
      "trial_idx= 314\n",
      "trial_idx= 315\n",
      "trial_idx= 316\n",
      "trial_idx= 317\n",
      "trial_idx= 318\n",
      "trial_idx= 319\n",
      "trial_idx= 320\n",
      "trial_idx= 321\n",
      "trial_idx= 322\n",
      "trial_idx= 323\n",
      "trial_idx= 324\n",
      "trial_idx= 325\n",
      "trial_idx= 326\n",
      "trial_idx= 327\n",
      "trial_idx= 328\n",
      "trial_idx= 329\n",
      "trial_idx= 330\n",
      "trial_idx= 331\n",
      "trial_idx= 332\n",
      "trial_idx= 333\n",
      "trial_idx= 334\n",
      "trial_idx= 335\n",
      "trial_idx= 336\n",
      "trial_idx= 337\n",
      "trial_idx= 338\n",
      "trial_idx= 339\n",
      "trial_idx= 340\n",
      "trial_idx= 341\n",
      "trial_idx= 342\n",
      "trial_idx= 343\n",
      "trial_idx= 344\n",
      "trial_idx= 345\n",
      "trial_idx= 346\n",
      "trial_idx= 347\n",
      "trial_idx= 348\n",
      "trial_idx= 349\n",
      "trial_idx= 350\n",
      "trial_idx= 351\n",
      "trial_idx= 352\n",
      "trial_idx= 353\n",
      "trial_idx= 354\n",
      "trial_idx= 355\n",
      "trial_idx= 356\n",
      "trial_idx= 357\n",
      "trial_idx= 358\n",
      "trial_idx= 359\n",
      "trial_idx= 360\n",
      "trial_idx= 361\n",
      "trial_idx= 362\n",
      "trial_idx= 363\n",
      "trial_idx= 364\n",
      "trial_idx= 365\n",
      "trial_idx= 366\n",
      "trial_idx= 367\n",
      "trial_idx= 368\n",
      "trial_idx= 369\n",
      "trial_idx= 370\n",
      "trial_idx= 371\n",
      "trial_idx= 372\n",
      "trial_idx= 373\n",
      "trial_idx= 374\n",
      "trial_idx= 375\n",
      "trial_idx= 376\n",
      "trial_idx= 377\n",
      "trial_idx= 378\n",
      "trial_idx= 379\n",
      "trial_idx= 380\n",
      "trial_idx= 381\n",
      "trial_idx= 382\n",
      "trial_idx= 383\n",
      "trial_idx= 384\n",
      "trial_idx= 385\n",
      "trial_idx= 386\n",
      "trial_idx= 387\n",
      "trial_idx= 388\n",
      "trial_idx= 389\n",
      "trial_idx= 390\n",
      "trial_idx= 391\n",
      "trial_idx= 392\n",
      "trial_idx= 393\n",
      "trial_idx= 394\n",
      "trial_idx= 395\n",
      "trial_idx= 396\n",
      "trial_idx= 397\n",
      "trial_idx= 398\n",
      "trial_idx= 399\n",
      "trial_idx= 400\n",
      "trial_idx= 401\n",
      "trial_idx= 402\n",
      "trial_idx= 403\n",
      "trial_idx= 404\n",
      "trial_idx= 405\n",
      "trial_idx= 406\n",
      "trial_idx= 407\n",
      "trial_idx= 408\n",
      "trial_idx= 409\n",
      "trial_idx= 410\n",
      "trial_idx= 411\n",
      "trial_idx= 412\n",
      "trial_idx= 413\n",
      "trial_idx= 414\n",
      "trial_idx= 415\n",
      "trial_idx= 416\n",
      "trial_idx= 417\n",
      "trial_idx= 418\n",
      "trial_idx= 419\n",
      "trial_idx= 420\n",
      "trial_idx= 421\n",
      "trial_idx= 422\n",
      "trial_idx= 423\n",
      "trial_idx= 424\n",
      "trial_idx= 425\n",
      "trial_idx= 426\n",
      "trial_idx= 427\n",
      "trial_idx= 428\n",
      "trial_idx= 429\n",
      "trial_idx= 430\n",
      "trial_idx= 431\n",
      "trial_idx= 432\n",
      "trial_idx= 433\n",
      "trial_idx= 434\n",
      "trial_idx= 435\n",
      "trial_idx= 436\n",
      "trial_idx= 437\n",
      "trial_idx= 438\n",
      "trial_idx= 439\n",
      "trial_idx= 440\n",
      "trial_idx= 441\n",
      "trial_idx= 442\n",
      "trial_idx= 443\n",
      "trial_idx= 444\n",
      "trial_idx= 445\n",
      "trial_idx= 446\n",
      "trial_idx= 447\n",
      "trial_idx= 448\n",
      "trial_idx= 449\n",
      "trial_idx= 450\n",
      "trial_idx= 451\n",
      "trial_idx= 452\n",
      "trial_idx= 453\n",
      "trial_idx= 454\n",
      "trial_idx= 455\n",
      "trial_idx= 456\n",
      "trial_idx= 457\n",
      "trial_idx= 458\n",
      "trial_idx= 459\n",
      "trial_idx= 460\n",
      "trial_idx= 461\n",
      "trial_idx= 462\n",
      "trial_idx= 463\n",
      "trial_idx= 464\n",
      "trial_idx= 465\n",
      "trial_idx= 466\n",
      "trial_idx= 467\n",
      "trial_idx= 468\n",
      "trial_idx= 469\n",
      "trial_idx= 470\n",
      "trial_idx= 471\n",
      "trial_idx= 472\n",
      "trial_idx= 473\n",
      "trial_idx= 474\n",
      "trial_idx= 475\n",
      "trial_idx= 476\n",
      "trial_idx= 477\n",
      "trial_idx= 478\n",
      "trial_idx= 479\n",
      "trial_idx= 480\n",
      "trial_idx= 481\n",
      "trial_idx= 482\n",
      "trial_idx= 483\n",
      "trial_idx= 484\n",
      "trial_idx= 485\n",
      "trial_idx= 486\n",
      "trial_idx= 487\n",
      "trial_idx= 488\n",
      "trial_idx= 489\n",
      "trial_idx= 490\n",
      "trial_idx= 491\n",
      "trial_idx= 492\n",
      "trial_idx= 493\n",
      "trial_idx= 494\n",
      "trial_idx= 495\n",
      "trial_idx= 496\n",
      "trial_idx= 497\n",
      "trial_idx= 498\n",
      "trial_idx= 499\n",
      "trial_idx= 500\n",
      "trial_idx= 501\n",
      "trial_idx= 502\n",
      "trial_idx= 503\n",
      "trial_idx= 504\n",
      "trial_idx= 505\n",
      "trial_idx= 506\n",
      "trial_idx= 507\n",
      "trial_idx= 508\n",
      "trial_idx= 509\n",
      "trial_idx= 510\n",
      "trial_idx= 511\n",
      "trial_idx= 512\n",
      "trial_idx= 513\n",
      "trial_idx= 514\n",
      "trial_idx= 515\n",
      "trial_idx= 516\n",
      "trial_idx= 517\n",
      "trial_idx= 518\n",
      "trial_idx= 519\n",
      "trial_idx= 520\n",
      "trial_idx= 521\n",
      "trial_idx= 522\n",
      "trial_idx= 523\n",
      "trial_idx= 524\n",
      "trial_idx= 525\n",
      "trial_idx= 526\n",
      "trial_idx= 527\n",
      "trial_idx= 528\n",
      "trial_idx= 529\n",
      "trial_idx= 530\n",
      "trial_idx= 531\n",
      "trial_idx= 532\n",
      "trial_idx= 533\n",
      "trial_idx= 534\n",
      "trial_idx= 535\n",
      "trial_idx= 536\n",
      "trial_idx= 537\n",
      "trial_idx= 538\n",
      "trial_idx= 539\n",
      "trial_idx= 540\n",
      "trial_idx= 541\n",
      "trial_idx= 542\n",
      "trial_idx= 543\n",
      "trial_idx= 544\n",
      "trial_idx= 545\n",
      "trial_idx= 546\n",
      "trial_idx= 547\n",
      "trial_idx= 548\n",
      "trial_idx= 549\n",
      "trial_idx= 550\n",
      "trial_idx= 551\n",
      "trial_idx= 552\n",
      "trial_idx= 553\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 554\n",
      "trial_idx= 555\n",
      "trial_idx= 556\n",
      "trial_idx= 557\n",
      "trial_idx= 558\n",
      "trial_idx= 559\n",
      "trial_idx= 560\n",
      "trial_idx= 561\n",
      "trial_idx= 562\n",
      "trial_idx= 563\n",
      "trial_idx= 564\n",
      "trial_idx= 565\n",
      "trial_idx= 566\n",
      "trial_idx= 567\n",
      "trial_idx= 568\n",
      "trial_idx= 569\n",
      "trial_idx= 570\n",
      "trial_idx= 571\n",
      "trial_idx= 572\n",
      "trial_idx= 573\n",
      "trial_idx= 574\n",
      "trial_idx= 575\n",
      "trial_idx= 576\n",
      "trial_idx= 577\n",
      "trial_idx= 578\n",
      "trial_idx= 579\n",
      "trial_idx= 580\n",
      "trial_idx= 581\n",
      "trial_idx= 582\n",
      "trial_idx= 583\n",
      "trial_idx= 584\n",
      "trial_idx= 585\n",
      "trial_idx= 586\n",
      "trial_idx= 587\n",
      "trial_idx= 588\n",
      "trial_idx= 589\n",
      "trial_idx= 590\n",
      "trial_idx= 591\n",
      "trial_idx= 592\n",
      "trial_idx= 593\n",
      "trial_idx= 594\n",
      "trial_idx= 595\n",
      "trial_idx= 596\n",
      "trial_idx= 597\n",
      "trial_idx= 598\n",
      "trial_idx= 599\n",
      "trial_idx= 600\n",
      "trial_idx= 601\n",
      "trial_idx= 602\n",
      "trial_idx= 603\n",
      "trial_idx= 604\n",
      "trial_idx= 605\n",
      "trial_idx= 606\n",
      "trial_idx= 607\n",
      "trial_idx= 608\n",
      "trial_idx= 609\n",
      "trial_idx= 610\n",
      "trial_idx= 611\n",
      "trial_idx= 612\n",
      "trial_idx= 613\n",
      "trial_idx= 614\n",
      "trial_idx= 615\n",
      "trial_idx= 616\n",
      "trial_idx= 617\n",
      "trial_idx= 618\n",
      "trial_idx= 619\n",
      "trial_idx= 620\n",
      "trial_idx= 621\n",
      "trial_idx= 622\n",
      "trial_idx= 623\n",
      "trial_idx= 624\n",
      "trial_idx= 625\n",
      "trial_idx= 626\n",
      "trial_idx= 627\n",
      "trial_idx= 628\n",
      "trial_idx= 629\n",
      "trial_idx= 630\n",
      "trial_idx= 631\n",
      "trial_idx= 632\n",
      "trial_idx= 633\n",
      "trial_idx= 634\n",
      "trial_idx= 635\n",
      "trial_idx= 636\n",
      "trial_idx= 637\n",
      "trial_idx= 638\n",
      "trial_idx= 639\n",
      "trial_idx= 640\n",
      "trial_idx= 641\n",
      "trial_idx= 642\n",
      "trial_idx= 643\n",
      "trial_idx= 644\n",
      "trial_idx= 645\n",
      "trial_idx= 646\n",
      "trial_idx= 647\n",
      "trial_idx= 648\n",
      "trial_idx= 649\n",
      "trial_idx= 650\n",
      "trial_idx= 651\n",
      "trial_idx= 652\n",
      "trial_idx= 653\n",
      "trial_idx= 654\n",
      "trial_idx= 655\n",
      "trial_idx= 656\n",
      "trial_idx= 657\n",
      "trial_idx= 658\n",
      "trial_idx= 659\n",
      "trial_idx= 660\n",
      "trial_idx= 661\n",
      "trial_idx= 662\n",
      "trial_idx= 663\n",
      "trial_idx= 664\n",
      "trial_idx= 665\n",
      "trial_idx= 666\n",
      "trial_idx= 667\n",
      "trial_idx= 668\n",
      "trial_idx= 669\n",
      "trial_idx= 670\n",
      "trial_idx= 671\n",
      "trial_idx= 672\n",
      "trial_idx= 673\n",
      "trial_idx= 674\n",
      "trial_idx= 675\n",
      "trial_idx= 676\n",
      "trial_idx= 677\n",
      "trial_idx= 678\n",
      "trial_idx= 679\n",
      "trial_idx= 680\n",
      "trial_idx= 681\n",
      "trial_idx= 682\n",
      "trial_idx= 683\n",
      "trial_idx= 684\n",
      "trial_idx= 685\n",
      "trial_idx= 686\n",
      "trial_idx= 687\n",
      "trial_idx= 688\n",
      "trial_idx= 689\n",
      "trial_idx= 690\n",
      "trial_idx= 691\n",
      "trial_idx= 692\n",
      "trial_idx= 693\n",
      "trial_idx= 694\n",
      "trial_idx= 695\n",
      "trial_idx= 696\n",
      "trial_idx= 697\n",
      "trial_idx= 698\n",
      "trial_idx= 699\n",
      "trial_idx= 700\n",
      "trial_idx= 701\n",
      "trial_idx= 702\n",
      "trial_idx= 703\n",
      "trial_idx= 704\n",
      "trial_idx= 705\n",
      "trial_idx= 706\n",
      "trial_idx= 707\n",
      "trial_idx= 708\n",
      "trial_idx= 709\n",
      "trial_idx= 710\n",
      "trial_idx= 711\n",
      "trial_idx= 712\n",
      "trial_idx= 713\n",
      "trial_idx= 714\n",
      "trial_idx= 715\n",
      "trial_idx= 716\n",
      "trial_idx= 717\n",
      "trial_idx= 718\n",
      "trial_idx= 719\n",
      "trial_idx= 720\n",
      "trial_idx= 721\n",
      "trial_idx= 722\n",
      "trial_idx= 723\n",
      "trial_idx= 724\n",
      "trial_idx= 725\n",
      "trial_idx= 726\n",
      "trial_idx= 727\n",
      "trial_idx= 728\n",
      "trial_idx= 729\n",
      "trial_idx= 730\n",
      "trial_idx= 731\n",
      "trial_idx= 732\n",
      "trial_idx= 733\n",
      "trial_idx= 734\n",
      "trial_idx= 735\n",
      "trial_idx= 736\n",
      "trial_idx= 737\n",
      "trial_idx= 738\n",
      "trial_idx= 739\n",
      "trial_idx= 740\n",
      "trial_idx= 741\n",
      "trial_idx= 742\n",
      "trial_idx= 743\n",
      "trial_idx= 744\n",
      "trial_idx= 745\n",
      "trial_idx= 746\n",
      "trial_idx= 747\n",
      "trial_idx= 748\n",
      "trial_idx= 749\n",
      "trial_idx= 750\n",
      "trial_idx= 751\n",
      "trial_idx= 752\n",
      "trial_idx= 753\n",
      "trial_idx= 754\n",
      "trial_idx= 755\n",
      "trial_idx= 756\n",
      "trial_idx= 757\n",
      "trial_idx= 758\n",
      "trial_idx= 759\n",
      "trial_idx= 760\n",
      "trial_idx= 761\n",
      "trial_idx= 762\n",
      "trial_idx= 763\n",
      "trial_idx= 764\n",
      "trial_idx= 765\n",
      "trial_idx= 766\n",
      "trial_idx= 767\n",
      "trial_idx= 768\n",
      "trial_idx= 769\n",
      "trial_idx= 770\n",
      "trial_idx= 771\n",
      "trial_idx= 772\n",
      "trial_idx= 773\n",
      "trial_idx= 774\n",
      "trial_idx= 775\n",
      "trial_idx= 776\n",
      "trial_idx= 777\n",
      "trial_idx= 778\n",
      "trial_idx= 779\n",
      "trial_idx= 780\n",
      "trial_idx= 781\n",
      "trial_idx= 782\n",
      "trial_idx= 783\n",
      "trial_idx= 784\n",
      "trial_idx= 785\n",
      "trial_idx= 786\n",
      "trial_idx= 787\n",
      "trial_idx= 788\n",
      "trial_idx= 789\n",
      "trial_idx= 790\n",
      "trial_idx= 791\n",
      "trial_idx= 792\n",
      "trial_idx= 793\n",
      "trial_idx= 794\n",
      "trial_idx= 795\n",
      "trial_idx= 796\n",
      "trial_idx= 797\n",
      "trial_idx= 798\n",
      "trial_idx= 799\n",
      "trial_idx= 800\n",
      "trial_idx= 801\n",
      "trial_idx= 802\n",
      "trial_idx= 803\n",
      "trial_idx= 804\n",
      "trial_idx= 805\n",
      "trial_idx= 806\n",
      "trial_idx= 807\n",
      "trial_idx= 808\n",
      "trial_idx= 809\n",
      "trial_idx= 810\n",
      "trial_idx= 811\n",
      "trial_idx= 812\n",
      "trial_idx= 813\n",
      "trial_idx= 814\n",
      "trial_idx= 815\n",
      "trial_idx= 816\n",
      "trial_idx= 817\n",
      "trial_idx= 818\n",
      "trial_idx= 819\n",
      "trial_idx= 820\n",
      "trial_idx= 821\n",
      "trial_idx= 822\n",
      "trial_idx= 823\n",
      "trial_idx= 824\n",
      "trial_idx= 825\n",
      "trial_idx= 826\n",
      "trial_idx= 827\n",
      "trial_idx= 828\n",
      "trial_idx= 829\n",
      "trial_idx= 830\n",
      "trial_idx= 831\n",
      "trial_idx= 832\n",
      "trial_idx= 833\n",
      "trial_idx= 834\n",
      "trial_idx= 835\n",
      "trial_idx= 836\n",
      "trial_idx= 837\n",
      "trial_idx= 838\n",
      "trial_idx= 839\n",
      "trial_idx= 840\n",
      "trial_idx= 841\n",
      "trial_idx= 842\n",
      "trial_idx= 843\n",
      "trial_idx= 844\n",
      "trial_idx= 845\n",
      "trial_idx= 846\n",
      "trial_idx= 847\n",
      "trial_idx= 848\n",
      "trial_idx= 849\n",
      "trial_idx= 850\n",
      "trial_idx= 851\n",
      "trial_idx= 852\n",
      "trial_idx= 853\n",
      "trial_idx= 854\n",
      "trial_idx= 855\n",
      "trial_idx= 856\n",
      "trial_idx= 857\n",
      "trial_idx= 858\n",
      "trial_idx= 859\n",
      "trial_idx= 860\n",
      "trial_idx= 861\n",
      "trial_idx= 862\n",
      "trial_idx= 863\n",
      "trial_idx= 864\n",
      "trial_idx= 865\n",
      "trial_idx= 866\n",
      "trial_idx= 867\n",
      "trial_idx= 868\n",
      "trial_idx= 869\n",
      "trial_idx= 870\n",
      "trial_idx= 871\n",
      "trial_idx= 872\n",
      "trial_idx= 873\n",
      "trial_idx= 874\n",
      "trial_idx= 875\n",
      "trial_idx= 876\n",
      "trial_idx= 877\n",
      "trial_idx= 878\n",
      "trial_idx= 879\n",
      "trial_idx= 880\n",
      "trial_idx= 881\n",
      "trial_idx= 882\n",
      "trial_idx= 883\n",
      "trial_idx= 884\n",
      "trial_idx= 885\n",
      "trial_idx= 886\n",
      "trial_idx= 887\n",
      "trial_idx= 888\n",
      "trial_idx= 889\n",
      "trial_idx= 890\n",
      "trial_idx= 891\n",
      "trial_idx= 892\n",
      "trial_idx= 893\n",
      "trial_idx= 894\n",
      "trial_idx= 895\n",
      "trial_idx= 896\n",
      "trial_idx= 897\n",
      "trial_idx= 898\n",
      "trial_idx= 899\n",
      "trial_idx= 900\n",
      "trial_idx= 901\n",
      "trial_idx= 902\n",
      "trial_idx= 903\n",
      "trial_idx= 904\n",
      "trial_idx= 905\n",
      "trial_idx= 906\n",
      "trial_idx= 907\n",
      "trial_idx= 908\n",
      "trial_idx= 909\n",
      "trial_idx= 910\n",
      "trial_idx= 911\n",
      "trial_idx= 912\n",
      "trial_idx= 913\n",
      "trial_idx= 914\n",
      "trial_idx= 915\n",
      "trial_idx= 916\n",
      "trial_idx= 917\n",
      "trial_idx= 918\n",
      "trial_idx= 919\n",
      "trial_idx= 920\n",
      "trial_idx= 921\n",
      "trial_idx= 922\n",
      "trial_idx= 923\n",
      "trial_idx= 924\n",
      "trial_idx= 925\n",
      "trial_idx= 926\n",
      "trial_idx= 927\n",
      "trial_idx= 928\n",
      "trial_idx= 929\n",
      "trial_idx= 930\n",
      "trial_idx= 931\n",
      "trial_idx= 932\n",
      "trial_idx= 933\n",
      "trial_idx= 934\n",
      "trial_idx= 935\n",
      "trial_idx= 936\n",
      "trial_idx= 937\n",
      "trial_idx= 938\n",
      "trial_idx= 939\n",
      "trial_idx= 940\n",
      "trial_idx= 941\n",
      "trial_idx= 942\n",
      "trial_idx= 943\n",
      "trial_idx= 944\n",
      "trial_idx= 945\n",
      "trial_idx= 946\n",
      "trial_idx= 947\n",
      "trial_idx= 948\n",
      "trial_idx= 949\n",
      "trial_idx= 950\n",
      "trial_idx= 951\n",
      "trial_idx= 952\n",
      "trial_idx= 953\n",
      "trial_idx= 954\n",
      "trial_idx= 955\n",
      "trial_idx= 956\n",
      "trial_idx= 957\n",
      "trial_idx= 958\n",
      "trial_idx= 959\n",
      "trial_idx= 960\n",
      "trial_idx= 961\n",
      "trial_idx= 962\n",
      "trial_idx= 963\n",
      "trial_idx= 964\n",
      "trial_idx= 965\n",
      "trial_idx= 966\n",
      "trial_idx= 967\n",
      "trial_idx= 968\n",
      "trial_idx= 969\n",
      "trial_idx= 970\n",
      "trial_idx= 971\n",
      "trial_idx= 972\n",
      "trial_idx= 973\n",
      "trial_idx= 974\n",
      "trial_idx= 975\n",
      "trial_idx= 976\n",
      "trial_idx= 977\n",
      "trial_idx= 978\n",
      "trial_idx= 979\n",
      "trial_idx= 980\n",
      "trial_idx= 981\n",
      "trial_idx= 982\n",
      "trial_idx= 983\n",
      "trial_idx= 984\n",
      "trial_idx= 985\n",
      "trial_idx= 986\n",
      "trial_idx= 987\n",
      "trial_idx= 988\n",
      "trial_idx= 989\n",
      "trial_idx= 990\n",
      "trial_idx= 991\n",
      "trial_idx= 992\n",
      "trial_idx= 993\n",
      "trial_idx= 994\n",
      "trial_idx= 995\n",
      "trial_idx= 996\n",
      "trial_idx= 997\n",
      "trial_idx= 998\n",
      "trial_idx= 999\n"
     ]
    }
   ],
   "source": [
    "J = 50  # Total iterations\n",
    "p = 0.3 # dropout rate\n",
    "\n",
    "\n",
    "\n",
    "is_print = False\n",
    "# is_print = False\n",
    "\n",
    "is_print_tmp = True\n",
    "\n",
    "N_schemes = 4\n",
    "\n",
    "N_trial = 1000\n",
    "\n",
    "Agg_Card = np.zeros((N_schemes, N_trial, J))\n",
    "Privacy  = np.zeros((N_schemes, N_trial, J))\n",
    "\n",
    "\n",
    "for trial_idx in range(N_trial):\n",
    "    \n",
    "    print('trial_idx=',trial_idx)\n",
    "#     print()\n",
    "    \n",
    "    P_random    = []\n",
    "    P_partition = []\n",
    "    P_proposed  = []\n",
    "    P_proposed_T2 = []\n",
    "    \n",
    "    for j in range(J):\n",
    "        u = np.random.binomial(1, 1-p, size=(N))\n",
    "        if is_print:\n",
    "            print('[iter=',j,'] Surviving vector u=',u)\n",
    "\n",
    "        if np.sum(u) < K:\n",
    "            p_tmp = np.zero(N)\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "            P_partition.append(p_tmp)\n",
    "            P_proposed.append(p_tmp)\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "        else:\n",
    "            result = np.where(u == 1)\n",
    "\n",
    "            ###############################\n",
    "            # 1. Random Selection\n",
    "            ###############################\n",
    "            select = np.random.choice(result[0], K, replace=False)\n",
    "\n",
    "            p_tmp = np.zeros(N)\n",
    "            p_tmp[select] = 1\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "\n",
    "            # 1.1 Calculate Privacy\n",
    "            P = np.array(P_random)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[0,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[0,trial_idx,j] = np.min([partial_sum, Privacy[0,trial_idx,j-1]])\n",
    "\n",
    "            # 1.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_random),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[0,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print('[iter=',j,'] @Random Method, Codebook selection')\n",
    "\n",
    "            ###############################\n",
    "            # 2. Partition\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Partition * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "                p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "\n",
    "            P_partition.append(p_tmp)\n",
    "\n",
    "            # 2.1 Calculate Privacy\n",
    "            P = np.array(P_partition)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[1,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[1,trial_idx,j] = np.min([partial_sum, Privacy[1,trial_idx,j-1]])\n",
    "\n",
    "            # 2.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_partition),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[1,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "            ###############################\n",
    "            # 3. Proposed, T_0 = 4\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[2,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[2,trial_idx,j] = np.min([partial_sum, Privacy[2,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[2,trial_idx,j] = acc_card/(j+1)\n",
    "            \n",
    "            \n",
    "            \n",
    "            ###############################\n",
    "            # 4. Proposed, T_0 = 2\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed_T2 * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed_T2[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed_T2)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[3,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[3,trial_idx,j] = np.min([partial_sum, Privacy[3,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed_T2),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[3,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print()\n",
    "\n",
    "\n",
    "        # random selection\n",
    "\n",
    "#     print(Privacy)\n",
    "#     print()\n",
    "#     print(Agg_Card)\n",
    "\n",
    "\n",
    "mean_priavcy_p03 = np.sum(Privacy, axis=1)/N_trial\n",
    "print(np.shape(mean_priavcy_p03))\n",
    "\n",
    "mean_Agg_Card_p03 = np.sum(Agg_Card, axis=1)/N_trial\n",
    "print(np.shape(mean_Agg_Card_p03))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# matplotlib.use('Agg')\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(mean_priavcy_p03[0,:], label='random')\n",
    "plt.plot(mean_priavcy_p03[1,:], label='partition')\n",
    "plt.plot(mean_priavcy_p03[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_priavcy_p03[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Privacy')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "plt.plot(mean_Agg_Card_p03[0,:], label='random')\n",
    "plt.plot(mean_Agg_Card_p03[1,:], label='partition')\n",
    "plt.plot(mean_Agg_Card_p03[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_Agg_Card_p03[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Aggregation Cardinality')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 0\n",
      "trial_idx= 1\n",
      "trial_idx= 2\n",
      "trial_idx= 3\n",
      "trial_idx= 4\n",
      "trial_idx= 5\n",
      "trial_idx= 6\n",
      "trial_idx= 7\n",
      "trial_idx= 8\n",
      "trial_idx= 9\n",
      "trial_idx= 10\n",
      "trial_idx= 11\n",
      "trial_idx= 12\n",
      "trial_idx= 13\n",
      "trial_idx= 14\n",
      "trial_idx= 15\n",
      "trial_idx= 16\n",
      "trial_idx= 17\n",
      "trial_idx= 18\n",
      "trial_idx= 19\n",
      "trial_idx= 20\n",
      "trial_idx= 21\n",
      "trial_idx= 22\n",
      "trial_idx= 23\n",
      "trial_idx= 24\n",
      "trial_idx= 25\n",
      "trial_idx= 26\n",
      "trial_idx= 27\n",
      "trial_idx= 28\n",
      "trial_idx= 29\n",
      "trial_idx= 30\n",
      "trial_idx= 31\n",
      "trial_idx= 32\n",
      "trial_idx= 33\n",
      "trial_idx= 34\n",
      "trial_idx= 35\n",
      "trial_idx= 36\n",
      "trial_idx= 37\n",
      "trial_idx= 38\n",
      "trial_idx= 39\n",
      "trial_idx= 40\n",
      "trial_idx= 41\n",
      "trial_idx= 42\n",
      "trial_idx= 43\n",
      "trial_idx= 44\n",
      "trial_idx= 45\n",
      "trial_idx= 46\n",
      "trial_idx= 47\n",
      "trial_idx= 48\n",
      "trial_idx= 49\n",
      "trial_idx= 50\n",
      "trial_idx= 51\n",
      "trial_idx= 52\n",
      "trial_idx= 53\n",
      "trial_idx= 54\n",
      "trial_idx= 55\n",
      "trial_idx= 56\n",
      "trial_idx= 57\n",
      "trial_idx= 58\n",
      "trial_idx= 59\n",
      "trial_idx= 60\n",
      "trial_idx= 61\n",
      "trial_idx= 62\n",
      "trial_idx= 63\n",
      "trial_idx= 64\n",
      "trial_idx= 65\n",
      "trial_idx= 66\n",
      "trial_idx= 67\n",
      "trial_idx= 68\n",
      "trial_idx= 69\n",
      "trial_idx= 70\n",
      "trial_idx= 71\n",
      "trial_idx= 72\n",
      "trial_idx= 73\n",
      "trial_idx= 74\n",
      "trial_idx= 75\n",
      "trial_idx= 76\n",
      "trial_idx= 77\n",
      "trial_idx= 78\n",
      "trial_idx= 79\n",
      "trial_idx= 80\n",
      "trial_idx= 81\n",
      "trial_idx= 82\n",
      "trial_idx= 83\n",
      "trial_idx= 84\n",
      "trial_idx= 85\n",
      "trial_idx= 86\n",
      "trial_idx= 87\n",
      "trial_idx= 88\n",
      "trial_idx= 89\n",
      "trial_idx= 90\n",
      "trial_idx= 91\n",
      "trial_idx= 92\n",
      "trial_idx= 93\n",
      "trial_idx= 94\n",
      "trial_idx= 95\n",
      "trial_idx= 96\n",
      "trial_idx= 97\n",
      "trial_idx= 98\n",
      "trial_idx= 99\n",
      "trial_idx= 100\n",
      "trial_idx= 101\n",
      "trial_idx= 102\n",
      "trial_idx= 103\n",
      "trial_idx= 104\n",
      "trial_idx= 105\n",
      "trial_idx= 106\n",
      "trial_idx= 107\n",
      "trial_idx= 108\n",
      "trial_idx= 109\n",
      "trial_idx= 110\n",
      "trial_idx= 111\n",
      "trial_idx= 112\n",
      "trial_idx= 113\n",
      "trial_idx= 114\n",
      "trial_idx= 115\n",
      "trial_idx= 116\n",
      "trial_idx= 117\n",
      "trial_idx= 118\n",
      "trial_idx= 119\n",
      "trial_idx= 120\n",
      "trial_idx= 121\n",
      "trial_idx= 122\n",
      "trial_idx= 123\n",
      "trial_idx= 124\n",
      "trial_idx= 125\n",
      "trial_idx= 126\n",
      "trial_idx= 127\n",
      "trial_idx= 128\n",
      "trial_idx= 129\n",
      "trial_idx= 130\n",
      "trial_idx= 131\n",
      "trial_idx= 132\n",
      "trial_idx= 133\n",
      "trial_idx= 134\n",
      "trial_idx= 135\n",
      "trial_idx= 136\n",
      "trial_idx= 137\n",
      "trial_idx= 138\n",
      "trial_idx= 139\n",
      "trial_idx= 140\n",
      "trial_idx= 141\n",
      "trial_idx= 142\n",
      "trial_idx= 143\n",
      "trial_idx= 144\n",
      "trial_idx= 145\n",
      "trial_idx= 146\n",
      "trial_idx= 147\n",
      "trial_idx= 148\n",
      "trial_idx= 149\n",
      "trial_idx= 150\n",
      "trial_idx= 151\n",
      "trial_idx= 152\n",
      "trial_idx= 153\n",
      "trial_idx= 154\n",
      "trial_idx= 155\n",
      "trial_idx= 156\n",
      "trial_idx= 157\n",
      "trial_idx= 158\n",
      "trial_idx= 159\n",
      "trial_idx= 160\n",
      "trial_idx= 161\n",
      "trial_idx= 162\n",
      "trial_idx= 163\n",
      "trial_idx= 164\n",
      "trial_idx= 165\n",
      "trial_idx= 166\n",
      "trial_idx= 167\n",
      "trial_idx= 168\n",
      "trial_idx= 169\n",
      "trial_idx= 170\n",
      "trial_idx= 171\n",
      "trial_idx= 172\n",
      "trial_idx= 173\n",
      "trial_idx= 174\n",
      "trial_idx= 175\n",
      "trial_idx= 176\n",
      "trial_idx= 177\n",
      "trial_idx= 178\n",
      "trial_idx= 179\n",
      "trial_idx= 180\n",
      "trial_idx= 181\n",
      "trial_idx= 182\n",
      "trial_idx= 183\n",
      "trial_idx= 184\n",
      "trial_idx= 185\n",
      "trial_idx= 186\n",
      "trial_idx= 187\n",
      "trial_idx= 188\n",
      "trial_idx= 189\n",
      "trial_idx= 190\n",
      "trial_idx= 191\n",
      "trial_idx= 192\n",
      "trial_idx= 193\n",
      "trial_idx= 194\n",
      "trial_idx= 195\n",
      "trial_idx= 196\n",
      "trial_idx= 197\n",
      "trial_idx= 198\n",
      "trial_idx= 199\n",
      "trial_idx= 200\n",
      "trial_idx= 201\n",
      "trial_idx= 202\n",
      "trial_idx= 203\n",
      "trial_idx= 204\n",
      "trial_idx= 205\n",
      "trial_idx= 206\n",
      "trial_idx= 207\n",
      "trial_idx= 208\n",
      "trial_idx= 209\n",
      "trial_idx= 210\n",
      "trial_idx= 211\n",
      "trial_idx= 212\n",
      "trial_idx= 213\n",
      "trial_idx= 214\n",
      "trial_idx= 215\n",
      "trial_idx= 216\n",
      "trial_idx= 217\n",
      "trial_idx= 218\n",
      "trial_idx= 219\n",
      "trial_idx= 220\n",
      "trial_idx= 221\n",
      "trial_idx= 222\n",
      "trial_idx= 223\n",
      "trial_idx= 224\n",
      "trial_idx= 225\n",
      "trial_idx= 226\n",
      "trial_idx= 227\n",
      "trial_idx= 228\n",
      "trial_idx= 229\n",
      "trial_idx= 230\n",
      "trial_idx= 231\n",
      "trial_idx= 232\n",
      "trial_idx= 233\n",
      "trial_idx= 234\n",
      "trial_idx= 235\n",
      "trial_idx= 236\n",
      "trial_idx= 237\n",
      "trial_idx= 238\n",
      "trial_idx= 239\n",
      "trial_idx= 240\n",
      "trial_idx= 241\n",
      "trial_idx= 242\n",
      "trial_idx= 243\n",
      "trial_idx= 244\n",
      "trial_idx= 245\n",
      "trial_idx= 246\n",
      "trial_idx= 247\n",
      "trial_idx= 248\n",
      "trial_idx= 249\n",
      "trial_idx= 250\n",
      "trial_idx= 251\n",
      "trial_idx= 252\n",
      "trial_idx= 253\n",
      "trial_idx= 254\n",
      "trial_idx= 255\n",
      "trial_idx= 256\n",
      "trial_idx= 257\n",
      "trial_idx= 258\n",
      "trial_idx= 259\n",
      "trial_idx= 260\n",
      "trial_idx= 261\n",
      "trial_idx= 262\n",
      "trial_idx= 263\n",
      "trial_idx= 264\n",
      "trial_idx= 265\n",
      "trial_idx= 266\n",
      "trial_idx= 267\n",
      "trial_idx= 268\n",
      "trial_idx= 269\n",
      "trial_idx= 270\n",
      "trial_idx= 271\n",
      "trial_idx= 272\n",
      "trial_idx= 273\n",
      "trial_idx= 274\n",
      "trial_idx= 275\n",
      "trial_idx= 276\n",
      "trial_idx= 277\n",
      "trial_idx= 278\n",
      "trial_idx= 279\n",
      "trial_idx= 280\n",
      "trial_idx= 281\n",
      "trial_idx= 282\n",
      "trial_idx= 283\n",
      "trial_idx= 284\n",
      "trial_idx= 285\n",
      "trial_idx= 286\n",
      "trial_idx= 287\n",
      "trial_idx= 288\n",
      "trial_idx= 289\n",
      "trial_idx= 290\n",
      "trial_idx= 291\n",
      "trial_idx= 292\n",
      "trial_idx= 293\n",
      "trial_idx= 294\n",
      "trial_idx= 295\n",
      "trial_idx= 296\n",
      "trial_idx= 297\n",
      "trial_idx= 298\n",
      "trial_idx= 299\n",
      "trial_idx= 300\n",
      "trial_idx= 301\n",
      "trial_idx= 302\n",
      "trial_idx= 303\n",
      "trial_idx= 304\n",
      "trial_idx= 305\n",
      "trial_idx= 306\n",
      "trial_idx= 307\n",
      "trial_idx= 308\n",
      "trial_idx= 309\n",
      "trial_idx= 310\n",
      "trial_idx= 311\n",
      "trial_idx= 312\n",
      "trial_idx= 313\n",
      "trial_idx= 314\n",
      "trial_idx= 315\n",
      "trial_idx= 316\n",
      "trial_idx= 317\n",
      "trial_idx= 318\n",
      "trial_idx= 319\n",
      "trial_idx= 320\n",
      "trial_idx= 321\n",
      "trial_idx= 322\n",
      "trial_idx= 323\n",
      "trial_idx= 324\n",
      "trial_idx= 325\n",
      "trial_idx= 326\n",
      "trial_idx= 327\n",
      "trial_idx= 328\n",
      "trial_idx= 329\n",
      "trial_idx= 330\n",
      "trial_idx= 331\n",
      "trial_idx= 332\n",
      "trial_idx= 333\n",
      "trial_idx= 334\n",
      "trial_idx= 335\n",
      "trial_idx= 336\n",
      "trial_idx= 337\n",
      "trial_idx= 338\n",
      "trial_idx= 339\n",
      "trial_idx= 340\n",
      "trial_idx= 341\n",
      "trial_idx= 342\n",
      "trial_idx= 343\n",
      "trial_idx= 344\n",
      "trial_idx= 345\n",
      "trial_idx= 346\n",
      "trial_idx= 347\n",
      "trial_idx= 348\n",
      "trial_idx= 349\n",
      "trial_idx= 350\n",
      "trial_idx= 351\n",
      "trial_idx= 352\n",
      "trial_idx= 353\n",
      "trial_idx= 354\n",
      "trial_idx= 355\n",
      "trial_idx= 356\n",
      "trial_idx= 357\n",
      "trial_idx= 358\n",
      "trial_idx= 359\n",
      "trial_idx= 360\n",
      "trial_idx= 361\n",
      "trial_idx= 362\n",
      "trial_idx= 363\n",
      "trial_idx= 364\n",
      "trial_idx= 365\n",
      "trial_idx= 366\n",
      "trial_idx= 367\n",
      "trial_idx= 368\n",
      "trial_idx= 369\n",
      "trial_idx= 370\n",
      "trial_idx= 371\n",
      "trial_idx= 372\n",
      "trial_idx= 373\n",
      "trial_idx= 374\n",
      "trial_idx= 375\n",
      "trial_idx= 376\n",
      "trial_idx= 377\n",
      "trial_idx= 378\n",
      "trial_idx= 379\n",
      "trial_idx= 380\n",
      "trial_idx= 381\n",
      "trial_idx= 382\n",
      "trial_idx= 383\n",
      "trial_idx= 384\n",
      "trial_idx= 385\n",
      "trial_idx= 386\n",
      "trial_idx= 387\n",
      "trial_idx= 388\n",
      "trial_idx= 389\n",
      "trial_idx= 390\n",
      "trial_idx= 391\n",
      "trial_idx= 392\n",
      "trial_idx= 393\n",
      "trial_idx= 394\n",
      "trial_idx= 395\n",
      "trial_idx= 396\n",
      "trial_idx= 397\n",
      "trial_idx= 398\n",
      "trial_idx= 399\n",
      "trial_idx= 400\n",
      "trial_idx= 401\n",
      "trial_idx= 402\n",
      "trial_idx= 403\n",
      "trial_idx= 404\n",
      "trial_idx= 405\n",
      "trial_idx= 406\n",
      "trial_idx= 407\n",
      "trial_idx= 408\n",
      "trial_idx= 409\n",
      "trial_idx= 410\n",
      "trial_idx= 411\n",
      "trial_idx= 412\n",
      "trial_idx= 413\n",
      "trial_idx= 414\n",
      "trial_idx= 415\n",
      "trial_idx= 416\n",
      "trial_idx= 417\n",
      "trial_idx= 418\n",
      "trial_idx= 419\n",
      "trial_idx= 420\n",
      "trial_idx= 421\n",
      "trial_idx= 422\n",
      "trial_idx= 423\n",
      "trial_idx= 424\n",
      "trial_idx= 425\n",
      "trial_idx= 426\n",
      "trial_idx= 427\n",
      "trial_idx= 428\n",
      "trial_idx= 429\n",
      "trial_idx= 430\n",
      "trial_idx= 431\n",
      "trial_idx= 432\n",
      "trial_idx= 433\n",
      "trial_idx= 434\n",
      "trial_idx= 435\n",
      "trial_idx= 436\n",
      "trial_idx= 437\n",
      "trial_idx= 438\n",
      "trial_idx= 439\n",
      "trial_idx= 440\n",
      "trial_idx= 441\n",
      "trial_idx= 442\n",
      "trial_idx= 443\n",
      "trial_idx= 444\n",
      "trial_idx= 445\n",
      "trial_idx= 446\n",
      "trial_idx= 447\n",
      "trial_idx= 448\n",
      "trial_idx= 449\n",
      "trial_idx= 450\n",
      "trial_idx= 451\n",
      "trial_idx= 452\n",
      "trial_idx= 453\n",
      "trial_idx= 454\n",
      "trial_idx= 455\n",
      "trial_idx= 456\n",
      "trial_idx= 457\n",
      "trial_idx= 458\n",
      "trial_idx= 459\n",
      "trial_idx= 460\n",
      "trial_idx= 461\n",
      "trial_idx= 462\n",
      "trial_idx= 463\n",
      "trial_idx= 464\n",
      "trial_idx= 465\n",
      "trial_idx= 466\n",
      "trial_idx= 467\n",
      "trial_idx= 468\n",
      "trial_idx= 469\n",
      "trial_idx= 470\n",
      "trial_idx= 471\n",
      "trial_idx= 472\n",
      "trial_idx= 473\n",
      "trial_idx= 474\n",
      "trial_idx= 475\n",
      "trial_idx= 476\n",
      "trial_idx= 477\n",
      "trial_idx= 478\n",
      "trial_idx= 479\n",
      "trial_idx= 480\n",
      "trial_idx= 481\n",
      "trial_idx= 482\n",
      "trial_idx= 483\n",
      "trial_idx= 484\n",
      "trial_idx= 485\n",
      "trial_idx= 486\n",
      "trial_idx= 487\n",
      "trial_idx= 488\n",
      "trial_idx= 489\n",
      "trial_idx= 490\n",
      "trial_idx= 491\n",
      "trial_idx= 492\n",
      "trial_idx= 493\n",
      "trial_idx= 494\n",
      "trial_idx= 495\n",
      "trial_idx= 496\n",
      "trial_idx= 497\n",
      "trial_idx= 498\n",
      "trial_idx= 499\n",
      "trial_idx= 500\n",
      "trial_idx= 501\n",
      "trial_idx= 502\n",
      "trial_idx= 503\n",
      "trial_idx= 504\n",
      "trial_idx= 505\n",
      "trial_idx= 506\n",
      "trial_idx= 507\n",
      "trial_idx= 508\n",
      "trial_idx= 509\n",
      "trial_idx= 510\n",
      "trial_idx= 511\n",
      "trial_idx= 512\n",
      "trial_idx= 513\n",
      "trial_idx= 514\n",
      "trial_idx= 515\n",
      "trial_idx= 516\n",
      "trial_idx= 517\n",
      "trial_idx= 518\n",
      "trial_idx= 519\n",
      "trial_idx= 520\n",
      "trial_idx= 521\n",
      "trial_idx= 522\n",
      "trial_idx= 523\n",
      "trial_idx= 524\n",
      "trial_idx= 525\n",
      "trial_idx= 526\n",
      "trial_idx= 527\n",
      "trial_idx= 528\n",
      "trial_idx= 529\n",
      "trial_idx= 530\n",
      "trial_idx= 531\n",
      "trial_idx= 532\n",
      "trial_idx= 533\n",
      "trial_idx= 534\n",
      "trial_idx= 535\n",
      "trial_idx= 536\n",
      "trial_idx= 537\n",
      "trial_idx= 538\n",
      "trial_idx= 539\n",
      "trial_idx= 540\n",
      "trial_idx= 541\n",
      "trial_idx= 542\n",
      "trial_idx= 543\n",
      "trial_idx= 544\n",
      "trial_idx= 545\n",
      "trial_idx= 546\n",
      "trial_idx= 547\n",
      "trial_idx= 548\n",
      "trial_idx= 549\n",
      "trial_idx= 550\n",
      "trial_idx= 551\n",
      "trial_idx= 552\n",
      "trial_idx= 553\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 554\n",
      "trial_idx= 555\n",
      "trial_idx= 556\n",
      "trial_idx= 557\n",
      "trial_idx= 558\n",
      "trial_idx= 559\n",
      "trial_idx= 560\n",
      "trial_idx= 561\n",
      "trial_idx= 562\n",
      "trial_idx= 563\n",
      "trial_idx= 564\n",
      "trial_idx= 565\n",
      "trial_idx= 566\n",
      "trial_idx= 567\n",
      "trial_idx= 568\n",
      "trial_idx= 569\n",
      "trial_idx= 570\n",
      "trial_idx= 571\n",
      "trial_idx= 572\n",
      "trial_idx= 573\n",
      "trial_idx= 574\n",
      "trial_idx= 575\n",
      "trial_idx= 576\n",
      "trial_idx= 577\n",
      "trial_idx= 578\n",
      "trial_idx= 579\n",
      "trial_idx= 580\n",
      "trial_idx= 581\n",
      "trial_idx= 582\n",
      "trial_idx= 583\n",
      "trial_idx= 584\n",
      "trial_idx= 585\n",
      "trial_idx= 586\n",
      "trial_idx= 587\n",
      "trial_idx= 588\n",
      "trial_idx= 589\n",
      "trial_idx= 590\n",
      "trial_idx= 591\n",
      "trial_idx= 592\n",
      "trial_idx= 593\n",
      "trial_idx= 594\n",
      "trial_idx= 595\n",
      "trial_idx= 596\n",
      "trial_idx= 597\n",
      "trial_idx= 598\n",
      "trial_idx= 599\n",
      "trial_idx= 600\n",
      "trial_idx= 601\n",
      "trial_idx= 602\n",
      "trial_idx= 603\n",
      "trial_idx= 604\n",
      "trial_idx= 605\n",
      "trial_idx= 606\n",
      "trial_idx= 607\n",
      "trial_idx= 608\n",
      "trial_idx= 609\n",
      "trial_idx= 610\n",
      "trial_idx= 611\n",
      "trial_idx= 612\n",
      "trial_idx= 613\n",
      "trial_idx= 614\n",
      "trial_idx= 615\n",
      "trial_idx= 616\n",
      "trial_idx= 617\n",
      "trial_idx= 618\n",
      "trial_idx= 619\n",
      "trial_idx= 620\n",
      "trial_idx= 621\n",
      "trial_idx= 622\n",
      "trial_idx= 623\n",
      "trial_idx= 624\n",
      "trial_idx= 625\n",
      "trial_idx= 626\n",
      "trial_idx= 627\n",
      "trial_idx= 628\n",
      "trial_idx= 629\n",
      "trial_idx= 630\n",
      "trial_idx= 631\n",
      "trial_idx= 632\n",
      "trial_idx= 633\n",
      "trial_idx= 634\n",
      "trial_idx= 635\n",
      "trial_idx= 636\n",
      "trial_idx= 637\n",
      "trial_idx= 638\n",
      "trial_idx= 639\n",
      "trial_idx= 640\n",
      "trial_idx= 641\n",
      "trial_idx= 642\n",
      "trial_idx= 643\n",
      "trial_idx= 644\n",
      "trial_idx= 645\n",
      "trial_idx= 646\n",
      "trial_idx= 647\n",
      "trial_idx= 648\n",
      "trial_idx= 649\n",
      "trial_idx= 650\n",
      "trial_idx= 651\n",
      "trial_idx= 652\n",
      "trial_idx= 653\n",
      "trial_idx= 654\n",
      "trial_idx= 655\n",
      "trial_idx= 656\n",
      "trial_idx= 657\n",
      "trial_idx= 658\n",
      "trial_idx= 659\n",
      "trial_idx= 660\n",
      "trial_idx= 661\n",
      "trial_idx= 662\n",
      "trial_idx= 663\n",
      "trial_idx= 664\n",
      "trial_idx= 665\n",
      "trial_idx= 666\n",
      "trial_idx= 667\n",
      "trial_idx= 668\n",
      "trial_idx= 669\n",
      "trial_idx= 670\n",
      "trial_idx= 671\n",
      "trial_idx= 672\n",
      "trial_idx= 673\n",
      "trial_idx= 674\n",
      "trial_idx= 675\n",
      "trial_idx= 676\n",
      "trial_idx= 677\n",
      "trial_idx= 678\n",
      "trial_idx= 679\n",
      "trial_idx= 680\n",
      "trial_idx= 681\n",
      "trial_idx= 682\n",
      "trial_idx= 683\n",
      "trial_idx= 684\n",
      "trial_idx= 685\n",
      "trial_idx= 686\n",
      "trial_idx= 687\n",
      "trial_idx= 688\n",
      "trial_idx= 689\n",
      "trial_idx= 690\n",
      "trial_idx= 691\n",
      "trial_idx= 692\n",
      "trial_idx= 693\n",
      "trial_idx= 694\n",
      "trial_idx= 695\n",
      "trial_idx= 696\n",
      "trial_idx= 697\n",
      "trial_idx= 698\n",
      "trial_idx= 699\n",
      "trial_idx= 700\n",
      "trial_idx= 701\n",
      "trial_idx= 702\n",
      "trial_idx= 703\n",
      "trial_idx= 704\n",
      "trial_idx= 705\n",
      "trial_idx= 706\n",
      "trial_idx= 707\n",
      "trial_idx= 708\n",
      "trial_idx= 709\n",
      "trial_idx= 710\n",
      "trial_idx= 711\n",
      "trial_idx= 712\n",
      "trial_idx= 713\n",
      "trial_idx= 714\n",
      "trial_idx= 715\n",
      "trial_idx= 716\n",
      "trial_idx= 717\n",
      "trial_idx= 718\n",
      "trial_idx= 719\n",
      "trial_idx= 720\n",
      "trial_idx= 721\n",
      "trial_idx= 722\n",
      "trial_idx= 723\n",
      "trial_idx= 724\n",
      "trial_idx= 725\n",
      "trial_idx= 726\n",
      "trial_idx= 727\n",
      "trial_idx= 728\n",
      "trial_idx= 729\n",
      "trial_idx= 730\n",
      "trial_idx= 731\n",
      "trial_idx= 732\n",
      "trial_idx= 733\n",
      "trial_idx= 734\n",
      "trial_idx= 735\n",
      "trial_idx= 736\n",
      "trial_idx= 737\n",
      "trial_idx= 738\n",
      "trial_idx= 739\n",
      "trial_idx= 740\n",
      "trial_idx= 741\n",
      "trial_idx= 742\n",
      "trial_idx= 743\n",
      "trial_idx= 744\n",
      "trial_idx= 745\n",
      "trial_idx= 746\n",
      "trial_idx= 747\n",
      "trial_idx= 748\n",
      "trial_idx= 749\n",
      "trial_idx= 750\n",
      "trial_idx= 751\n",
      "trial_idx= 752\n",
      "trial_idx= 753\n",
      "trial_idx= 754\n",
      "trial_idx= 755\n",
      "trial_idx= 756\n",
      "trial_idx= 757\n",
      "trial_idx= 758\n",
      "trial_idx= 759\n",
      "trial_idx= 760\n",
      "trial_idx= 761\n",
      "trial_idx= 762\n",
      "trial_idx= 763\n",
      "trial_idx= 764\n",
      "trial_idx= 765\n",
      "trial_idx= 766\n",
      "trial_idx= 767\n",
      "trial_idx= 768\n",
      "trial_idx= 769\n",
      "trial_idx= 770\n",
      "trial_idx= 771\n",
      "trial_idx= 772\n",
      "trial_idx= 773\n",
      "trial_idx= 774\n",
      "trial_idx= 775\n",
      "trial_idx= 776\n",
      "trial_idx= 777\n",
      "trial_idx= 778\n",
      "trial_idx= 779\n",
      "trial_idx= 780\n",
      "trial_idx= 781\n",
      "trial_idx= 782\n",
      "trial_idx= 783\n",
      "trial_idx= 784\n",
      "trial_idx= 785\n",
      "trial_idx= 786\n",
      "trial_idx= 787\n",
      "trial_idx= 788\n",
      "trial_idx= 789\n",
      "trial_idx= 790\n",
      "trial_idx= 791\n",
      "trial_idx= 792\n",
      "trial_idx= 793\n",
      "trial_idx= 794\n",
      "trial_idx= 795\n",
      "trial_idx= 796\n",
      "trial_idx= 797\n",
      "trial_idx= 798\n",
      "trial_idx= 799\n",
      "trial_idx= 800\n",
      "trial_idx= 801\n",
      "trial_idx= 802\n",
      "trial_idx= 803\n",
      "trial_idx= 804\n",
      "trial_idx= 805\n",
      "trial_idx= 806\n",
      "trial_idx= 807\n",
      "trial_idx= 808\n",
      "trial_idx= 809\n",
      "trial_idx= 810\n",
      "trial_idx= 811\n",
      "trial_idx= 812\n",
      "trial_idx= 813\n",
      "trial_idx= 814\n",
      "trial_idx= 815\n",
      "trial_idx= 816\n",
      "trial_idx= 817\n",
      "trial_idx= 818\n",
      "trial_idx= 819\n",
      "trial_idx= 820\n",
      "trial_idx= 821\n",
      "trial_idx= 822\n",
      "trial_idx= 823\n",
      "trial_idx= 824\n",
      "trial_idx= 825\n",
      "trial_idx= 826\n",
      "trial_idx= 827\n",
      "trial_idx= 828\n",
      "trial_idx= 829\n",
      "trial_idx= 830\n",
      "trial_idx= 831\n",
      "trial_idx= 832\n",
      "trial_idx= 833\n",
      "trial_idx= 834\n",
      "trial_idx= 835\n",
      "trial_idx= 836\n",
      "trial_idx= 837\n",
      "trial_idx= 838\n",
      "trial_idx= 839\n",
      "trial_idx= 840\n",
      "trial_idx= 841\n",
      "trial_idx= 842\n",
      "trial_idx= 843\n",
      "trial_idx= 844\n",
      "trial_idx= 845\n",
      "trial_idx= 846\n",
      "trial_idx= 847\n",
      "trial_idx= 848\n",
      "trial_idx= 849\n",
      "trial_idx= 850\n",
      "trial_idx= 851\n",
      "trial_idx= 852\n",
      "trial_idx= 853\n",
      "trial_idx= 854\n",
      "trial_idx= 855\n",
      "trial_idx= 856\n",
      "trial_idx= 857\n",
      "trial_idx= 858\n",
      "trial_idx= 859\n",
      "trial_idx= 860\n",
      "trial_idx= 861\n",
      "trial_idx= 862\n",
      "trial_idx= 863\n",
      "trial_idx= 864\n",
      "trial_idx= 865\n",
      "trial_idx= 866\n",
      "trial_idx= 867\n",
      "trial_idx= 868\n",
      "trial_idx= 869\n",
      "trial_idx= 870\n",
      "trial_idx= 871\n",
      "trial_idx= 872\n",
      "trial_idx= 873\n",
      "trial_idx= 874\n",
      "trial_idx= 875\n",
      "trial_idx= 876\n",
      "trial_idx= 877\n",
      "trial_idx= 878\n",
      "trial_idx= 879\n",
      "trial_idx= 880\n",
      "trial_idx= 881\n",
      "trial_idx= 882\n",
      "trial_idx= 883\n",
      "trial_idx= 884\n",
      "trial_idx= 885\n",
      "trial_idx= 886\n",
      "trial_idx= 887\n",
      "trial_idx= 888\n",
      "trial_idx= 889\n",
      "trial_idx= 890\n",
      "trial_idx= 891\n",
      "trial_idx= 892\n",
      "trial_idx= 893\n",
      "trial_idx= 894\n",
      "trial_idx= 895\n",
      "trial_idx= 896\n",
      "trial_idx= 897\n",
      "trial_idx= 898\n",
      "trial_idx= 899\n",
      "trial_idx= 900\n",
      "trial_idx= 901\n",
      "trial_idx= 902\n",
      "trial_idx= 903\n",
      "trial_idx= 904\n",
      "trial_idx= 905\n",
      "trial_idx= 906\n",
      "trial_idx= 907\n",
      "trial_idx= 908\n",
      "trial_idx= 909\n",
      "trial_idx= 910\n",
      "trial_idx= 911\n",
      "trial_idx= 912\n",
      "trial_idx= 913\n",
      "trial_idx= 914\n",
      "trial_idx= 915\n",
      "trial_idx= 916\n",
      "trial_idx= 917\n",
      "trial_idx= 918\n",
      "trial_idx= 919\n",
      "trial_idx= 920\n",
      "trial_idx= 921\n",
      "trial_idx= 922\n",
      "trial_idx= 923\n",
      "trial_idx= 924\n",
      "trial_idx= 925\n",
      "trial_idx= 926\n",
      "trial_idx= 927\n",
      "trial_idx= 928\n",
      "trial_idx= 929\n",
      "trial_idx= 930\n",
      "trial_idx= 931\n",
      "trial_idx= 932\n",
      "trial_idx= 933\n",
      "trial_idx= 934\n",
      "trial_idx= 935\n",
      "trial_idx= 936\n",
      "trial_idx= 937\n",
      "trial_idx= 938\n",
      "trial_idx= 939\n",
      "trial_idx= 940\n",
      "trial_idx= 941\n",
      "trial_idx= 942\n",
      "trial_idx= 943\n",
      "trial_idx= 944\n",
      "trial_idx= 945\n",
      "trial_idx= 946\n",
      "trial_idx= 947\n",
      "trial_idx= 948\n",
      "trial_idx= 949\n",
      "trial_idx= 950\n",
      "trial_idx= 951\n",
      "trial_idx= 952\n",
      "trial_idx= 953\n",
      "trial_idx= 954\n",
      "trial_idx= 955\n",
      "trial_idx= 956\n",
      "trial_idx= 957\n",
      "trial_idx= 958\n",
      "trial_idx= 959\n",
      "trial_idx= 960\n",
      "trial_idx= 961\n",
      "trial_idx= 962\n",
      "trial_idx= 963\n",
      "trial_idx= 964\n",
      "trial_idx= 965\n",
      "trial_idx= 966\n",
      "trial_idx= 967\n",
      "trial_idx= 968\n",
      "trial_idx= 969\n",
      "trial_idx= 970\n",
      "trial_idx= 971\n",
      "trial_idx= 972\n",
      "trial_idx= 973\n",
      "trial_idx= 974\n",
      "trial_idx= 975\n",
      "trial_idx= 976\n",
      "trial_idx= 977\n",
      "trial_idx= 978\n",
      "trial_idx= 979\n",
      "trial_idx= 980\n",
      "trial_idx= 981\n",
      "trial_idx= 982\n",
      "trial_idx= 983\n",
      "trial_idx= 984\n",
      "trial_idx= 985\n",
      "trial_idx= 986\n",
      "trial_idx= 987\n",
      "trial_idx= 988\n",
      "trial_idx= 989\n",
      "trial_idx= 990\n",
      "trial_idx= 991\n",
      "trial_idx= 992\n",
      "trial_idx= 993\n",
      "trial_idx= 994\n",
      "trial_idx= 995\n",
      "trial_idx= 996\n",
      "trial_idx= 997\n",
      "trial_idx= 998\n",
      "trial_idx= 999\n"
     ]
    }
   ],
   "source": [
    "J = 50  # Total iterations\n",
    "p = 0.2 # dropout rate\n",
    "\n",
    "\n",
    "\n",
    "is_print = False\n",
    "# is_print = False\n",
    "\n",
    "is_print_tmp = True\n",
    "\n",
    "N_schemes = 4\n",
    "\n",
    "N_trial = 1000\n",
    "\n",
    "Agg_Card = np.zeros((N_schemes, N_trial, J))\n",
    "Privacy  = np.zeros((N_schemes, N_trial, J))\n",
    "\n",
    "\n",
    "for trial_idx in range(N_trial):\n",
    "    \n",
    "    print('trial_idx=',trial_idx)\n",
    "#     print()\n",
    "    \n",
    "    P_random    = []\n",
    "    P_partition = []\n",
    "    P_proposed  = []\n",
    "    P_proposed_T2 = []\n",
    "    \n",
    "    for j in range(J):\n",
    "        u = np.random.binomial(1, 1-p, size=(N))\n",
    "        if is_print:\n",
    "            print('[iter=',j,'] Surviving vector u=',u)\n",
    "\n",
    "        if np.sum(u) < K:\n",
    "            p_tmp = np.zero(N)\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "            P_partition.append(p_tmp)\n",
    "            P_proposed.append(p_tmp)\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "        else:\n",
    "            result = np.where(u == 1)\n",
    "\n",
    "            ###############################\n",
    "            # 1. Random Selection\n",
    "            ###############################\n",
    "            select = np.random.choice(result[0], K, replace=False)\n",
    "\n",
    "            p_tmp = np.zeros(N)\n",
    "            p_tmp[select] = 1\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "\n",
    "            # 1.1 Calculate Privacy\n",
    "            P = np.array(P_random)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[0,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[0,trial_idx,j] = np.min([partial_sum, Privacy[0,trial_idx,j-1]])\n",
    "\n",
    "            # 1.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_random),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[0,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print('[iter=',j,'] @Random Method, Codebook selection')\n",
    "\n",
    "            ###############################\n",
    "            # 2. Partition\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Partition * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "                p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "\n",
    "            P_partition.append(p_tmp)\n",
    "\n",
    "            # 2.1 Calculate Privacy\n",
    "            P = np.array(P_partition)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[1,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[1,trial_idx,j] = np.min([partial_sum, Privacy[1,trial_idx,j-1]])\n",
    "\n",
    "            # 2.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_partition),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[1,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "            ###############################\n",
    "            # 3. Proposed, T_0 = 4\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[2,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[2,trial_idx,j] = np.min([partial_sum, Privacy[2,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[2,trial_idx,j] = acc_card/(j+1)\n",
    "            \n",
    "            \n",
    "            \n",
    "            ###############################\n",
    "            # 4. Proposed, T_0 = 2\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed_T2 * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed_T2[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed_T2)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[3,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[3,trial_idx,j] = np.min([partial_sum, Privacy[3,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed_T2),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[3,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print()\n",
    "\n",
    "\n",
    "        # random selection\n",
    "\n",
    "#     print(Privacy)\n",
    "#     print()\n",
    "#     print(Agg_Card)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# matplotlib.use('Agg')\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "mean_priavcy_p02 = np.sum(Privacy, axis=1)/N_trial\n",
    "print(np.shape(mean_priavcy_p02))\n",
    "\n",
    "plt.plot(mean_priavcy_p02[0,:], label='random')\n",
    "plt.plot(mean_priavcy_p02[1,:], label='partition')\n",
    "plt.plot(mean_priavcy_p02[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_priavcy_p02[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Privacy')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "mean_Agg_Card_p02 = np.sum(Agg_Card, axis=1)/N_trial\n",
    "print(np.shape(mean_Agg_Card_p02))\n",
    "\n",
    "plt.plot(mean_Agg_Card_p02[0,:], label='random')\n",
    "plt.plot(mean_Agg_Card_p02[1,:], label='partition')\n",
    "plt.plot(mean_Agg_Card_p02[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_Agg_Card_p02[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Aggregation Cardinality')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 0\n",
      "trial_idx= 1\n",
      "trial_idx= 2\n",
      "trial_idx= 3\n",
      "trial_idx= 4\n",
      "trial_idx= 5\n",
      "trial_idx= 6\n",
      "trial_idx= 7\n",
      "trial_idx= 8\n",
      "trial_idx= 9\n",
      "trial_idx= 10\n",
      "trial_idx= 11\n",
      "trial_idx= 12\n",
      "trial_idx= 13\n",
      "trial_idx= 14\n",
      "trial_idx= 15\n",
      "trial_idx= 16\n",
      "trial_idx= 17\n",
      "trial_idx= 18\n",
      "trial_idx= 19\n",
      "trial_idx= 20\n",
      "trial_idx= 21\n",
      "trial_idx= 22\n",
      "trial_idx= 23\n",
      "trial_idx= 24\n",
      "trial_idx= 25\n",
      "trial_idx= 26\n",
      "trial_idx= 27\n",
      "trial_idx= 28\n",
      "trial_idx= 29\n",
      "trial_idx= 30\n",
      "trial_idx= 31\n",
      "trial_idx= 32\n",
      "trial_idx= 33\n",
      "trial_idx= 34\n",
      "trial_idx= 35\n",
      "trial_idx= 36\n",
      "trial_idx= 37\n",
      "trial_idx= 38\n",
      "trial_idx= 39\n",
      "trial_idx= 40\n",
      "trial_idx= 41\n",
      "trial_idx= 42\n",
      "trial_idx= 43\n",
      "trial_idx= 44\n",
      "trial_idx= 45\n",
      "trial_idx= 46\n",
      "trial_idx= 47\n",
      "trial_idx= 48\n",
      "trial_idx= 49\n",
      "trial_idx= 50\n",
      "trial_idx= 51\n",
      "trial_idx= 52\n",
      "trial_idx= 53\n",
      "trial_idx= 54\n",
      "trial_idx= 55\n",
      "trial_idx= 56\n",
      "trial_idx= 57\n",
      "trial_idx= 58\n",
      "trial_idx= 59\n",
      "trial_idx= 60\n",
      "trial_idx= 61\n",
      "trial_idx= 62\n",
      "trial_idx= 63\n",
      "trial_idx= 64\n",
      "trial_idx= 65\n",
      "trial_idx= 66\n",
      "trial_idx= 67\n",
      "trial_idx= 68\n",
      "trial_idx= 69\n",
      "trial_idx= 70\n",
      "trial_idx= 71\n",
      "trial_idx= 72\n",
      "trial_idx= 73\n",
      "trial_idx= 74\n",
      "trial_idx= 75\n",
      "trial_idx= 76\n",
      "trial_idx= 77\n",
      "trial_idx= 78\n",
      "trial_idx= 79\n",
      "trial_idx= 80\n",
      "trial_idx= 81\n",
      "trial_idx= 82\n",
      "trial_idx= 83\n",
      "trial_idx= 84\n",
      "trial_idx= 85\n",
      "trial_idx= 86\n",
      "trial_idx= 87\n",
      "trial_idx= 88\n",
      "trial_idx= 89\n",
      "trial_idx= 90\n",
      "trial_idx= 91\n",
      "trial_idx= 92\n",
      "trial_idx= 93\n",
      "trial_idx= 94\n",
      "trial_idx= 95\n",
      "trial_idx= 96\n",
      "trial_idx= 97\n",
      "trial_idx= 98\n",
      "trial_idx= 99\n",
      "trial_idx= 100\n",
      "trial_idx= 101\n",
      "trial_idx= 102\n",
      "trial_idx= 103\n",
      "trial_idx= 104\n",
      "trial_idx= 105\n",
      "trial_idx= 106\n",
      "trial_idx= 107\n",
      "trial_idx= 108\n",
      "trial_idx= 109\n",
      "trial_idx= 110\n",
      "trial_idx= 111\n",
      "trial_idx= 112\n",
      "trial_idx= 113\n",
      "trial_idx= 114\n",
      "trial_idx= 115\n",
      "trial_idx= 116\n",
      "trial_idx= 117\n",
      "trial_idx= 118\n",
      "trial_idx= 119\n",
      "trial_idx= 120\n",
      "trial_idx= 121\n",
      "trial_idx= 122\n",
      "trial_idx= 123\n",
      "trial_idx= 124\n",
      "trial_idx= 125\n",
      "trial_idx= 126\n",
      "trial_idx= 127\n",
      "trial_idx= 128\n",
      "trial_idx= 129\n",
      "trial_idx= 130\n",
      "trial_idx= 131\n",
      "trial_idx= 132\n",
      "trial_idx= 133\n",
      "trial_idx= 134\n",
      "trial_idx= 135\n",
      "trial_idx= 136\n",
      "trial_idx= 137\n",
      "trial_idx= 138\n",
      "trial_idx= 139\n",
      "trial_idx= 140\n",
      "trial_idx= 141\n",
      "trial_idx= 142\n",
      "trial_idx= 143\n",
      "trial_idx= 144\n",
      "trial_idx= 145\n",
      "trial_idx= 146\n",
      "trial_idx= 147\n",
      "trial_idx= 148\n",
      "trial_idx= 149\n",
      "trial_idx= 150\n",
      "trial_idx= 151\n",
      "trial_idx= 152\n",
      "trial_idx= 153\n",
      "trial_idx= 154\n",
      "trial_idx= 155\n",
      "trial_idx= 156\n",
      "trial_idx= 157\n",
      "trial_idx= 158\n",
      "trial_idx= 159\n",
      "trial_idx= 160\n",
      "trial_idx= 161\n",
      "trial_idx= 162\n",
      "trial_idx= 163\n",
      "trial_idx= 164\n",
      "trial_idx= 165\n",
      "trial_idx= 166\n",
      "trial_idx= 167\n",
      "trial_idx= 168\n",
      "trial_idx= 169\n",
      "trial_idx= 170\n",
      "trial_idx= 171\n",
      "trial_idx= 172\n",
      "trial_idx= 173\n",
      "trial_idx= 174\n",
      "trial_idx= 175\n",
      "trial_idx= 176\n",
      "trial_idx= 177\n",
      "trial_idx= 178\n",
      "trial_idx= 179\n",
      "trial_idx= 180\n",
      "trial_idx= 181\n",
      "trial_idx= 182\n",
      "trial_idx= 183\n",
      "trial_idx= 184\n",
      "trial_idx= 185\n",
      "trial_idx= 186\n",
      "trial_idx= 187\n",
      "trial_idx= 188\n",
      "trial_idx= 189\n",
      "trial_idx= 190\n",
      "trial_idx= 191\n",
      "trial_idx= 192\n",
      "trial_idx= 193\n",
      "trial_idx= 194\n",
      "trial_idx= 195\n",
      "trial_idx= 196\n",
      "trial_idx= 197\n",
      "trial_idx= 198\n",
      "trial_idx= 199\n",
      "trial_idx= 200\n",
      "trial_idx= 201\n",
      "trial_idx= 202\n",
      "trial_idx= 203\n",
      "trial_idx= 204\n",
      "trial_idx= 205\n",
      "trial_idx= 206\n",
      "trial_idx= 207\n",
      "trial_idx= 208\n",
      "trial_idx= 209\n",
      "trial_idx= 210\n",
      "trial_idx= 211\n",
      "trial_idx= 212\n",
      "trial_idx= 213\n",
      "trial_idx= 214\n",
      "trial_idx= 215\n",
      "trial_idx= 216\n",
      "trial_idx= 217\n",
      "trial_idx= 218\n",
      "trial_idx= 219\n",
      "trial_idx= 220\n",
      "trial_idx= 221\n",
      "trial_idx= 222\n",
      "trial_idx= 223\n",
      "trial_idx= 224\n",
      "trial_idx= 225\n",
      "trial_idx= 226\n",
      "trial_idx= 227\n",
      "trial_idx= 228\n",
      "trial_idx= 229\n",
      "trial_idx= 230\n",
      "trial_idx= 231\n",
      "trial_idx= 232\n",
      "trial_idx= 233\n",
      "trial_idx= 234\n",
      "trial_idx= 235\n",
      "trial_idx= 236\n",
      "trial_idx= 237\n",
      "trial_idx= 238\n",
      "trial_idx= 239\n",
      "trial_idx= 240\n",
      "trial_idx= 241\n",
      "trial_idx= 242\n",
      "trial_idx= 243\n",
      "trial_idx= 244\n",
      "trial_idx= 245\n",
      "trial_idx= 246\n",
      "trial_idx= 247\n",
      "trial_idx= 248\n",
      "trial_idx= 249\n",
      "trial_idx= 250\n",
      "trial_idx= 251\n",
      "trial_idx= 252\n",
      "trial_idx= 253\n",
      "trial_idx= 254\n",
      "trial_idx= 255\n",
      "trial_idx= 256\n",
      "trial_idx= 257\n",
      "trial_idx= 258\n",
      "trial_idx= 259\n",
      "trial_idx= 260\n",
      "trial_idx= 261\n",
      "trial_idx= 262\n",
      "trial_idx= 263\n",
      "trial_idx= 264\n",
      "trial_idx= 265\n",
      "trial_idx= 266\n",
      "trial_idx= 267\n",
      "trial_idx= 268\n",
      "trial_idx= 269\n",
      "trial_idx= 270\n",
      "trial_idx= 271\n",
      "trial_idx= 272\n",
      "trial_idx= 273\n",
      "trial_idx= 274\n",
      "trial_idx= 275\n",
      "trial_idx= 276\n",
      "trial_idx= 277\n",
      "trial_idx= 278\n",
      "trial_idx= 279\n",
      "trial_idx= 280\n",
      "trial_idx= 281\n",
      "trial_idx= 282\n",
      "trial_idx= 283\n",
      "trial_idx= 284\n",
      "trial_idx= 285\n",
      "trial_idx= 286\n",
      "trial_idx= 287\n",
      "trial_idx= 288\n",
      "trial_idx= 289\n",
      "trial_idx= 290\n",
      "trial_idx= 291\n",
      "trial_idx= 292\n",
      "trial_idx= 293\n",
      "trial_idx= 294\n",
      "trial_idx= 295\n",
      "trial_idx= 296\n",
      "trial_idx= 297\n",
      "trial_idx= 298\n",
      "trial_idx= 299\n",
      "trial_idx= 300\n",
      "trial_idx= 301\n",
      "trial_idx= 302\n",
      "trial_idx= 303\n",
      "trial_idx= 304\n",
      "trial_idx= 305\n",
      "trial_idx= 306\n",
      "trial_idx= 307\n",
      "trial_idx= 308\n",
      "trial_idx= 309\n",
      "trial_idx= 310\n",
      "trial_idx= 311\n",
      "trial_idx= 312\n",
      "trial_idx= 313\n",
      "trial_idx= 314\n",
      "trial_idx= 315\n",
      "trial_idx= 316\n",
      "trial_idx= 317\n",
      "trial_idx= 318\n",
      "trial_idx= 319\n",
      "trial_idx= 320\n",
      "trial_idx= 321\n",
      "trial_idx= 322\n",
      "trial_idx= 323\n",
      "trial_idx= 324\n",
      "trial_idx= 325\n",
      "trial_idx= 326\n",
      "trial_idx= 327\n",
      "trial_idx= 328\n",
      "trial_idx= 329\n",
      "trial_idx= 330\n",
      "trial_idx= 331\n",
      "trial_idx= 332\n",
      "trial_idx= 333\n",
      "trial_idx= 334\n",
      "trial_idx= 335\n",
      "trial_idx= 336\n",
      "trial_idx= 337\n",
      "trial_idx= 338\n",
      "trial_idx= 339\n",
      "trial_idx= 340\n",
      "trial_idx= 341\n",
      "trial_idx= 342\n",
      "trial_idx= 343\n",
      "trial_idx= 344\n",
      "trial_idx= 345\n",
      "trial_idx= 346\n",
      "trial_idx= 347\n",
      "trial_idx= 348\n",
      "trial_idx= 349\n",
      "trial_idx= 350\n",
      "trial_idx= 351\n",
      "trial_idx= 352\n",
      "trial_idx= 353\n",
      "trial_idx= 354\n",
      "trial_idx= 355\n",
      "trial_idx= 356\n",
      "trial_idx= 357\n",
      "trial_idx= 358\n",
      "trial_idx= 359\n",
      "trial_idx= 360\n",
      "trial_idx= 361\n",
      "trial_idx= 362\n",
      "trial_idx= 363\n",
      "trial_idx= 364\n",
      "trial_idx= 365\n",
      "trial_idx= 366\n",
      "trial_idx= 367\n",
      "trial_idx= 368\n",
      "trial_idx= 369\n",
      "trial_idx= 370\n",
      "trial_idx= 371\n",
      "trial_idx= 372\n",
      "trial_idx= 373\n",
      "trial_idx= 374\n",
      "trial_idx= 375\n",
      "trial_idx= 376\n",
      "trial_idx= 377\n",
      "trial_idx= 378\n",
      "trial_idx= 379\n",
      "trial_idx= 380\n",
      "trial_idx= 381\n",
      "trial_idx= 382\n",
      "trial_idx= 383\n",
      "trial_idx= 384\n",
      "trial_idx= 385\n",
      "trial_idx= 386\n",
      "trial_idx= 387\n",
      "trial_idx= 388\n",
      "trial_idx= 389\n",
      "trial_idx= 390\n",
      "trial_idx= 391\n",
      "trial_idx= 392\n",
      "trial_idx= 393\n",
      "trial_idx= 394\n",
      "trial_idx= 395\n",
      "trial_idx= 396\n",
      "trial_idx= 397\n",
      "trial_idx= 398\n",
      "trial_idx= 399\n",
      "trial_idx= 400\n",
      "trial_idx= 401\n",
      "trial_idx= 402\n",
      "trial_idx= 403\n",
      "trial_idx= 404\n",
      "trial_idx= 405\n",
      "trial_idx= 406\n",
      "trial_idx= 407\n",
      "trial_idx= 408\n",
      "trial_idx= 409\n",
      "trial_idx= 410\n",
      "trial_idx= 411\n",
      "trial_idx= 412\n",
      "trial_idx= 413\n",
      "trial_idx= 414\n",
      "trial_idx= 415\n",
      "trial_idx= 416\n",
      "trial_idx= 417\n",
      "trial_idx= 418\n",
      "trial_idx= 419\n",
      "trial_idx= 420\n",
      "trial_idx= 421\n",
      "trial_idx= 422\n",
      "trial_idx= 423\n",
      "trial_idx= 424\n",
      "trial_idx= 425\n",
      "trial_idx= 426\n",
      "trial_idx= 427\n",
      "trial_idx= 428\n",
      "trial_idx= 429\n",
      "trial_idx= 430\n",
      "trial_idx= 431\n",
      "trial_idx= 432\n",
      "trial_idx= 433\n",
      "trial_idx= 434\n",
      "trial_idx= 435\n",
      "trial_idx= 436\n",
      "trial_idx= 437\n",
      "trial_idx= 438\n",
      "trial_idx= 439\n",
      "trial_idx= 440\n",
      "trial_idx= 441\n",
      "trial_idx= 442\n",
      "trial_idx= 443\n",
      "trial_idx= 444\n",
      "trial_idx= 445\n",
      "trial_idx= 446\n",
      "trial_idx= 447\n",
      "trial_idx= 448\n",
      "trial_idx= 449\n",
      "trial_idx= 450\n",
      "trial_idx= 451\n",
      "trial_idx= 452\n",
      "trial_idx= 453\n",
      "trial_idx= 454\n",
      "trial_idx= 455\n",
      "trial_idx= 456\n",
      "trial_idx= 457\n",
      "trial_idx= 458\n",
      "trial_idx= 459\n",
      "trial_idx= 460\n",
      "trial_idx= 461\n",
      "trial_idx= 462\n",
      "trial_idx= 463\n",
      "trial_idx= 464\n",
      "trial_idx= 465\n",
      "trial_idx= 466\n",
      "trial_idx= 467\n",
      "trial_idx= 468\n",
      "trial_idx= 469\n",
      "trial_idx= 470\n",
      "trial_idx= 471\n",
      "trial_idx= 472\n",
      "trial_idx= 473\n",
      "trial_idx= 474\n",
      "trial_idx= 475\n",
      "trial_idx= 476\n",
      "trial_idx= 477\n",
      "trial_idx= 478\n",
      "trial_idx= 479\n",
      "trial_idx= 480\n",
      "trial_idx= 481\n",
      "trial_idx= 482\n",
      "trial_idx= 483\n",
      "trial_idx= 484\n",
      "trial_idx= 485\n",
      "trial_idx= 486\n",
      "trial_idx= 487\n",
      "trial_idx= 488\n",
      "trial_idx= 489\n",
      "trial_idx= 490\n",
      "trial_idx= 491\n",
      "trial_idx= 492\n",
      "trial_idx= 493\n",
      "trial_idx= 494\n",
      "trial_idx= 495\n",
      "trial_idx= 496\n",
      "trial_idx= 497\n",
      "trial_idx= 498\n",
      "trial_idx= 499\n",
      "trial_idx= 500\n",
      "trial_idx= 501\n",
      "trial_idx= 502\n",
      "trial_idx= 503\n",
      "trial_idx= 504\n",
      "trial_idx= 505\n",
      "trial_idx= 506\n",
      "trial_idx= 507\n",
      "trial_idx= 508\n",
      "trial_idx= 509\n",
      "trial_idx= 510\n",
      "trial_idx= 511\n",
      "trial_idx= 512\n",
      "trial_idx= 513\n",
      "trial_idx= 514\n",
      "trial_idx= 515\n",
      "trial_idx= 516\n",
      "trial_idx= 517\n",
      "trial_idx= 518\n",
      "trial_idx= 519\n",
      "trial_idx= 520\n",
      "trial_idx= 521\n",
      "trial_idx= 522\n",
      "trial_idx= 523\n",
      "trial_idx= 524\n",
      "trial_idx= 525\n",
      "trial_idx= 526\n",
      "trial_idx= 527\n",
      "trial_idx= 528\n",
      "trial_idx= 529\n",
      "trial_idx= 530\n",
      "trial_idx= 531\n",
      "trial_idx= 532\n",
      "trial_idx= 533\n",
      "trial_idx= 534\n",
      "trial_idx= 535\n",
      "trial_idx= 536\n",
      "trial_idx= 537\n",
      "trial_idx= 538\n",
      "trial_idx= 539\n",
      "trial_idx= 540\n",
      "trial_idx= 541\n",
      "trial_idx= 542\n",
      "trial_idx= 543\n",
      "trial_idx= 544\n",
      "trial_idx= 545\n",
      "trial_idx= 546\n",
      "trial_idx= 547\n",
      "trial_idx= 548\n",
      "trial_idx= 549\n",
      "trial_idx= 550\n",
      "trial_idx= 551\n",
      "trial_idx= 552\n",
      "trial_idx= 553\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 554\n",
      "trial_idx= 555\n",
      "trial_idx= 556\n",
      "trial_idx= 557\n",
      "trial_idx= 558\n",
      "trial_idx= 559\n",
      "trial_idx= 560\n",
      "trial_idx= 561\n",
      "trial_idx= 562\n",
      "trial_idx= 563\n",
      "trial_idx= 564\n",
      "trial_idx= 565\n",
      "trial_idx= 566\n",
      "trial_idx= 567\n",
      "trial_idx= 568\n",
      "trial_idx= 569\n",
      "trial_idx= 570\n",
      "trial_idx= 571\n",
      "trial_idx= 572\n",
      "trial_idx= 573\n",
      "trial_idx= 574\n",
      "trial_idx= 575\n",
      "trial_idx= 576\n",
      "trial_idx= 577\n",
      "trial_idx= 578\n",
      "trial_idx= 579\n",
      "trial_idx= 580\n",
      "trial_idx= 581\n",
      "trial_idx= 582\n",
      "trial_idx= 583\n",
      "trial_idx= 584\n",
      "trial_idx= 585\n",
      "trial_idx= 586\n",
      "trial_idx= 587\n",
      "trial_idx= 588\n",
      "trial_idx= 589\n",
      "trial_idx= 590\n",
      "trial_idx= 591\n",
      "trial_idx= 592\n",
      "trial_idx= 593\n",
      "trial_idx= 594\n",
      "trial_idx= 595\n",
      "trial_idx= 596\n",
      "trial_idx= 597\n",
      "trial_idx= 598\n",
      "trial_idx= 599\n",
      "trial_idx= 600\n",
      "trial_idx= 601\n",
      "trial_idx= 602\n",
      "trial_idx= 603\n",
      "trial_idx= 604\n",
      "trial_idx= 605\n",
      "trial_idx= 606\n",
      "trial_idx= 607\n",
      "trial_idx= 608\n",
      "trial_idx= 609\n",
      "trial_idx= 610\n",
      "trial_idx= 611\n",
      "trial_idx= 612\n",
      "trial_idx= 613\n",
      "trial_idx= 614\n",
      "trial_idx= 615\n",
      "trial_idx= 616\n",
      "trial_idx= 617\n",
      "trial_idx= 618\n",
      "trial_idx= 619\n",
      "trial_idx= 620\n",
      "trial_idx= 621\n",
      "trial_idx= 622\n",
      "trial_idx= 623\n",
      "trial_idx= 624\n",
      "trial_idx= 625\n",
      "trial_idx= 626\n",
      "trial_idx= 627\n",
      "trial_idx= 628\n",
      "trial_idx= 629\n",
      "trial_idx= 630\n",
      "trial_idx= 631\n",
      "trial_idx= 632\n",
      "trial_idx= 633\n",
      "trial_idx= 634\n",
      "trial_idx= 635\n",
      "trial_idx= 636\n",
      "trial_idx= 637\n",
      "trial_idx= 638\n",
      "trial_idx= 639\n",
      "trial_idx= 640\n",
      "trial_idx= 641\n",
      "trial_idx= 642\n",
      "trial_idx= 643\n",
      "trial_idx= 644\n",
      "trial_idx= 645\n",
      "trial_idx= 646\n",
      "trial_idx= 647\n",
      "trial_idx= 648\n",
      "trial_idx= 649\n",
      "trial_idx= 650\n",
      "trial_idx= 651\n",
      "trial_idx= 652\n",
      "trial_idx= 653\n",
      "trial_idx= 654\n",
      "trial_idx= 655\n",
      "trial_idx= 656\n",
      "trial_idx= 657\n",
      "trial_idx= 658\n",
      "trial_idx= 659\n",
      "trial_idx= 660\n",
      "trial_idx= 661\n",
      "trial_idx= 662\n",
      "trial_idx= 663\n",
      "trial_idx= 664\n",
      "trial_idx= 665\n",
      "trial_idx= 666\n",
      "trial_idx= 667\n",
      "trial_idx= 668\n",
      "trial_idx= 669\n",
      "trial_idx= 670\n",
      "trial_idx= 671\n",
      "trial_idx= 672\n",
      "trial_idx= 673\n",
      "trial_idx= 674\n",
      "trial_idx= 675\n",
      "trial_idx= 676\n",
      "trial_idx= 677\n",
      "trial_idx= 678\n",
      "trial_idx= 679\n",
      "trial_idx= 680\n",
      "trial_idx= 681\n",
      "trial_idx= 682\n",
      "trial_idx= 683\n",
      "trial_idx= 684\n",
      "trial_idx= 685\n",
      "trial_idx= 686\n",
      "trial_idx= 687\n",
      "trial_idx= 688\n",
      "trial_idx= 689\n",
      "trial_idx= 690\n",
      "trial_idx= 691\n",
      "trial_idx= 692\n",
      "trial_idx= 693\n",
      "trial_idx= 694\n",
      "trial_idx= 695\n",
      "trial_idx= 696\n",
      "trial_idx= 697\n",
      "trial_idx= 698\n",
      "trial_idx= 699\n",
      "trial_idx= 700\n",
      "trial_idx= 701\n",
      "trial_idx= 702\n",
      "trial_idx= 703\n",
      "trial_idx= 704\n",
      "trial_idx= 705\n",
      "trial_idx= 706\n",
      "trial_idx= 707\n",
      "trial_idx= 708\n",
      "trial_idx= 709\n",
      "trial_idx= 710\n",
      "trial_idx= 711\n",
      "trial_idx= 712\n",
      "trial_idx= 713\n",
      "trial_idx= 714\n",
      "trial_idx= 715\n",
      "trial_idx= 716\n",
      "trial_idx= 717\n",
      "trial_idx= 718\n",
      "trial_idx= 719\n",
      "trial_idx= 720\n",
      "trial_idx= 721\n",
      "trial_idx= 722\n",
      "trial_idx= 723\n",
      "trial_idx= 724\n",
      "trial_idx= 725\n",
      "trial_idx= 726\n",
      "trial_idx= 727\n",
      "trial_idx= 728\n",
      "trial_idx= 729\n",
      "trial_idx= 730\n",
      "trial_idx= 731\n",
      "trial_idx= 732\n",
      "trial_idx= 733\n",
      "trial_idx= 734\n",
      "trial_idx= 735\n",
      "trial_idx= 736\n",
      "trial_idx= 737\n",
      "trial_idx= 738\n",
      "trial_idx= 739\n",
      "trial_idx= 740\n",
      "trial_idx= 741\n",
      "trial_idx= 742\n",
      "trial_idx= 743\n",
      "trial_idx= 744\n",
      "trial_idx= 745\n",
      "trial_idx= 746\n",
      "trial_idx= 747\n",
      "trial_idx= 748\n",
      "trial_idx= 749\n",
      "trial_idx= 750\n",
      "trial_idx= 751\n",
      "trial_idx= 752\n",
      "trial_idx= 753\n",
      "trial_idx= 754\n",
      "trial_idx= 755\n",
      "trial_idx= 756\n",
      "trial_idx= 757\n",
      "trial_idx= 758\n",
      "trial_idx= 759\n",
      "trial_idx= 760\n",
      "trial_idx= 761\n",
      "trial_idx= 762\n",
      "trial_idx= 763\n",
      "trial_idx= 764\n",
      "trial_idx= 765\n",
      "trial_idx= 766\n",
      "trial_idx= 767\n",
      "trial_idx= 768\n",
      "trial_idx= 769\n",
      "trial_idx= 770\n",
      "trial_idx= 771\n",
      "trial_idx= 772\n",
      "trial_idx= 773\n",
      "trial_idx= 774\n",
      "trial_idx= 775\n",
      "trial_idx= 776\n",
      "trial_idx= 777\n",
      "trial_idx= 778\n",
      "trial_idx= 779\n",
      "trial_idx= 780\n",
      "trial_idx= 781\n",
      "trial_idx= 782\n",
      "trial_idx= 783\n",
      "trial_idx= 784\n",
      "trial_idx= 785\n",
      "trial_idx= 786\n",
      "trial_idx= 787\n",
      "trial_idx= 788\n",
      "trial_idx= 789\n",
      "trial_idx= 790\n",
      "trial_idx= 791\n",
      "trial_idx= 792\n",
      "trial_idx= 793\n",
      "trial_idx= 794\n",
      "trial_idx= 795\n",
      "trial_idx= 796\n",
      "trial_idx= 797\n",
      "trial_idx= 798\n",
      "trial_idx= 799\n",
      "trial_idx= 800\n",
      "trial_idx= 801\n",
      "trial_idx= 802\n",
      "trial_idx= 803\n",
      "trial_idx= 804\n",
      "trial_idx= 805\n",
      "trial_idx= 806\n",
      "trial_idx= 807\n",
      "trial_idx= 808\n",
      "trial_idx= 809\n",
      "trial_idx= 810\n",
      "trial_idx= 811\n",
      "trial_idx= 812\n",
      "trial_idx= 813\n",
      "trial_idx= 814\n",
      "trial_idx= 815\n",
      "trial_idx= 816\n",
      "trial_idx= 817\n",
      "trial_idx= 818\n",
      "trial_idx= 819\n",
      "trial_idx= 820\n",
      "trial_idx= 821\n",
      "trial_idx= 822\n",
      "trial_idx= 823\n",
      "trial_idx= 824\n",
      "trial_idx= 825\n",
      "trial_idx= 826\n",
      "trial_idx= 827\n",
      "trial_idx= 828\n",
      "trial_idx= 829\n",
      "trial_idx= 830\n",
      "trial_idx= 831\n",
      "trial_idx= 832\n",
      "trial_idx= 833\n",
      "trial_idx= 834\n",
      "trial_idx= 835\n",
      "trial_idx= 836\n",
      "trial_idx= 837\n",
      "trial_idx= 838\n",
      "trial_idx= 839\n",
      "trial_idx= 840\n",
      "trial_idx= 841\n",
      "trial_idx= 842\n",
      "trial_idx= 843\n",
      "trial_idx= 844\n",
      "trial_idx= 845\n",
      "trial_idx= 846\n",
      "trial_idx= 847\n",
      "trial_idx= 848\n",
      "trial_idx= 849\n",
      "trial_idx= 850\n",
      "trial_idx= 851\n",
      "trial_idx= 852\n",
      "trial_idx= 853\n",
      "trial_idx= 854\n",
      "trial_idx= 855\n",
      "trial_idx= 856\n",
      "trial_idx= 857\n",
      "trial_idx= 858\n",
      "trial_idx= 859\n",
      "trial_idx= 860\n",
      "trial_idx= 861\n",
      "trial_idx= 862\n",
      "trial_idx= 863\n",
      "trial_idx= 864\n",
      "trial_idx= 865\n",
      "trial_idx= 866\n",
      "trial_idx= 867\n",
      "trial_idx= 868\n",
      "trial_idx= 869\n",
      "trial_idx= 870\n",
      "trial_idx= 871\n",
      "trial_idx= 872\n",
      "trial_idx= 873\n",
      "trial_idx= 874\n",
      "trial_idx= 875\n",
      "trial_idx= 876\n",
      "trial_idx= 877\n",
      "trial_idx= 878\n",
      "trial_idx= 879\n",
      "trial_idx= 880\n",
      "trial_idx= 881\n",
      "trial_idx= 882\n",
      "trial_idx= 883\n",
      "trial_idx= 884\n",
      "trial_idx= 885\n",
      "trial_idx= 886\n",
      "trial_idx= 887\n",
      "trial_idx= 888\n",
      "trial_idx= 889\n",
      "trial_idx= 890\n",
      "trial_idx= 891\n",
      "trial_idx= 892\n",
      "trial_idx= 893\n",
      "trial_idx= 894\n",
      "trial_idx= 895\n",
      "trial_idx= 896\n",
      "trial_idx= 897\n",
      "trial_idx= 898\n",
      "trial_idx= 899\n",
      "trial_idx= 900\n",
      "trial_idx= 901\n",
      "trial_idx= 902\n",
      "trial_idx= 903\n",
      "trial_idx= 904\n",
      "trial_idx= 905\n",
      "trial_idx= 906\n",
      "trial_idx= 907\n",
      "trial_idx= 908\n",
      "trial_idx= 909\n",
      "trial_idx= 910\n",
      "trial_idx= 911\n",
      "trial_idx= 912\n",
      "trial_idx= 913\n",
      "trial_idx= 914\n",
      "trial_idx= 915\n",
      "trial_idx= 916\n",
      "trial_idx= 917\n",
      "trial_idx= 918\n",
      "trial_idx= 919\n",
      "trial_idx= 920\n",
      "trial_idx= 921\n",
      "trial_idx= 922\n",
      "trial_idx= 923\n",
      "trial_idx= 924\n",
      "trial_idx= 925\n",
      "trial_idx= 926\n",
      "trial_idx= 927\n",
      "trial_idx= 928\n",
      "trial_idx= 929\n",
      "trial_idx= 930\n",
      "trial_idx= 931\n",
      "trial_idx= 932\n",
      "trial_idx= 933\n",
      "trial_idx= 934\n",
      "trial_idx= 935\n",
      "trial_idx= 936\n",
      "trial_idx= 937\n",
      "trial_idx= 938\n",
      "trial_idx= 939\n",
      "trial_idx= 940\n",
      "trial_idx= 941\n",
      "trial_idx= 942\n",
      "trial_idx= 943\n",
      "trial_idx= 944\n",
      "trial_idx= 945\n",
      "trial_idx= 946\n",
      "trial_idx= 947\n",
      "trial_idx= 948\n",
      "trial_idx= 949\n",
      "trial_idx= 950\n",
      "trial_idx= 951\n",
      "trial_idx= 952\n",
      "trial_idx= 953\n",
      "trial_idx= 954\n",
      "trial_idx= 955\n",
      "trial_idx= 956\n",
      "trial_idx= 957\n",
      "trial_idx= 958\n",
      "trial_idx= 959\n",
      "trial_idx= 960\n",
      "trial_idx= 961\n",
      "trial_idx= 962\n",
      "trial_idx= 963\n",
      "trial_idx= 964\n",
      "trial_idx= 965\n",
      "trial_idx= 966\n",
      "trial_idx= 967\n",
      "trial_idx= 968\n",
      "trial_idx= 969\n",
      "trial_idx= 970\n",
      "trial_idx= 971\n",
      "trial_idx= 972\n",
      "trial_idx= 973\n",
      "trial_idx= 974\n",
      "trial_idx= 975\n",
      "trial_idx= 976\n",
      "trial_idx= 977\n",
      "trial_idx= 978\n",
      "trial_idx= 979\n",
      "trial_idx= 980\n",
      "trial_idx= 981\n",
      "trial_idx= 982\n",
      "trial_idx= 983\n",
      "trial_idx= 984\n",
      "trial_idx= 985\n",
      "trial_idx= 986\n",
      "trial_idx= 987\n",
      "trial_idx= 988\n",
      "trial_idx= 989\n",
      "trial_idx= 990\n",
      "trial_idx= 991\n",
      "trial_idx= 992\n",
      "trial_idx= 993\n",
      "trial_idx= 994\n",
      "trial_idx= 995\n",
      "trial_idx= 996\n",
      "trial_idx= 997\n",
      "trial_idx= 998\n",
      "trial_idx= 999\n"
     ]
    }
   ],
   "source": [
    "J = 50  # Total iterations\n",
    "p = 0.1 # dropout rate\n",
    "\n",
    "\n",
    "\n",
    "is_print = False\n",
    "# is_print = False\n",
    "\n",
    "is_print_tmp = True\n",
    "\n",
    "N_schemes = 4\n",
    "\n",
    "N_trial = 1000\n",
    "\n",
    "Agg_Card = np.zeros((N_schemes, N_trial, J))\n",
    "Privacy  = np.zeros((N_schemes, N_trial, J))\n",
    "\n",
    "\n",
    "for trial_idx in range(N_trial):\n",
    "    \n",
    "    print('trial_idx=',trial_idx)\n",
    "#     print()\n",
    "    \n",
    "    P_random    = []\n",
    "    P_partition = []\n",
    "    P_proposed  = []\n",
    "    P_proposed_T2 = []\n",
    "    \n",
    "    for j in range(J):\n",
    "        u = np.random.binomial(1, 1-p, size=(N))\n",
    "        if is_print:\n",
    "            print('[iter=',j,'] Surviving vector u=',u)\n",
    "\n",
    "        if np.sum(u) < K:\n",
    "            p_tmp = np.zero(N)\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "            P_partition.append(p_tmp)\n",
    "            P_proposed.append(p_tmp)\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "        else:\n",
    "            result = np.where(u == 1)\n",
    "\n",
    "            ###############################\n",
    "            # 1. Random Selection\n",
    "            ###############################\n",
    "            select = np.random.choice(result[0], K, replace=False)\n",
    "\n",
    "            p_tmp = np.zeros(N)\n",
    "            p_tmp[select] = 1\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "\n",
    "            # 1.1 Calculate Privacy\n",
    "            P = np.array(P_random)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[0,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[0,trial_idx,j] = np.min([partial_sum, Privacy[0,trial_idx,j-1]])\n",
    "\n",
    "            # 1.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_random),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[0,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print('[iter=',j,'] @Random Method, Codebook selection')\n",
    "\n",
    "            ###############################\n",
    "            # 2. Partition\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Partition * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "                p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "\n",
    "            P_partition.append(p_tmp)\n",
    "\n",
    "            # 2.1 Calculate Privacy\n",
    "            P = np.array(P_partition)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[1,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[1,trial_idx,j] = np.min([partial_sum, Privacy[1,trial_idx,j-1]])\n",
    "\n",
    "            # 2.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_partition),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[1,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "            ###############################\n",
    "            # 3. Proposed, T_0 = 4\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[2,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[2,trial_idx,j] = np.min([partial_sum, Privacy[2,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[2,trial_idx,j] = acc_card/(j+1)\n",
    "            \n",
    "            \n",
    "            \n",
    "            ###############################\n",
    "            # 4. Proposed, T_0 = 2\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed_T2 * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed_T2[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed_T2)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[3,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[3,trial_idx,j] = np.min([partial_sum, Privacy[3,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed_T2),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[3,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print()\n",
    "\n",
    "\n",
    "        # random selection\n",
    "\n",
    "#     print(Privacy)\n",
    "#     print()\n",
    "#     print(Agg_Card)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# matplotlib.use('Agg')\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "mean_priavcy_p01 = np.sum(Privacy, axis=1)/N_trial\n",
    "print(np.shape(mean_priavcy_p01))\n",
    "\n",
    "plt.plot(mean_priavcy_p01[0,:], label='random')\n",
    "plt.plot(mean_priavcy_p01[1,:], label='partition')\n",
    "plt.plot(mean_priavcy_p01[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_priavcy_p01[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Privacy')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "mean_Agg_Card_p01 = np.sum(Agg_Card, axis=1)/N_trial\n",
    "print(np.shape(mean_Agg_Card_p01))\n",
    "\n",
    "plt.plot(mean_Agg_Card_p01[0,:], label='random')\n",
    "plt.plot(mean_Agg_Card_p01[1,:], label='partition')\n",
    "plt.plot(mean_Agg_Card_p01[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_Agg_Card_p01[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Aggregation Cardinality')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 0\n",
      "trial_idx= 1\n",
      "trial_idx= 2\n",
      "trial_idx= 3\n",
      "trial_idx= 4\n",
      "trial_idx= 5\n",
      "trial_idx= 6\n",
      "trial_idx= 7\n",
      "trial_idx= 8\n",
      "trial_idx= 9\n",
      "trial_idx= 10\n",
      "trial_idx= 11\n",
      "trial_idx= 12\n",
      "trial_idx= 13\n",
      "trial_idx= 14\n",
      "trial_idx= 15\n",
      "trial_idx= 16\n",
      "trial_idx= 17\n",
      "trial_idx= 18\n",
      "trial_idx= 19\n",
      "trial_idx= 20\n",
      "trial_idx= 21\n",
      "trial_idx= 22\n",
      "trial_idx= 23\n",
      "trial_idx= 24\n",
      "trial_idx= 25\n",
      "trial_idx= 26\n",
      "trial_idx= 27\n",
      "trial_idx= 28\n",
      "trial_idx= 29\n",
      "trial_idx= 30\n",
      "trial_idx= 31\n",
      "trial_idx= 32\n",
      "trial_idx= 33\n",
      "trial_idx= 34\n",
      "trial_idx= 35\n",
      "trial_idx= 36\n",
      "trial_idx= 37\n",
      "trial_idx= 38\n",
      "trial_idx= 39\n",
      "trial_idx= 40\n",
      "trial_idx= 41\n",
      "trial_idx= 42\n",
      "trial_idx= 43\n",
      "trial_idx= 44\n",
      "trial_idx= 45\n",
      "trial_idx= 46\n",
      "trial_idx= 47\n",
      "trial_idx= 48\n",
      "trial_idx= 49\n",
      "trial_idx= 50\n",
      "trial_idx= 51\n",
      "trial_idx= 52\n",
      "trial_idx= 53\n",
      "trial_idx= 54\n",
      "trial_idx= 55\n",
      "trial_idx= 56\n",
      "trial_idx= 57\n",
      "trial_idx= 58\n",
      "trial_idx= 59\n",
      "trial_idx= 60\n",
      "trial_idx= 61\n",
      "trial_idx= 62\n",
      "trial_idx= 63\n",
      "trial_idx= 64\n",
      "trial_idx= 65\n",
      "trial_idx= 66\n",
      "trial_idx= 67\n",
      "trial_idx= 68\n",
      "trial_idx= 69\n",
      "trial_idx= 70\n",
      "trial_idx= 71\n",
      "trial_idx= 72\n",
      "trial_idx= 73\n",
      "trial_idx= 74\n",
      "trial_idx= 75\n",
      "trial_idx= 76\n",
      "trial_idx= 77\n",
      "trial_idx= 78\n",
      "trial_idx= 79\n",
      "trial_idx= 80\n",
      "trial_idx= 81\n",
      "trial_idx= 82\n",
      "trial_idx= 83\n",
      "trial_idx= 84\n",
      "trial_idx= 85\n",
      "trial_idx= 86\n",
      "trial_idx= 87\n",
      "trial_idx= 88\n",
      "trial_idx= 89\n",
      "trial_idx= 90\n",
      "trial_idx= 91\n",
      "trial_idx= 92\n",
      "trial_idx= 93\n",
      "trial_idx= 94\n",
      "trial_idx= 95\n",
      "trial_idx= 96\n",
      "trial_idx= 97\n",
      "trial_idx= 98\n",
      "trial_idx= 99\n",
      "trial_idx= 100\n",
      "trial_idx= 101\n",
      "trial_idx= 102\n",
      "trial_idx= 103\n",
      "trial_idx= 104\n",
      "trial_idx= 105\n",
      "trial_idx= 106\n",
      "trial_idx= 107\n",
      "trial_idx= 108\n",
      "trial_idx= 109\n",
      "trial_idx= 110\n",
      "trial_idx= 111\n",
      "trial_idx= 112\n",
      "trial_idx= 113\n",
      "trial_idx= 114\n",
      "trial_idx= 115\n",
      "trial_idx= 116\n",
      "trial_idx= 117\n",
      "trial_idx= 118\n",
      "trial_idx= 119\n",
      "trial_idx= 120\n",
      "trial_idx= 121\n",
      "trial_idx= 122\n",
      "trial_idx= 123\n",
      "trial_idx= 124\n",
      "trial_idx= 125\n",
      "trial_idx= 126\n",
      "trial_idx= 127\n",
      "trial_idx= 128\n",
      "trial_idx= 129\n",
      "trial_idx= 130\n",
      "trial_idx= 131\n",
      "trial_idx= 132\n",
      "trial_idx= 133\n",
      "trial_idx= 134\n",
      "trial_idx= 135\n",
      "trial_idx= 136\n",
      "trial_idx= 137\n",
      "trial_idx= 138\n",
      "trial_idx= 139\n",
      "trial_idx= 140\n",
      "trial_idx= 141\n",
      "trial_idx= 142\n",
      "trial_idx= 143\n",
      "trial_idx= 144\n",
      "trial_idx= 145\n",
      "trial_idx= 146\n",
      "trial_idx= 147\n",
      "trial_idx= 148\n",
      "trial_idx= 149\n",
      "trial_idx= 150\n",
      "trial_idx= 151\n",
      "trial_idx= 152\n",
      "trial_idx= 153\n",
      "trial_idx= 154\n",
      "trial_idx= 155\n",
      "trial_idx= 156\n",
      "trial_idx= 157\n",
      "trial_idx= 158\n",
      "trial_idx= 159\n",
      "trial_idx= 160\n",
      "trial_idx= 161\n",
      "trial_idx= 162\n",
      "trial_idx= 163\n",
      "trial_idx= 164\n",
      "trial_idx= 165\n",
      "trial_idx= 166\n",
      "trial_idx= 167\n",
      "trial_idx= 168\n",
      "trial_idx= 169\n",
      "trial_idx= 170\n",
      "trial_idx= 171\n",
      "trial_idx= 172\n",
      "trial_idx= 173\n",
      "trial_idx= 174\n",
      "trial_idx= 175\n",
      "trial_idx= 176\n",
      "trial_idx= 177\n",
      "trial_idx= 178\n",
      "trial_idx= 179\n",
      "trial_idx= 180\n",
      "trial_idx= 181\n",
      "trial_idx= 182\n",
      "trial_idx= 183\n",
      "trial_idx= 184\n",
      "trial_idx= 185\n",
      "trial_idx= 186\n",
      "trial_idx= 187\n",
      "trial_idx= 188\n",
      "trial_idx= 189\n",
      "trial_idx= 190\n",
      "trial_idx= 191\n",
      "trial_idx= 192\n",
      "trial_idx= 193\n",
      "trial_idx= 194\n",
      "trial_idx= 195\n",
      "trial_idx= 196\n",
      "trial_idx= 197\n",
      "trial_idx= 198\n",
      "trial_idx= 199\n",
      "trial_idx= 200\n",
      "trial_idx= 201\n",
      "trial_idx= 202\n",
      "trial_idx= 203\n",
      "trial_idx= 204\n",
      "trial_idx= 205\n",
      "trial_idx= 206\n",
      "trial_idx= 207\n",
      "trial_idx= 208\n",
      "trial_idx= 209\n",
      "trial_idx= 210\n",
      "trial_idx= 211\n",
      "trial_idx= 212\n",
      "trial_idx= 213\n",
      "trial_idx= 214\n",
      "trial_idx= 215\n",
      "trial_idx= 216\n",
      "trial_idx= 217\n",
      "trial_idx= 218\n",
      "trial_idx= 219\n",
      "trial_idx= 220\n",
      "trial_idx= 221\n",
      "trial_idx= 222\n",
      "trial_idx= 223\n",
      "trial_idx= 224\n",
      "trial_idx= 225\n",
      "trial_idx= 226\n",
      "trial_idx= 227\n",
      "trial_idx= 228\n",
      "trial_idx= 229\n",
      "trial_idx= 230\n",
      "trial_idx= 231\n",
      "trial_idx= 232\n",
      "trial_idx= 233\n",
      "trial_idx= 234\n",
      "trial_idx= 235\n",
      "trial_idx= 236\n",
      "trial_idx= 237\n",
      "trial_idx= 238\n",
      "trial_idx= 239\n",
      "trial_idx= 240\n",
      "trial_idx= 241\n",
      "trial_idx= 242\n",
      "trial_idx= 243\n",
      "trial_idx= 244\n",
      "trial_idx= 245\n",
      "trial_idx= 246\n",
      "trial_idx= 247\n",
      "trial_idx= 248\n",
      "trial_idx= 249\n",
      "trial_idx= 250\n",
      "trial_idx= 251\n",
      "trial_idx= 252\n",
      "trial_idx= 253\n",
      "trial_idx= 254\n",
      "trial_idx= 255\n",
      "trial_idx= 256\n",
      "trial_idx= 257\n",
      "trial_idx= 258\n",
      "trial_idx= 259\n",
      "trial_idx= 260\n",
      "trial_idx= 261\n",
      "trial_idx= 262\n",
      "trial_idx= 263\n",
      "trial_idx= 264\n",
      "trial_idx= 265\n",
      "trial_idx= 266\n",
      "trial_idx= 267\n",
      "trial_idx= 268\n",
      "trial_idx= 269\n",
      "trial_idx= 270\n",
      "trial_idx= 271\n",
      "trial_idx= 272\n",
      "trial_idx= 273\n",
      "trial_idx= 274\n",
      "trial_idx= 275\n",
      "trial_idx= 276\n",
      "trial_idx= 277\n",
      "trial_idx= 278\n",
      "trial_idx= 279\n",
      "trial_idx= 280\n",
      "trial_idx= 281\n",
      "trial_idx= 282\n",
      "trial_idx= 283\n",
      "trial_idx= 284\n",
      "trial_idx= 285\n",
      "trial_idx= 286\n",
      "trial_idx= 287\n",
      "trial_idx= 288\n",
      "trial_idx= 289\n",
      "trial_idx= 290\n",
      "trial_idx= 291\n",
      "trial_idx= 292\n",
      "trial_idx= 293\n",
      "trial_idx= 294\n",
      "trial_idx= 295\n",
      "trial_idx= 296\n",
      "trial_idx= 297\n",
      "trial_idx= 298\n",
      "trial_idx= 299\n",
      "trial_idx= 300\n",
      "trial_idx= 301\n",
      "trial_idx= 302\n",
      "trial_idx= 303\n",
      "trial_idx= 304\n",
      "trial_idx= 305\n",
      "trial_idx= 306\n",
      "trial_idx= 307\n",
      "trial_idx= 308\n",
      "trial_idx= 309\n",
      "trial_idx= 310\n",
      "trial_idx= 311\n",
      "trial_idx= 312\n",
      "trial_idx= 313\n",
      "trial_idx= 314\n",
      "trial_idx= 315\n",
      "trial_idx= 316\n",
      "trial_idx= 317\n",
      "trial_idx= 318\n",
      "trial_idx= 319\n",
      "trial_idx= 320\n",
      "trial_idx= 321\n",
      "trial_idx= 322\n",
      "trial_idx= 323\n",
      "trial_idx= 324\n",
      "trial_idx= 325\n",
      "trial_idx= 326\n",
      "trial_idx= 327\n",
      "trial_idx= 328\n",
      "trial_idx= 329\n",
      "trial_idx= 330\n",
      "trial_idx= 331\n",
      "trial_idx= 332\n",
      "trial_idx= 333\n",
      "trial_idx= 334\n",
      "trial_idx= 335\n",
      "trial_idx= 336\n",
      "trial_idx= 337\n",
      "trial_idx= 338\n",
      "trial_idx= 339\n",
      "trial_idx= 340\n",
      "trial_idx= 341\n",
      "trial_idx= 342\n",
      "trial_idx= 343\n",
      "trial_idx= 344\n",
      "trial_idx= 345\n",
      "trial_idx= 346\n",
      "trial_idx= 347\n",
      "trial_idx= 348\n",
      "trial_idx= 349\n",
      "trial_idx= 350\n",
      "trial_idx= 351\n",
      "trial_idx= 352\n",
      "trial_idx= 353\n",
      "trial_idx= 354\n",
      "trial_idx= 355\n",
      "trial_idx= 356\n",
      "trial_idx= 357\n",
      "trial_idx= 358\n",
      "trial_idx= 359\n",
      "trial_idx= 360\n",
      "trial_idx= 361\n",
      "trial_idx= 362\n",
      "trial_idx= 363\n",
      "trial_idx= 364\n",
      "trial_idx= 365\n",
      "trial_idx= 366\n",
      "trial_idx= 367\n",
      "trial_idx= 368\n",
      "trial_idx= 369\n",
      "trial_idx= 370\n",
      "trial_idx= 371\n",
      "trial_idx= 372\n",
      "trial_idx= 373\n",
      "trial_idx= 374\n",
      "trial_idx= 375\n",
      "trial_idx= 376\n",
      "trial_idx= 377\n",
      "trial_idx= 378\n",
      "trial_idx= 379\n",
      "trial_idx= 380\n",
      "trial_idx= 381\n",
      "trial_idx= 382\n",
      "trial_idx= 383\n",
      "trial_idx= 384\n",
      "trial_idx= 385\n",
      "trial_idx= 386\n",
      "trial_idx= 387\n",
      "trial_idx= 388\n",
      "trial_idx= 389\n",
      "trial_idx= 390\n",
      "trial_idx= 391\n",
      "trial_idx= 392\n",
      "trial_idx= 393\n",
      "trial_idx= 394\n",
      "trial_idx= 395\n",
      "trial_idx= 396\n",
      "trial_idx= 397\n",
      "trial_idx= 398\n",
      "trial_idx= 399\n",
      "trial_idx= 400\n",
      "trial_idx= 401\n",
      "trial_idx= 402\n",
      "trial_idx= 403\n",
      "trial_idx= 404\n",
      "trial_idx= 405\n",
      "trial_idx= 406\n",
      "trial_idx= 407\n",
      "trial_idx= 408\n",
      "trial_idx= 409\n",
      "trial_idx= 410\n",
      "trial_idx= 411\n",
      "trial_idx= 412\n",
      "trial_idx= 413\n",
      "trial_idx= 414\n",
      "trial_idx= 415\n",
      "trial_idx= 416\n",
      "trial_idx= 417\n",
      "trial_idx= 418\n",
      "trial_idx= 419\n",
      "trial_idx= 420\n",
      "trial_idx= 421\n",
      "trial_idx= 422\n",
      "trial_idx= 423\n",
      "trial_idx= 424\n",
      "trial_idx= 425\n",
      "trial_idx= 426\n",
      "trial_idx= 427\n",
      "trial_idx= 428\n",
      "trial_idx= 429\n",
      "trial_idx= 430\n",
      "trial_idx= 431\n",
      "trial_idx= 432\n",
      "trial_idx= 433\n",
      "trial_idx= 434\n",
      "trial_idx= 435\n",
      "trial_idx= 436\n",
      "trial_idx= 437\n",
      "trial_idx= 438\n",
      "trial_idx= 439\n",
      "trial_idx= 440\n",
      "trial_idx= 441\n",
      "trial_idx= 442\n",
      "trial_idx= 443\n",
      "trial_idx= 444\n",
      "trial_idx= 445\n",
      "trial_idx= 446\n",
      "trial_idx= 447\n",
      "trial_idx= 448\n",
      "trial_idx= 449\n",
      "trial_idx= 450\n",
      "trial_idx= 451\n",
      "trial_idx= 452\n",
      "trial_idx= 453\n",
      "trial_idx= 454\n",
      "trial_idx= 455\n",
      "trial_idx= 456\n",
      "trial_idx= 457\n",
      "trial_idx= 458\n",
      "trial_idx= 459\n",
      "trial_idx= 460\n",
      "trial_idx= 461\n",
      "trial_idx= 462\n",
      "trial_idx= 463\n",
      "trial_idx= 464\n",
      "trial_idx= 465\n",
      "trial_idx= 466\n",
      "trial_idx= 467\n",
      "trial_idx= 468\n",
      "trial_idx= 469\n",
      "trial_idx= 470\n",
      "trial_idx= 471\n",
      "trial_idx= 472\n",
      "trial_idx= 473\n",
      "trial_idx= 474\n",
      "trial_idx= 475\n",
      "trial_idx= 476\n",
      "trial_idx= 477\n",
      "trial_idx= 478\n",
      "trial_idx= 479\n",
      "trial_idx= 480\n",
      "trial_idx= 481\n",
      "trial_idx= 482\n",
      "trial_idx= 483\n",
      "trial_idx= 484\n",
      "trial_idx= 485\n",
      "trial_idx= 486\n",
      "trial_idx= 487\n",
      "trial_idx= 488\n",
      "trial_idx= 489\n",
      "trial_idx= 490\n",
      "trial_idx= 491\n",
      "trial_idx= 492\n",
      "trial_idx= 493\n",
      "trial_idx= 494\n",
      "trial_idx= 495\n",
      "trial_idx= 496\n",
      "trial_idx= 497\n",
      "trial_idx= 498\n",
      "trial_idx= 499\n",
      "trial_idx= 500\n",
      "trial_idx= 501\n",
      "trial_idx= 502\n",
      "trial_idx= 503\n",
      "trial_idx= 504\n",
      "trial_idx= 505\n",
      "trial_idx= 506\n",
      "trial_idx= 507\n",
      "trial_idx= 508\n",
      "trial_idx= 509\n",
      "trial_idx= 510\n",
      "trial_idx= 511\n",
      "trial_idx= 512\n",
      "trial_idx= 513\n",
      "trial_idx= 514\n",
      "trial_idx= 515\n",
      "trial_idx= 516\n",
      "trial_idx= 517\n",
      "trial_idx= 518\n",
      "trial_idx= 519\n",
      "trial_idx= 520\n",
      "trial_idx= 521\n",
      "trial_idx= 522\n",
      "trial_idx= 523\n",
      "trial_idx= 524\n",
      "trial_idx= 525\n",
      "trial_idx= 526\n",
      "trial_idx= 527\n",
      "trial_idx= 528\n",
      "trial_idx= 529\n",
      "trial_idx= 530\n",
      "trial_idx= 531\n",
      "trial_idx= 532\n",
      "trial_idx= 533\n",
      "trial_idx= 534\n",
      "trial_idx= 535\n",
      "trial_idx= 536\n",
      "trial_idx= 537\n",
      "trial_idx= 538\n",
      "trial_idx= 539\n",
      "trial_idx= 540\n",
      "trial_idx= 541\n",
      "trial_idx= 542\n",
      "trial_idx= 543\n",
      "trial_idx= 544\n",
      "trial_idx= 545\n",
      "trial_idx= 546\n",
      "trial_idx= 547\n",
      "trial_idx= 548\n",
      "trial_idx= 549\n",
      "trial_idx= 550\n",
      "trial_idx= 551\n",
      "trial_idx= 552\n",
      "trial_idx= 553\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trial_idx= 554\n",
      "trial_idx= 555\n",
      "trial_idx= 556\n",
      "trial_idx= 557\n",
      "trial_idx= 558\n",
      "trial_idx= 559\n",
      "trial_idx= 560\n",
      "trial_idx= 561\n",
      "trial_idx= 562\n",
      "trial_idx= 563\n",
      "trial_idx= 564\n",
      "trial_idx= 565\n",
      "trial_idx= 566\n",
      "trial_idx= 567\n",
      "trial_idx= 568\n",
      "trial_idx= 569\n",
      "trial_idx= 570\n",
      "trial_idx= 571\n",
      "trial_idx= 572\n",
      "trial_idx= 573\n",
      "trial_idx= 574\n",
      "trial_idx= 575\n",
      "trial_idx= 576\n",
      "trial_idx= 577\n",
      "trial_idx= 578\n",
      "trial_idx= 579\n",
      "trial_idx= 580\n",
      "trial_idx= 581\n",
      "trial_idx= 582\n",
      "trial_idx= 583\n",
      "trial_idx= 584\n",
      "trial_idx= 585\n",
      "trial_idx= 586\n",
      "trial_idx= 587\n",
      "trial_idx= 588\n",
      "trial_idx= 589\n",
      "trial_idx= 590\n",
      "trial_idx= 591\n",
      "trial_idx= 592\n",
      "trial_idx= 593\n",
      "trial_idx= 594\n",
      "trial_idx= 595\n",
      "trial_idx= 596\n",
      "trial_idx= 597\n",
      "trial_idx= 598\n",
      "trial_idx= 599\n",
      "trial_idx= 600\n",
      "trial_idx= 601\n",
      "trial_idx= 602\n",
      "trial_idx= 603\n",
      "trial_idx= 604\n",
      "trial_idx= 605\n",
      "trial_idx= 606\n",
      "trial_idx= 607\n",
      "trial_idx= 608\n",
      "trial_idx= 609\n",
      "trial_idx= 610\n",
      "trial_idx= 611\n",
      "trial_idx= 612\n",
      "trial_idx= 613\n",
      "trial_idx= 614\n",
      "trial_idx= 615\n",
      "trial_idx= 616\n",
      "trial_idx= 617\n",
      "trial_idx= 618\n",
      "trial_idx= 619\n",
      "trial_idx= 620\n",
      "trial_idx= 621\n",
      "trial_idx= 622\n",
      "trial_idx= 623\n",
      "trial_idx= 624\n",
      "trial_idx= 625\n",
      "trial_idx= 626\n",
      "trial_idx= 627\n",
      "trial_idx= 628\n",
      "trial_idx= 629\n",
      "trial_idx= 630\n",
      "trial_idx= 631\n",
      "trial_idx= 632\n",
      "trial_idx= 633\n",
      "trial_idx= 634\n",
      "trial_idx= 635\n",
      "trial_idx= 636\n",
      "trial_idx= 637\n",
      "trial_idx= 638\n",
      "trial_idx= 639\n",
      "trial_idx= 640\n",
      "trial_idx= 641\n",
      "trial_idx= 642\n",
      "trial_idx= 643\n",
      "trial_idx= 644\n",
      "trial_idx= 645\n",
      "trial_idx= 646\n",
      "trial_idx= 647\n",
      "trial_idx= 648\n",
      "trial_idx= 649\n",
      "trial_idx= 650\n",
      "trial_idx= 651\n",
      "trial_idx= 652\n",
      "trial_idx= 653\n",
      "trial_idx= 654\n",
      "trial_idx= 655\n",
      "trial_idx= 656\n",
      "trial_idx= 657\n",
      "trial_idx= 658\n",
      "trial_idx= 659\n",
      "trial_idx= 660\n",
      "trial_idx= 661\n",
      "trial_idx= 662\n",
      "trial_idx= 663\n",
      "trial_idx= 664\n",
      "trial_idx= 665\n",
      "trial_idx= 666\n",
      "trial_idx= 667\n",
      "trial_idx= 668\n",
      "trial_idx= 669\n",
      "trial_idx= 670\n",
      "trial_idx= 671\n",
      "trial_idx= 672\n",
      "trial_idx= 673\n",
      "trial_idx= 674\n",
      "trial_idx= 675\n",
      "trial_idx= 676\n",
      "trial_idx= 677\n",
      "trial_idx= 678\n",
      "trial_idx= 679\n",
      "trial_idx= 680\n",
      "trial_idx= 681\n",
      "trial_idx= 682\n",
      "trial_idx= 683\n",
      "trial_idx= 684\n",
      "trial_idx= 685\n",
      "trial_idx= 686\n",
      "trial_idx= 687\n",
      "trial_idx= 688\n",
      "trial_idx= 689\n",
      "trial_idx= 690\n",
      "trial_idx= 691\n",
      "trial_idx= 692\n",
      "trial_idx= 693\n",
      "trial_idx= 694\n",
      "trial_idx= 695\n",
      "trial_idx= 696\n",
      "trial_idx= 697\n",
      "trial_idx= 698\n",
      "trial_idx= 699\n",
      "trial_idx= 700\n",
      "trial_idx= 701\n",
      "trial_idx= 702\n",
      "trial_idx= 703\n",
      "trial_idx= 704\n",
      "trial_idx= 705\n",
      "trial_idx= 706\n",
      "trial_idx= 707\n",
      "trial_idx= 708\n",
      "trial_idx= 709\n",
      "trial_idx= 710\n",
      "trial_idx= 711\n",
      "trial_idx= 712\n",
      "trial_idx= 713\n",
      "trial_idx= 714\n",
      "trial_idx= 715\n",
      "trial_idx= 716\n",
      "trial_idx= 717\n",
      "trial_idx= 718\n",
      "trial_idx= 719\n",
      "trial_idx= 720\n",
      "trial_idx= 721\n",
      "trial_idx= 722\n",
      "trial_idx= 723\n",
      "trial_idx= 724\n",
      "trial_idx= 725\n",
      "trial_idx= 726\n",
      "trial_idx= 727\n",
      "trial_idx= 728\n",
      "trial_idx= 729\n",
      "trial_idx= 730\n",
      "trial_idx= 731\n",
      "trial_idx= 732\n",
      "trial_idx= 733\n",
      "trial_idx= 734\n",
      "trial_idx= 735\n",
      "trial_idx= 736\n",
      "trial_idx= 737\n",
      "trial_idx= 738\n",
      "trial_idx= 739\n",
      "trial_idx= 740\n",
      "trial_idx= 741\n",
      "trial_idx= 742\n",
      "trial_idx= 743\n",
      "trial_idx= 744\n",
      "trial_idx= 745\n",
      "trial_idx= 746\n",
      "trial_idx= 747\n",
      "trial_idx= 748\n",
      "trial_idx= 749\n",
      "trial_idx= 750\n",
      "trial_idx= 751\n",
      "trial_idx= 752\n",
      "trial_idx= 753\n",
      "trial_idx= 754\n",
      "trial_idx= 755\n",
      "trial_idx= 756\n",
      "trial_idx= 757\n",
      "trial_idx= 758\n",
      "trial_idx= 759\n",
      "trial_idx= 760\n",
      "trial_idx= 761\n",
      "trial_idx= 762\n",
      "trial_idx= 763\n",
      "trial_idx= 764\n",
      "trial_idx= 765\n",
      "trial_idx= 766\n",
      "trial_idx= 767\n",
      "trial_idx= 768\n",
      "trial_idx= 769\n",
      "trial_idx= 770\n",
      "trial_idx= 771\n",
      "trial_idx= 772\n",
      "trial_idx= 773\n",
      "trial_idx= 774\n",
      "trial_idx= 775\n",
      "trial_idx= 776\n",
      "trial_idx= 777\n",
      "trial_idx= 778\n",
      "trial_idx= 779\n",
      "trial_idx= 780\n",
      "trial_idx= 781\n",
      "trial_idx= 782\n",
      "trial_idx= 783\n",
      "trial_idx= 784\n",
      "trial_idx= 785\n",
      "trial_idx= 786\n",
      "trial_idx= 787\n",
      "trial_idx= 788\n",
      "trial_idx= 789\n",
      "trial_idx= 790\n",
      "trial_idx= 791\n",
      "trial_idx= 792\n",
      "trial_idx= 793\n",
      "trial_idx= 794\n",
      "trial_idx= 795\n",
      "trial_idx= 796\n",
      "trial_idx= 797\n",
      "trial_idx= 798\n",
      "trial_idx= 799\n",
      "trial_idx= 800\n",
      "trial_idx= 801\n",
      "trial_idx= 802\n",
      "trial_idx= 803\n",
      "trial_idx= 804\n",
      "trial_idx= 805\n",
      "trial_idx= 806\n",
      "trial_idx= 807\n",
      "trial_idx= 808\n",
      "trial_idx= 809\n",
      "trial_idx= 810\n",
      "trial_idx= 811\n",
      "trial_idx= 812\n",
      "trial_idx= 813\n",
      "trial_idx= 814\n",
      "trial_idx= 815\n",
      "trial_idx= 816\n",
      "trial_idx= 817\n",
      "trial_idx= 818\n",
      "trial_idx= 819\n",
      "trial_idx= 820\n",
      "trial_idx= 821\n",
      "trial_idx= 822\n",
      "trial_idx= 823\n",
      "trial_idx= 824\n",
      "trial_idx= 825\n",
      "trial_idx= 826\n",
      "trial_idx= 827\n",
      "trial_idx= 828\n",
      "trial_idx= 829\n",
      "trial_idx= 830\n",
      "trial_idx= 831\n",
      "trial_idx= 832\n",
      "trial_idx= 833\n",
      "trial_idx= 834\n",
      "trial_idx= 835\n",
      "trial_idx= 836\n",
      "trial_idx= 837\n",
      "trial_idx= 838\n",
      "trial_idx= 839\n",
      "trial_idx= 840\n",
      "trial_idx= 841\n",
      "trial_idx= 842\n",
      "trial_idx= 843\n",
      "trial_idx= 844\n",
      "trial_idx= 845\n",
      "trial_idx= 846\n",
      "trial_idx= 847\n",
      "trial_idx= 848\n",
      "trial_idx= 849\n",
      "trial_idx= 850\n",
      "trial_idx= 851\n",
      "trial_idx= 852\n",
      "trial_idx= 853\n",
      "trial_idx= 854\n",
      "trial_idx= 855\n",
      "trial_idx= 856\n",
      "trial_idx= 857\n",
      "trial_idx= 858\n",
      "trial_idx= 859\n",
      "trial_idx= 860\n",
      "trial_idx= 861\n",
      "trial_idx= 862\n",
      "trial_idx= 863\n",
      "trial_idx= 864\n",
      "trial_idx= 865\n",
      "trial_idx= 866\n",
      "trial_idx= 867\n",
      "trial_idx= 868\n",
      "trial_idx= 869\n",
      "trial_idx= 870\n",
      "trial_idx= 871\n",
      "trial_idx= 872\n",
      "trial_idx= 873\n",
      "trial_idx= 874\n",
      "trial_idx= 875\n",
      "trial_idx= 876\n",
      "trial_idx= 877\n",
      "trial_idx= 878\n",
      "trial_idx= 879\n",
      "trial_idx= 880\n",
      "trial_idx= 881\n",
      "trial_idx= 882\n",
      "trial_idx= 883\n",
      "trial_idx= 884\n",
      "trial_idx= 885\n",
      "trial_idx= 886\n",
      "trial_idx= 887\n",
      "trial_idx= 888\n",
      "trial_idx= 889\n",
      "trial_idx= 890\n",
      "trial_idx= 891\n",
      "trial_idx= 892\n",
      "trial_idx= 893\n",
      "trial_idx= 894\n",
      "trial_idx= 895\n",
      "trial_idx= 896\n",
      "trial_idx= 897\n",
      "trial_idx= 898\n",
      "trial_idx= 899\n",
      "trial_idx= 900\n",
      "trial_idx= 901\n",
      "trial_idx= 902\n",
      "trial_idx= 903\n",
      "trial_idx= 904\n",
      "trial_idx= 905\n",
      "trial_idx= 906\n",
      "trial_idx= 907\n",
      "trial_idx= 908\n",
      "trial_idx= 909\n",
      "trial_idx= 910\n",
      "trial_idx= 911\n",
      "trial_idx= 912\n",
      "trial_idx= 913\n",
      "trial_idx= 914\n",
      "trial_idx= 915\n",
      "trial_idx= 916\n",
      "trial_idx= 917\n",
      "trial_idx= 918\n",
      "trial_idx= 919\n",
      "trial_idx= 920\n",
      "trial_idx= 921\n",
      "trial_idx= 922\n",
      "trial_idx= 923\n",
      "trial_idx= 924\n",
      "trial_idx= 925\n",
      "trial_idx= 926\n",
      "trial_idx= 927\n",
      "trial_idx= 928\n",
      "trial_idx= 929\n",
      "trial_idx= 930\n",
      "trial_idx= 931\n",
      "trial_idx= 932\n",
      "trial_idx= 933\n",
      "trial_idx= 934\n",
      "trial_idx= 935\n",
      "trial_idx= 936\n",
      "trial_idx= 937\n",
      "trial_idx= 938\n",
      "trial_idx= 939\n",
      "trial_idx= 940\n",
      "trial_idx= 941\n",
      "trial_idx= 942\n",
      "trial_idx= 943\n",
      "trial_idx= 944\n",
      "trial_idx= 945\n",
      "trial_idx= 946\n",
      "trial_idx= 947\n",
      "trial_idx= 948\n",
      "trial_idx= 949\n",
      "trial_idx= 950\n",
      "trial_idx= 951\n",
      "trial_idx= 952\n",
      "trial_idx= 953\n",
      "trial_idx= 954\n",
      "trial_idx= 955\n",
      "trial_idx= 956\n",
      "trial_idx= 957\n",
      "trial_idx= 958\n",
      "trial_idx= 959\n",
      "trial_idx= 960\n",
      "trial_idx= 961\n",
      "trial_idx= 962\n",
      "trial_idx= 963\n",
      "trial_idx= 964\n",
      "trial_idx= 965\n",
      "trial_idx= 966\n",
      "trial_idx= 967\n",
      "trial_idx= 968\n",
      "trial_idx= 969\n",
      "trial_idx= 970\n",
      "trial_idx= 971\n",
      "trial_idx= 972\n",
      "trial_idx= 973\n",
      "trial_idx= 974\n",
      "trial_idx= 975\n",
      "trial_idx= 976\n",
      "trial_idx= 977\n",
      "trial_idx= 978\n",
      "trial_idx= 979\n",
      "trial_idx= 980\n",
      "trial_idx= 981\n",
      "trial_idx= 982\n",
      "trial_idx= 983\n",
      "trial_idx= 984\n",
      "trial_idx= 985\n",
      "trial_idx= 986\n",
      "trial_idx= 987\n",
      "trial_idx= 988\n",
      "trial_idx= 989\n",
      "trial_idx= 990\n",
      "trial_idx= 991\n",
      "trial_idx= 992\n",
      "trial_idx= 993\n",
      "trial_idx= 994\n",
      "trial_idx= 995\n",
      "trial_idx= 996\n",
      "trial_idx= 997\n",
      "trial_idx= 998\n",
      "trial_idx= 999\n"
     ]
    }
   ],
   "source": [
    "J = 50  # Total iterations\n",
    "p = 0.4 # dropout rate\n",
    "\n",
    "\n",
    "\n",
    "is_print = False\n",
    "# is_print = False\n",
    "\n",
    "is_print_tmp = True\n",
    "\n",
    "N_schemes = 4\n",
    "\n",
    "N_trial = 1000\n",
    "\n",
    "Agg_Card = np.zeros((N_schemes, N_trial, J))\n",
    "Privacy  = np.zeros((N_schemes, N_trial, J))\n",
    "\n",
    "\n",
    "for trial_idx in range(N_trial):\n",
    "    \n",
    "    print('trial_idx=',trial_idx)\n",
    "#     print()\n",
    "    \n",
    "    P_random    = []\n",
    "    P_partition = []\n",
    "    P_proposed  = []\n",
    "    P_proposed_T2 = []\n",
    "    \n",
    "    for j in range(J):\n",
    "        u = np.random.binomial(1, 1-p, size=(N))\n",
    "        if is_print:\n",
    "            print('[iter=',j,'] Surviving vector u=',u)\n",
    "\n",
    "        if np.sum(u) < K:\n",
    "            p_tmp = np.zero(N)\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "            P_partition.append(p_tmp)\n",
    "            P_proposed.append(p_tmp)\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "        else:\n",
    "            result = np.where(u == 1)\n",
    "\n",
    "            ###############################\n",
    "            # 1. Random Selection\n",
    "            ###############################\n",
    "            select = np.random.choice(result[0], K, replace=False)\n",
    "\n",
    "            p_tmp = np.zeros(N)\n",
    "            p_tmp[select] = 1\n",
    "\n",
    "            P_random.append(p_tmp)\n",
    "\n",
    "            # 1.1 Calculate Privacy\n",
    "            P = np.array(P_random)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[0,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[0,trial_idx,j] = np.min([partial_sum, Privacy[0,trial_idx,j-1]])\n",
    "\n",
    "            # 1.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_random),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[0,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print('[iter=',j,'] @Random Method, Codebook selection')\n",
    "\n",
    "            ###############################\n",
    "            # 2. Partition\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Partition * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Partition Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "                p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "\n",
    "            P_partition.append(p_tmp)\n",
    "\n",
    "            # 2.1 Calculate Privacy\n",
    "            P = np.array(P_partition)\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[1,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[1,trial_idx,j] = np.min([partial_sum, Privacy[1,trial_idx,j-1]])\n",
    "\n",
    "            # 2.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_partition),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[1,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "            ###############################\n",
    "            # 3. Proposed, T_0 = 4\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[2,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[2,trial_idx,j] = np.min([partial_sum, Privacy[2,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[2,trial_idx,j] = acc_card/(j+1)\n",
    "            \n",
    "            \n",
    "            \n",
    "            ###############################\n",
    "            # 4. Proposed, T_0 = 2\n",
    "            ###############################\n",
    "\n",
    "            tmp = Codebook_Proposed_T2 * u\n",
    "            codebook_en = 1*(np.sum(tmp,axis=1) == K)\n",
    "    #         print(np.sum(tmp,axis=1))\n",
    "    #         print(codebook_en)\n",
    "\n",
    "            if np.sum(codebook_en) == 0:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @Proposed Method 2, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "    #             print('idx_sel=',idx_sel)\n",
    "\n",
    "                p_tmp = Codebook_Proposed_T2[idx_sel[0],:]\n",
    "\n",
    "\n",
    "\n",
    "            P_proposed_T2.append(p_tmp)\n",
    "\n",
    "            # 3.1 Calculate Privacy\n",
    "            P = np.array(P_proposed_T2)\n",
    "\n",
    "            P_rref = rref(P)\n",
    "\n",
    "            P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "            zero_index = np.where(P_num == 0)\n",
    "            P_num[zero_index] = N+1\n",
    "\n",
    "            partial_sum = np.min(P_num)\n",
    "            if partial_sum == N+1:\n",
    "                partial_sum = K\n",
    "\n",
    "            if j == 0:\n",
    "                Privacy[3,trial_idx,j] = partial_sum\n",
    "            else:\n",
    "                Privacy[3,trial_idx,j] = np.min([partial_sum, Privacy[3,trial_idx,j-1]])\n",
    "\n",
    "            # 3.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_proposed_T2),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[3,trial_idx,j] = acc_card/(j+1)\n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print()\n",
    "\n",
    "\n",
    "        # random selection\n",
    "\n",
    "#     print(Privacy)\n",
    "#     print()\n",
    "#     print(Agg_Card)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 50)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# matplotlib.use('Agg')\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "mean_priavcy_p04 = np.sum(Privacy, axis=1)/N_trial\n",
    "print(np.shape(mean_priavcy_p04))\n",
    "\n",
    "plt.plot(mean_priavcy_p04[0,:], label='random')\n",
    "plt.plot(mean_priavcy_p04[1,:], label='partition')\n",
    "plt.plot(mean_priavcy_p04[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_priavcy_p04[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Privacy')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "mean_Agg_Card_p04 = np.sum(Agg_Card, axis=1)/N_trial\n",
    "print(np.shape(mean_Agg_Card_p04))\n",
    "\n",
    "plt.plot(mean_Agg_Card_p04[0,:], label='random')\n",
    "plt.plot(mean_Agg_Card_p04[1,:], label='partition')\n",
    "plt.plot(mean_Agg_Card_p04[2,:], label='proposed, T=4')\n",
    "plt.plot(mean_Agg_Card_p04[3,:], label='proposed, T=2')\n",
    "plt.ylabel('Aggregation Cardinality')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,9])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.94235199\n",
      "7.447055137407359\n"
     ]
    }
   ],
   "source": [
    "p = 0.3\n",
    "K = 8\n",
    "pr_b_i_unavail = 1- (1-p) ** 8\n",
    "\n",
    "all_unavail = pr_b_i_unavail ** 45\n",
    "print(pr_b_i_unavail)\n",
    "\n",
    "print((1 - all_unavail)*8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10456592670160\n",
      "0.05764800999999997\n",
      "0.9999930396608473\n"
     ]
    }
   ],
   "source": [
    "from utils.functions import *\n",
    "\n",
    "N = 120\n",
    "T = 6\n",
    "K = 12\n",
    "\n",
    "p =0.3\n",
    "\n",
    "R_max = int(nCr(N, K-np.floor(T/2)))\n",
    "print(R_max)\n",
    "\n",
    "# q_i = proabaility that i-th codeword is available\n",
    "q_i = (1-p) ** 8\n",
    "    \n",
    "print(q_i)\n",
    "\n",
    "# ((1-q_i)**200) = Pr{ all codeword is unavailable }\n",
    "print(1-((1-q_i)**200))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1758608767254.1814\n",
      "5.945945945945947\n"
     ]
    }
   ],
   "source": [
    "from utils.functions import *\n",
    "import numpy as np\n",
    "\n",
    "N=120\n",
    "K=12\n",
    "\n",
    "R_max = int(nCr(N, K)) / int(nCr(N-K+3-1, 2))\n",
    "\n",
    "print(R_max)\n",
    "print(10456592670160/R_max)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.882351\n",
      "19\n",
      "20\n",
      "0.2999887589901408\n",
      "8.40013489211831\n"
     ]
    }
   ],
   "source": [
    "N = 120\n",
    "T = 6\n",
    "K = 12\n",
    "\n",
    "p = 0.3\n",
    "prob_a_bin_is_not_available = 1 - ((1-p) ** T)\n",
    "print(prob_a_bin_is_not_available)\n",
    "\n",
    "sum = 0\n",
    "\n",
    "prob_array = np.zeros((int(N/T)+1))\n",
    "\n",
    "# L = int(N/T)\n",
    "# print(L)\n",
    "for j in range(int(N/T)+1):\n",
    "#     print(j)\n",
    "    prob_array[j] = nCr(L, j)* (prob_a_bin_is_not_available ** j) * (1-prob_a_bin_is_not_available)**(L-j)\n",
    "\n",
    "# print(prob_array)\n",
    "# print(np.sum(prob_array))\n",
    "for j in range(int(N/T- K/T +1),int(N/T)+1):\n",
    "    print(j)\n",
    "    \n",
    "#     sum = sum + (prob_a_bin_is_not_available ** j)\n",
    "    sum = sum + nCr(L, j)* (prob_a_bin_is_not_available ** j) * (1-prob_a_bin_is_not_available)**(L-j)\n",
    "\n",
    "print(sum)\n",
    "\n",
    "print((1-sum)*K)\n"
   ]
  },
  {
   "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
