{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from sympy import * \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": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "T= 1\n",
      "T= 2\n",
      "T= 3\n",
      "T= 4\n",
      "T= 5\n",
      "T= 6\n",
      "T= 7\n",
      "T= 8\n",
      "T= 9\n",
      "T= 10\n",
      "T= 11\n",
      "T= 12\n",
      "T= 13\n",
      "T= 14\n",
      "T= 15\n",
      "[5.     4.4064 3.7632 3.18   2.734  2.4414 2.2358 2.0876 1.9044 1.4762\n",
      " 1.2222 1.103  1.0478 1.021  1.012 ]\n"
     ]
    }
   ],
   "source": [
    "N=10\n",
    "K=5\n",
    "T_max = 15\n",
    "is_print = False\n",
    "\n",
    "N_trial = 5000\n",
    "T_array = np.array(range(1,T_max+1))\n",
    "partial_sum_array = np.zeros((len(T_array),N_trial))\n",
    "\n",
    "for j in range(len(T_array)):\n",
    "    \n",
    "    T = T_array[j]\n",
    "    print('T=',T)\n",
    "    for i in range(N_trial):\n",
    "        P = []\n",
    "        # print(len(P))\n",
    "        while(len(P)<T):\n",
    "            M = np.random.binomial(1, 0.7, size=(N))\n",
    "            if np.sum(M) < K:\n",
    "                continue;\n",
    "            else:\n",
    "                result = np.where(M == 1)\n",
    "\n",
    "            if is_print:\n",
    "                print('surviving user info:',result[0])\n",
    "            select = np.random.choice(result[0], K, replace=False)\n",
    "\n",
    "            tmp = np.zeros(N)\n",
    "            tmp[select] = 1\n",
    "            if is_print:\n",
    "                print('selected user info:',tmp)\n",
    "\n",
    "            P.append(tmp)\n",
    "\n",
    "        P = np.array(P)\n",
    "        # print(P)\n",
    "        P_rref = rref(P)\n",
    "\n",
    "        if is_print:\n",
    "            print(P_rref)\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",
    "        # result = np.where(P_rref != 0)\n",
    "        if is_print:\n",
    "            print(P_num)\n",
    "\n",
    "        partial_sum = np.min(P_num)\n",
    "        if is_print:\n",
    "            print(partial_sum)\n",
    "\n",
    "        partial_sum_array[j][i] = partial_sum\n",
    "\n",
    "mean_partial_sum = np.mean(partial_sum_array, axis=1)\n",
    "print(mean_partial_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "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_partial_sum)\n",
    "plt.ylabel('Avg # Partial Sum')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "0.0\n",
      "0.0\n",
      "0.0\n",
      "0.0002\n",
      "0.0006\n",
      "0.0028\n",
      "0.0178\n",
      "0.1186\n",
      "0.5286\n",
      "0.7794\n",
      "0.8972\n",
      "0.9522\n",
      "0.979\n",
      "0.988\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": [
    "num_is_one = np.zeros(len(T_array))\n",
    "for i in range(len(T_array)):\n",
    "    is_one = np.where(partial_sum_array[i,:] == 1)\n",
    "    \n",
    "    num_is_one[i] = np.shape(is_one)[1] / N_trial\n",
    "    print(num_is_one[i])\n",
    "    \n",
    "plt.plot(num_is_one)\n",
    "plt.ylabel('Pr{N_partial == 1}')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1 1 1 1 1 0 0 0 0 0]\n",
      " [0 0 0 0 0 1 1 1 1 1]\n",
      " [0 0 1 1 1 1 1 0 0 0]\n",
      " [1 1 0 0 0 0 0 1 1 1]\n",
      " [1 0 0 0 1 1 1 0 0 1]\n",
      " [0 1 1 1 0 0 0 1 1 0]]\n",
      "\n",
      "[[ 1  0  0  0  1  0  0 -1 -1  0]\n",
      " [ 0  1  0  0 -1  0  0  2  2  1]\n",
      " [ 0  0  1  1  1  0  0 -1 -1 -1]\n",
      " [ 0  0  0  0  0  1  1  1  1  1]\n",
      " [ 0  0  0  0  0  0  0  0  0  0]\n",
      " [ 0  0  0  0  0  0  0  0  0  0]]\n",
      "6\n"
     ]
    }
   ],
   "source": [
    "Basis = np.array([[1,1,1,1,1,0,0,0,0,0],[0,0,0,0,0,1,1,1,1,1],[0,0,1,1,1,1,1,0,0,0],[1,1,0,0,0,0,0,1,1,1],[1,0,0,0,1,1,1,0,0,1],[0,1,1,1,0,0,0,1,1,0]])\n",
    "print(Basis)\n",
    "\n",
    "Basis_rref = rref(Basis)\n",
    "\n",
    "print()\n",
    "print(Basis_rref)\n",
    "\n",
    "print(len(Basis))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "T= 1\n",
      "T= 2\n",
      "T= 3\n",
      "T= 4\n",
      "T= 5\n",
      "T= 6\n",
      "T= 7\n",
      "T= 8\n",
      "T= 9\n",
      "T= 10\n",
      "T= 11\n",
      "T= 12\n",
      "T= 13\n",
      "T= 14\n",
      "T= 15\n"
     ]
    }
   ],
   "source": [
    "Basis = np.array([[1,1,1,1,1,0,0,0,0,0],[0,0,0,0,0,1,1,1,1,1],[0,0,1,1,1,1,1,0,0,0],[1,1,0,0,0,0,0,1,1,1],[1,0,0,0,1,1,1,0,0,1],[0,1,1,1,0,0,0,1,1,0]])\n",
    "\n",
    "partial_sum_array_prop = np.zeros((len(T_array),N_trial))\n",
    "\n",
    "for j in range(len(T_array)):\n",
    "    \n",
    "    T = T_array[j]\n",
    "    print('T=',T)\n",
    "    for i in range(N_trial):\n",
    "        \n",
    "        P = []\n",
    "        # print(len(P))\n",
    "        while(len(P)<T):\n",
    "#             select = np.random.choice(result[0], K, replace=False)\n",
    "            select = np.random.choice(range(len(Basis)),1,replace=False)\n",
    "            tmp = Basis[select[0],:]\n",
    "#             print(tmp)\n",
    "            P.append(tmp)\n",
    "\n",
    "        P = np.array(P)\n",
    "        # print(P)\n",
    "        P_rref = rref(P)\n",
    "\n",
    "        if is_print:\n",
    "            print(P_rref)\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",
    "        # result = np.where(P_rref != 0)\n",
    "        if is_print:\n",
    "            print(P_num)\n",
    "\n",
    "        partial_sum = np.min(P_num)\n",
    "        if is_print:\n",
    "            print(partial_sum)\n",
    "\n",
    "        partial_sum_array_prop[j][i] = partial_sum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[5.     4.782  4.6356 4.46   4.3172 4.2042 4.1406 4.0862 4.056  4.0356\n",
      " 4.0234 4.0148 4.0106 4.0076 4.0042]\n"
     ]
    }
   ],
   "source": [
    "mean_partial_sum_prop = np.mean(partial_sum_array_prop, axis=1)\n",
    "print(mean_partial_sum_prop)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAEGCAYAAABo25JHAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nO3dd3hUZfr/8fc9k0kCBEIPSIAAoYcQEqq0BCwoiMKqiBXLYl0ru5bdn4j7Vde111VWRVzAWFZcRFQUgYBiAaQX6RBQ6SX0JPfvjzOBgClDkslkMvfrus41Z+aU+WTEuec55XlEVTHGGBO6XIEOYIwxJrCsEBhjTIizQmCMMSHOCoExxoQ4KwTGGBPiwgId4EzVrVtX4+LiSrTtwYMHqVatWtkG8qNgyhtMWSG48gZTVgiuvMGUFUqXd8GCBTtVtV6BC1U1qKaUlBQtqZkzZ5Z420AIprzBlFU1uPIGU1bV4MobTFlVS5cXmK+FfK/aoSFjjAlxVgiMMSbEWSEwxpgQF3Qni40xJXP8+HEyMzM5cuSIX98nOjqalStX+vU9ykowZQXf8kZGRhIbG4vH4/F5v1YIjAkRmZmZVK9enbi4OETEb+9z4MABqlev7rf9l6VgygrF51VVdu3aRWZmJs2aNfN5v349NCQiG0VkqYgsEpH5BSwXEXlRRNaKyBIRSfZnHmNC2ZEjR6hTp45fi4AJLBGhTp06Z9zqK48WQZqq7ixk2QVAS+/UDfiX99EY4wdWBCq/kvw3DvTJ4ouBd7yXuX4H1BSRhv54ox2/bObYD//m+N5t/ti9McYELVE/jkcgIhuAPYACr6vq2NOWTwX+oapzvc9nAPer6vzT1hsJjASIiYlJSU9PP+MsB36exQVbXyBX3GxvNIDNTYZyLKJ2if6u8pKVlUVUVFSgY/gkmLJCcOUtq6zR0dHEx8eXQaKi5eTk4Ha7/f4+AAkJCcyePZs6deqUaPuyyFrSDHPmzCE8PJxu3ZyDIG+++SZVqlThyiuvLHXetWvXsm/fvlNeS0tLW6CqnQta39+Hhnqq6jYRqQ98KSKrVDUj3/KC2jC/q0zeAjIWoHPnzpqamnrmSVJTeeDFZiRv/y+XbptG7K/TIWUE9Lobapx15vsrB7NmzaJEf2sABFNWCK68ZZV15cqV5XJi1JcTsCfuaHWV7qCEiBAVFVXiv6ssThaXNMMPP/xAVFQU55xzDgB33313sdv4mjcyMpJOnTr5nMWvh4ZUdZv3cTswGeh62iqZQON8z2MBvx276de+CW/VHcUl8gKH2wyFH9+AF5Jg2p9hvx0yMsafNm7cSNu2bbnttttITk5my5Yt3HrrrXTu3Jn27dszevToE+vGxcUxevRokpOT6dChA6tWrQJg165dnHfeeXTq1Imbb76Z/Ec0nn32WRISEkhISOD5558/8Z5t2rThpptuIiEhgauuuoqvvvqKnj170rJlS+bP/901LCxfvpyuXbuSlJREYmIia9asAWDChAknXr/55pvJycn53baFrfP555+TnJxMx44d6d+/Pxs3buS1117jueeeIykpiTlz5vDII4/w9NNPA7Bo0SK6d+9OYmIiQ4YMYc+ePQBceOGF3H///XTt2pVWrVoxZ86csvhP478WgYhUA1yqesA7fx7w6GmrTQHuEJF0nJPE+1T1F39lCncLL1+ZzEUvHeKGPSOYcMf9uL95Fua/BQvehuRrodc9EB3rrwjGVAhjPlnOim37y3Sf7c6qweiL2he5zurVqxk3bhyvvvoqAI899hi1a9cmJyeH/v37s2TJEhITEwGoW7cuCxcu5NVXX+Xpp5/mjTfeYMyYMfTq1YuHH36YTz/9lLFjnaPNCxYsYNy4cXz//feoKt26daNv377UqlWLtWvX8sEHHzB27Fi6dOnCpEmTmDt3LlOmTOGZZ54hLS3tlIyvvfYad911F1dddRXHjh0jJyeHlStX8t577/HNN9/g8Xi47bbbmDhxItdee+2J7Qpb54ILLuCPf/wjGRkZNGvWjN27d1O7dm1uueUWoqKiGDVqFAAzZsw4sa9rr72Wl156ib59+/Lwww8zZsyYE8UtOzubH374gWnTpjFmzBi++uqrUv6X82+LIAaYKyKLgR+AT1X1cxG5RURu8a4zDVgPrAX+DdzmxzwAxNeP4u+XJDBv/S5e/ikbBr8Ef1oIHYc7xeDFTjD1XtiX6e8oxoScpk2b0r179xPP33//fZKTk+nUqRPLly9nxYoVJ5YNHToUgJSUFDZu3AhARkYGV199NQADBw6kVq1aAMydO5chQ4ZQrVo1oqKiGDp06Ilfy82aNaNDhw64XC7at29P//79ERE6dOjA5s2bf5exR48ePP744zz55JNs2rSJ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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(mean_partial_sum,label='random selection')\n",
    "plt.plot(mean_partial_sum_prop,label='proposed')\n",
    "plt.ylabel('Avg # Partial Sum')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "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
}
