{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "323c31d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils.functions import *\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "0844c6ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1\n",
      " 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n"
     ]
    }
   ],
   "source": [
    "N   = 120\n",
    "K   = 12\n",
    "\n",
    "p_array = np.array([0.1]) # dropout rate\n",
    "\n",
    "# print(p_matrix)\n",
    "p_sel = np.random.randint(low=0, high=len(p_array), size=(N,))\n",
    "\n",
    "p_per_user = np.ones((N,))\n",
    "\n",
    "for i in range(N):\n",
    "    p_per_user[i] = p_array[p_sel[i]]\n",
    "\n",
    "print(p_per_user)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d1f74956",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "@CodeBookDesign_Partition, Codebook Size= 10\n",
      "@CodeBookDesign_Partition, Codebook Size= 10\n",
      "[1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1\n",
      " 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1\n",
      " 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1\n",
      " 1 1 1 1 1 1 1 1 1]\n",
      "[12 12 12 12 12 12 12 12 12 12]\n"
     ]
    }
   ],
   "source": [
    "Codebook_Partition = CodeBookDesign_Partition(N,K)\n",
    "\n",
    "def CodeBookDesign_Partition_random(N,K):\n",
    "    B_Partition = int(N/K)\n",
    "\n",
    "    Codebook_Partition = np.zeros((B_Partition,N), dtype='int')\n",
    "    \n",
    "    idx_shard = [i for i in range(N)]\n",
    "\n",
    "    print('@CodeBookDesign_Partition, Codebook Size=',B_Partition)\n",
    "\n",
    "    for b in range(B_Partition):\n",
    "        rand_set = set(np.random.choice(idx_shard, K, replace=False))\n",
    "        #print(i,rand_set)\n",
    "        idx_shard = list(set(idx_shard) - rand_set)\n",
    "        for rand in rand_set:\n",
    "            Codebook_Partition[b,rand] = 1\n",
    "            \n",
    "#         stt_pos = b * K\n",
    "#         end_pos = (b+1) * K\n",
    "#         Codebook_Partition[b,stt_pos:end_pos] = 1\n",
    "\n",
    "    return Codebook_Partition\n",
    "\n",
    "Codebook_Partition_rand = CodeBookDesign_Partition_random(N,K)\n",
    "\n",
    "print(np.sum(Codebook_Partition_rand,axis=0))\n",
    "print(np.sum(Codebook_Partition_rand,axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "b311e0f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "trial_idx= 0\n",
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "trial_idx= 1\n",
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "trial_idx= 2\n",
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "trial_idx= 3\n",
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "trial_idx= 4\n",
      "@CodeBookDesign_Partition, Codebook Size= 2\n",
      "(3, 100)\n",
      "(3, 100)\n",
      "(3, 100)\n"
     ]
    }
   ],
   "source": [
    "N = 120\n",
    "K = 12\n",
    "\n",
    "\n",
    "Codebook_Partition = CodeBookDesign_Partition(N,K)\n",
    "\n",
    "J = 100  # Total iterations\n",
    "Max_iter = J\n",
    "\n",
    "j_0 = J/2\n",
    "\n",
    "is_print = False\n",
    "# is_print = False\n",
    "\n",
    "is_print_tmp = True\n",
    "\n",
    "is_selection_applied = False\n",
    "\n",
    "N_schemes = 3\n",
    "\n",
    "'''\n",
    "Information about N_schemes\n",
    "0: Random selection\n",
    "1: Partition (Static)\n",
    "2: Partition (Dynamic)\n",
    "'''\n",
    "\n",
    "N_trial = 5\n",
    "\n",
    "Agg_Card = np.zeros((N_schemes, N_trial, J))\n",
    "Privacy  = np.zeros((N_schemes, N_trial, J))\n",
    "Fairness = 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_dynamic_partition = []\n",
    "    \n",
    "    Codebook_Partition_rand = CodeBookDesign_Partition_random(N,K)\n",
    "    \n",
    "    for j in range(J):\n",
    "        \n",
    "        # Realization of u vector with the same dropout probability\n",
    "#         u = np.random.binomial(1, 1-p, size=(N))\n",
    "        \n",
    "        u = np.ones((N,))\n",
    "        for u_idx in range(N):\n",
    "            p_sel = p_per_user[u_idx]\n",
    "            u[u_idx] = np.random.binomial(1, 1-p_sel, size=1)[0]\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_dynamic_partition.append(p_tmp)\n",
    "\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",
    "            # 1.3. Calculate Fairness\n",
    "            P = np.array(P_random)\n",
    "#             P_sum = np.sum(P, axis=0)/(j+1)\n",
    "#             Fairness[0,trial_idx,j] = np.max(P_sum) - np.min(P_sum)\n",
    "            \n",
    "            num_aggr_true = acc_card / K\n",
    "\n",
    "            if num_aggr_true == 0:\n",
    "                Fairness[0,trial_idx,j] = 0\n",
    "            else:\n",
    "                P_sum = np.sum(P, axis=0)/num_aggr_true\n",
    "                Fairness[0,trial_idx,j] = np.max(P_sum) - np.min(P_sum)           \n",
    "            \n",
    "\n",
    "\n",
    "            if is_print:\n",
    "                print('[iter=',j,'] @Random Method, Codebook selection')\n",
    "                \n",
    "            \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",
    "                \n",
    "                if is_selection_applied:\n",
    "                    codebook_en_num = np.sum(codebook_en)\n",
    "                    Codebook_En = np.reshape(Codebook_Partition[idx_en,:],(codebook_en_num,N))\n",
    "                    \n",
    "                    p_tmp = UserSelection_Codebook(P_partition, Codebook_En)\n",
    "                else:\n",
    "                    idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "                    p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "                    \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",
    "            # 2.3. Calculate Fairness\n",
    "            P = np.array(P_partition)\n",
    "#             P_sum = np.sum(P, axis=0)/(j+1)\n",
    "#             Fairness[1,trial_idx,j] = np.max(P_sum) - np.min(P_sum)\n",
    "            \n",
    "            num_aggr_true = acc_card / K\n",
    "            \n",
    "            if num_aggr_true == 0:\n",
    "                Fairness[1,trial_idx,j] = 0\n",
    "            else:\n",
    "                P_sum = np.sum(P, axis=0)/num_aggr_true\n",
    "                Fairness[1,trial_idx,j] = np.max(P_sum) - np.min(P_sum)\n",
    "                \n",
    "                \n",
    "            ###############################\n",
    "            # 3. dynamic Partition\n",
    "            ###############################\n",
    "            if j < j_0:\n",
    "                tmp = Codebook_Partition * u\n",
    "            else:\n",
    "                tmp = Codebook_Partition_rand * 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,'] @dynamic Partition Method, there is no available codebook')\n",
    "                p_tmp = np.zeros(N)\n",
    "            else:\n",
    "                if is_print:\n",
    "                    print('[iter=',j,'] @dynamic Partition Method, Codebook selection')\n",
    "                idx_en = np.where(codebook_en == 1)\n",
    "                \n",
    "                if is_selection_applied:\n",
    "                    codebook_en_num = np.sum(codebook_en)\n",
    "                    Codebook_En = np.reshape(Codebook_Partition[idx_en,:],(codebook_en_num,N))\n",
    "                    \n",
    "                    p_tmp = UserSelection_Codebook(P_partition, Codebook_En)\n",
    "                else:\n",
    "                    idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "                    \n",
    "                    if j < j_0:\n",
    "                        p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "                    else:\n",
    "                        p_tmp = Codebook_Partition_rand[idx_sel[0],:]\n",
    "                    \n",
    "#                 idx_sel = np.random.choice(idx_en[0], 1, replace=False)\n",
    "\n",
    "#                 p_tmp = Codebook_Partition[idx_sel[0],:]\n",
    "\n",
    "            P_dynamic_partition.append(p_tmp)\n",
    "\n",
    "            # 2.1 Calculate Privacy\n",
    "            P = np.array(P_dynamic_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[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",
    "            # 2.2. Calculate Aggregation Cardinality\n",
    "            acc_card = np.sum(np.array(P_dynamic_partition),axis=0)\n",
    "            acc_card = np.sum(acc_card)\n",
    "\n",
    "            Agg_Card[2,trial_idx,j] = acc_card/(j+1)\n",
    "            \n",
    "            # 2.3. Calculate Fairness\n",
    "            P = np.array(P_dynamic_partition)\n",
    "#             P_sum = np.sum(P, axis=0)/(j+1)\n",
    "#             Fairness[1,trial_idx,j] = np.max(P_sum) - np.min(P_sum)\n",
    "            \n",
    "            num_aggr_true = acc_card / K\n",
    "            \n",
    "            if num_aggr_true == 0:\n",
    "                Fairness[2,trial_idx,j] = 0\n",
    "            else:\n",
    "                P_sum = np.sum(P, axis=0)/num_aggr_true\n",
    "                Fairness[2,trial_idx,j] = np.max(P_sum) - np.min(P_sum)\n",
    "            \n",
    "            \n",
    "\n",
    "            \n",
    "\n",
    "\n",
    "        # random selection\n",
    "\n",
    "#     print(Privacy)\n",
    "#     print()\n",
    "#     print(Agg_Card)\n",
    "\n",
    "\n",
    "mean_priavcy_N120_pdiff = np.sum(Privacy, axis=1)/N_trial\n",
    "print(np.shape(mean_priavcy_N120_pdiff))\n",
    "\n",
    "mean_Agg_Card_N120_pdiff = np.sum(Agg_Card, axis=1)/N_trial\n",
    "print(np.shape(mean_Agg_Card_N120_pdiff))\n",
    "\n",
    "mean_fairness_N120_pdiff = np.sum(Fairness, axis=1)/N_trial\n",
    "print(np.shape(mean_fairness_N120_pdiff))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "ebf96454",
   "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"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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_N120_pdiff[0,:], label='random')\n",
    "plt.plot(mean_priavcy_N120_pdiff[1,:], label='static partition')\n",
    "plt.plot(mean_priavcy_N120_pdiff[2,:], label='dynamic partition')\n",
    "\n",
    "\n",
    "# plt.plot(mean_priavcy_N120_pdiff[5,:], label='proposed, T=2')\n",
    "plt.ylabel('Privacy')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,13])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "plt.plot(mean_Agg_Card_N120_pdiff[0,:], label='random')\n",
    "plt.plot(mean_Agg_Card_N120_pdiff[1,:], label='static partition')\n",
    "plt.plot(mean_Agg_Card_N120_pdiff[2,:], label='dynamic partition')\n",
    "\n",
    "# plt.plot(mean_Agg_Card_N120_pdiff[5,:], label='proposed, T=2')\n",
    "plt.ylabel('Aggregation Cardinality')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([0,13])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "plt.plot(mean_fairness_N120_pdiff[0,:], label='random')\n",
    "plt.plot(mean_fairness_N120_pdiff[1,:], label='static partition')\n",
    "plt.plot(mean_fairness_N120_pdiff[2,:], label='dynamic partition')\n",
    "\n",
    "\n",
    "# plt.plot(mean_fairness_N120_pdiff[5,:], label='proposed, T=2')\n",
    "plt.ylabel('Fairness')\n",
    "plt.xlabel('# Rounds')\n",
    "plt.ylim([-0.1,1.1])\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "fb441219",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4.\n",
      "  4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4. 4.\n",
      "  4. 4. 4. 4.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6. 6.\n",
      "  6. 6. 6. 6.]]\n"
     ]
    }
   ],
   "source": [
    "print(Privacy[2,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "ac57a1c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(200, 120)\n",
      "[14.  8.  8.  9.  9.  9.  7. 11.  9. 10.  7. 14.  7. 15. 11. 14.  4. 11.\n",
      " 10. 10. 10.  9.  9. 10. 10.  9.  9. 11. 15.  4. 14. 15.  8.  9. 14. 10.\n",
      " 14.  9. 10. 11.  7. 10. 15.  4. 11.  4.  9.  4.  4.  7.  9. 15.  8. 10.\n",
      "  7.  9. 14.  9.  9.  7.  9.  9. 11.  7. 10. 10.  4.  9. 15.  9.  4. 15.\n",
      "  8. 10. 11.  4. 10.  8.  8. 14.  4.  4.  9.  7.  7. 15.  8. 10. 15. 15.\n",
      " 14. 10.  9.  7. 15. 11.  7.  8. 10. 10. 14. 10. 14. 10. 11. 10.  8. 10.\n",
      " 15. 10.  9.  8. 11.  8.  9.  4. 10.  9. 14. 11.]\n",
      "[array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,\n",
      "       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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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,\n",
      "       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, 0, 0, 0, 0, 0, 0]), array([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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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,\n",
      "       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, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0])]\n",
      "[array([0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,\n",
      "       1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,\n",
      "       0, 0, 1, 0, 0, 0, 0, 0, 0, 1]), array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0,\n",
      "       0, 0, 0, 0, 0, 0, 0, 0, 1, 0])]\n"
     ]
    }
   ],
   "source": [
    "print(np.shape(P_dynamic_partition))\n",
    "\n",
    "print(np.sum(P_dynamic_partition[100:200],axis=0))\n",
    "\n",
    "print(P_dynamic_partition[0:2])\n",
    "print(P_dynamic_partition[100:102])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "67595e84",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1. 0. 0. ... 0. 1. 0.]\n",
      " [0. 1. 1. ... 0. 0. 0.]\n",
      " [0. 0. 0. ... 0. 0. 0.]\n",
      " ...\n",
      " [0. 0. 0. ... 0. 0. 0.]\n",
      " [0. 0. 0. ... 0. 0. 0.]\n",
      " [0. 0. 0. ... 0. 0. 0.]]\n",
      "[22 18 16 58 12 20 52 22 22 12 12 12 12 12 12 12 12 12 12  0  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\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\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\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\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\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\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\n",
      "  0  0  0  0  0  0  0  0]\n"
     ]
    }
   ],
   "source": [
    "P = np.array(P_dynamic_partition)\n",
    "P_rref = rref(P)\n",
    "\n",
    "print(P_rref)\n",
    "\n",
    "P_num = np.count_nonzero(np.array(P_rref),axis = 1)\n",
    "\n",
    "print(P_num)\n",
    "zero_index = np.where(P_num == 0)\n",
    "P_num[zero_index] = N+1\n",
    "\n",
    "partial_sum = np.min(P_num)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa7f98c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "kernel_env_py38",
   "language": "python",
   "name": "env_py38"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
