{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "bfd93911-65d2-4e54-8cde-91e96d9e4327",
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import combinations\n",
    "import copy\n",
    "from functools import reduce\n",
    "import numpy as np\n",
    "\n",
    "def countSetBits(n):\n",
    "    count = 0\n",
    "    while (n):\n",
    "        n &= int(n-1) \n",
    "        count+= 1\n",
    "    return count\n",
    "\n",
    "def subsets(arr,status,curr = 0):\n",
    "    global s\n",
    "    if(curr>=len(arr)):\n",
    "        s.append(np.sum(arr*status))\n",
    "        return\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 1\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 0\n",
    "\n",
    "def get_binary(num, digits=15):\n",
    "    bin = [0]*digits\n",
    "    start = digits-1\n",
    "    while(num>0):\n",
    "        bin[start] = num%2\n",
    "        num = num//2\n",
    "        start-=1\n",
    "    return bin\n",
    "\n",
    "def find_stats(super_set, best_len, best_ss_ind):\n",
    "    #if(best_len == -1):\n",
    "    #    return None, None, None\n",
    "    overlap = reduce(lambda x, y: int(x) & int(y), best_ss_ind)\n",
    "    overlap_len = countSetBits(overlap)\n",
    "    extra_len = 0\n",
    "    for i in range(len(best_ss_ind)):\n",
    "        extra_len+=countSetBits(int(overlap) ^ int(best_ss_ind[i]))\n",
    "    final = reduce(lambda x, y: int(x) | int(y), best_ss_ind)\n",
    "    final_len = countSetBits(final)\n",
    "    ind_lens = [countSetBits(int(best_ss_ind[i])) for i in range(len(best_ss_ind))]\n",
    "    return best_len, overlap_len, extra_len, final_len, ind_lens\n",
    "\n",
    "def print_stats(super_set, best_len, best_ss_ind):\n",
    "    if(best_len==-1):\n",
    "        return\n",
    "    print(f'{\"Best overall subset is: \"+str(super_set) : <45}{str(get_binary(super_set)) : >25}')\n",
    "    for i in range(len(best_ss_ind)):\n",
    "        print(f'{\"Subset \"+str(i+1)+\": \"+str(best_ss_ind[i])+\" Length: \"+str(countSetBits(best_ss_ind[i])) : <45}{str(get_binary(best_ss_ind[i])) : >25}')\n",
    "    overlap = reduce(lambda x, y: x & y, best_ss_ind)\n",
    "    print(f'{\"Overlap Subset: \"+str(overlap) : <45}{str(get_binary(overlap)) : >25}')\n",
    "    print(f'{\"Overall subset length: \" : <25}{str(countSetBits(super_set)) : >10}')\n",
    "    print(f'{\"Overlap length: \" : <25}{str(countSetBits(overlap)) : >10}')\n",
    "    extra_len = 0\n",
    "    for i in range(len(best_ss_ind)):\n",
    "        extra_len+=countSetBits(overlap ^ best_ss_ind[i])\n",
    "    print(f'{\"Extra length: \" : <25}{str(extra_len) : >10}')\n",
    "    print(f'{\"BEST LENGTH IS: \" : <25}{str(best_len) : >10}')\n",
    "    print(\"-\"*100)\n",
    "    \n",
    "\n",
    "def subset_fixed_size(target, numbers, eps, subsize, errBest):\n",
    "    n = len(numbers)\n",
    "    cand = 0\n",
    "    indBest = np.array([np.NAN])\n",
    "    for ind in combinations(range(n),subsize):\n",
    "        inda = np.array(ind,dtype=\"int\")\n",
    "        napprox = np.sum(numbers[inda])\n",
    "        diff = np.abs(target-napprox)\n",
    "        if diff < errBest:\n",
    "            errBest = diff\n",
    "            cand = napprox\n",
    "            indBest = inda\n",
    "        if diff <= eps:\n",
    "            break\n",
    "    return cand, indBest, errBest\n",
    "\n",
    "def exhaustive(target, numbers, eps, nmax):\n",
    "    n = len(numbers)\n",
    "    err = np.abs(target)\n",
    "    errBest = err\n",
    "    cand = 0\n",
    "    indBest = np.array([-1])\n",
    "    nmax = min(nmax, n)\n",
    "    for k in range(nmax):\n",
    "        cank, indk, errk = subset_fixed_size(target, numbers, eps, k, errBest)\n",
    "        if errk < errBest:\n",
    "            errBest = errk\n",
    "            cand = cank\n",
    "            indBest = indk\n",
    "        if errBest <= eps:\n",
    "            break\n",
    "    return cand, indBest\n",
    "\n",
    "def find_best_subset_size(status, targets, experts, epsilon):\n",
    "    final_set = status[0].reshape(-1,1)\n",
    "    for i in range(1,experts):\n",
    "        final_set = np.bitwise_or(final_set, status[i].reshape(1,-1))\n",
    "        #print(final_set)\n",
    "        final_set = np.unique(final_set.reshape(-1)).reshape(-1,1)\n",
    "    # print(final_set)\n",
    "    final_set = final_set.reshape(-1)\n",
    "    best = 100000\n",
    "    best_id = -1\n",
    "    for i in range(len(final_set)):\n",
    "        b = countSetBits(final_set[i])\n",
    "        if(b<best):\n",
    "            best = b\n",
    "            best_id = final_set[i]\n",
    "    #print(\"Best combo is: \"+str(best_id))\n",
    "    #print(\"Binary string: \"+str(get_binary(best_id)))\n",
    "    #print()\n",
    "    #print(\"Best is: \"+str(best))\n",
    "    if(not (best <= 100)):\n",
    "        print(\"Weird1: \"+str(best))\n",
    "        best = -1\n",
    "    # count[best]+=1\n",
    "    if(best==-1):\n",
    "        return None, -1, None, None    \n",
    "    tot_len = 0\n",
    "    for i in range(experts):\n",
    "        status[i] = np.reshape(status[i], (-1))\n",
    "    candidates = []\n",
    "    for i in range(experts):\n",
    "        cand_id = np.argwhere((np.bitwise_and(status[i],best_id)-status[i])==0)\n",
    "        #print(cand_id)\n",
    "        combos = [status[i][id] for id in cand_id]\n",
    "        candidates.append(combos)\n",
    "        # for combo in combos:\n",
    "        #     # print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "        #     assert((np.sum(get_binary(combo[0])*rand_vars) - targets[i])<=epsilon)\n",
    "        cand_len = min([countSetBits(status[i][id]) for id in cand_id])\n",
    "        tot_len+=cand_len\n",
    "    candidates = [i[0][0] for i in candidates]\n",
    "    return best_id, best, candidates, tot_len\n",
    "\n",
    "def find_best_overall_size(status, targets, experts, epsilon):\n",
    "    #final_set = status[0].reshape(-1,1)\n",
    "    overlaps = status[0].reshape(-1,1)\n",
    "    for i in range(1,experts):\n",
    "        #final_set = np.bitwise_or(final_set, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        overlaps = np.bitwise_and(overlaps, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        #combined = np.unique(np.concatenate((final_set,overlaps), axis=1), axis=0)\n",
    "        #print(combined.shape)\n",
    "        #final_set = combined[:,0].reshape(-1,1)\n",
    "        #overlaps = combined[:,1].reshape(-1,1)\n",
    "        #print(i)\n",
    "        overlaps = np.unique(overlaps.reshape(-1)).reshape(-1,1)\n",
    "    overlaps = overlaps.reshape(-1,1)\n",
    "    # print(overlaps.shape)\n",
    "    cand = []\n",
    "    for i in range(experts):\n",
    "        o_s_map = (np.bitwise_and(overlaps, status[i].reshape(1,-1))==overlaps)\n",
    "        # print(o_s_map.sum(axis=1))\n",
    "        cand.append([status[i][np.where(o_s_map[j]==True)] for j in range(len(overlaps))])\n",
    "    best_len = 1000000\n",
    "    best_ss = -1\n",
    "    best_ss_ind = None\n",
    "    best_ss_id = -1\n",
    "    for ov_id in range(len(overlaps)):\n",
    "        ov_len = countSetBits(overlaps[ov_id][0])\n",
    "        extra_len = 0\n",
    "        min_vals = []\n",
    "        for i in range(experts):\n",
    "            l = []\n",
    "            for j in range(len(cand[i][ov_id])):\n",
    "                l.append(countSetBits(cand[i][ov_id][j] ^ overlaps[ov_id][0]))\n",
    "                # print(\"Candidate: \"+str(cand[i][ov_id][j])+\" Binary: \"+str(get_binary(cand[i][ov_id][j])))\n",
    "            cand_min_id = np.argmin(l)\n",
    "            #print(l)\n",
    "            extra_len+=l[cand_min_id]\n",
    "            min_vals.append(cand[i][ov_id][cand_min_id])\n",
    "        if(ov_len+extra_len<best_len):\n",
    "            best_ss = overlaps[ov_id][0]\n",
    "            best_ss_id = ov_id\n",
    "            best_ss_ind = copy.deepcopy(min_vals)\n",
    "            # print(\"Overlap: \"+str(overlaps[ov_id][0])+\" Binary: \"+str(get_binary(overlaps[ov_id][0])))\n",
    "            # print(\"Overlap length: \"+str(ov_len))\n",
    "            # print(\"Extra length: \"+str(extra_len))\n",
    "            # for i in range(experts):\n",
    "            #     print(\"Candidate: \"+str(min_vals[i])+\" Binary: \"+str(get_binary(min_vals[i])))\n",
    "            best_len = ov_len+extra_len\n",
    "            #print()\n",
    "    if(not (best_len <= 100)):\n",
    "        print(\"Weird2: \"+str(best_len))\n",
    "        best_len = -1\n",
    "    if(best_len==-1):\n",
    "        return None, -1, None, None\n",
    "    for i in range(experts):\n",
    "        assert(best_ss_ind[i] in status[i])\n",
    "    assert(overlaps[best_ss_id][0] == reduce(lambda x, y: int(x) & int(y), best_ss_ind))\n",
    "    super_set = reduce(lambda x, y: int(x) | int(y), best_ss_ind)\n",
    "    return super_set, best_len, best_ss_ind, best_ss\n",
    "\n",
    "def find_best_overlap_size(status, targets, experts, epsilon):\n",
    "    #final_set = status[0].reshape(-1,1)\n",
    "    overlaps = status[0].reshape(-1,1)\n",
    "    for i in range(1,experts):\n",
    "        #final_set = np.bitwise_or(final_set, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        overlaps = np.bitwise_and(overlaps, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        #combined = np.unique(np.concatenate((final_set,overlaps), axis=1), axis=0)\n",
    "        #print(combined.shape)\n",
    "        #final_set = combined[:,0].reshape(-1,1)\n",
    "        #overlaps = combined[:,1].reshape(-1,1)\n",
    "        #print(i)\n",
    "        overlaps = np.unique(overlaps.reshape(-1)).reshape(-1,1)\n",
    "    overlaps = overlaps.reshape(-1,1)\n",
    "    # print(overlaps.shape)\n",
    "    cand = []\n",
    "    for i in range(experts):\n",
    "        o_s_map = (np.bitwise_and(overlaps, status[i].reshape(1,-1))==overlaps)\n",
    "        # print(o_s_map.sum(axis=1))\n",
    "        cand.append([status[i][np.where(o_s_map[j]==True)] for j in range(len(overlaps))])\n",
    "    best_len = 1000000\n",
    "    best_ss = -1\n",
    "    best_ss_ind = None\n",
    "    best_ss_id = -1\n",
    "    for ov_id in range(len(overlaps)):\n",
    "        ov_len = countSetBits(overlaps[ov_id][0])\n",
    "        extra_len = 0\n",
    "        min_vals = []\n",
    "        for i in range(experts):\n",
    "            l = []\n",
    "            for j in range(len(cand[i][ov_id])):\n",
    "                l.append(countSetBits(cand[i][ov_id][j] ^ overlaps[ov_id][0]))\n",
    "                # print(\"Candidate: \"+str(cand[i][ov_id][j])+\" Binary: \"+str(get_binary(cand[i][ov_id][j])))\n",
    "            cand_min_id = np.argmin(l)\n",
    "            #print(l)\n",
    "            extra_len+=l[cand_min_id]\n",
    "            min_vals.append(cand[i][ov_id][cand_min_id])\n",
    "        if(extra_len-ov_len<best_len):\n",
    "            best_ss = overlaps[ov_id][0]\n",
    "            best_ss_id = ov_id\n",
    "            best_ss_ind = copy.deepcopy(min_vals)\n",
    "            # print(\"Overlap: \"+str(overlaps[ov_id][0])+\" Binary: \"+str(get_binary(overlaps[ov_id][0])))\n",
    "            # print(\"Overlap length: \"+str(ov_len))\n",
    "            # print(\"Extra length: \"+str(extra_len))\n",
    "            # for i in range(experts):\n",
    "            #     print(\"Candidate: \"+str(min_vals[i])+\" Binary: \"+str(get_binary(min_vals[i])))\n",
    "            best_len = extra_len-ov_len\n",
    "            #print()\n",
    "    # if(not (best_len <= 100)):\n",
    "    #     print(\"Weird3: \"+str(best_len))\n",
    "    #     best_len = -1\n",
    "    # if(best_len==-1):\n",
    "    #     return None, -1, None, None\n",
    "    for i in range(experts):\n",
    "        assert(best_ss_ind[i] in status[i])\n",
    "    assert(overlaps[best_ss_id][0] == reduce(lambda x, y: int(x) & int(y), best_ss_ind))\n",
    "    super_set = reduce(lambda x, y: int(x) | int(y), best_ss_ind)\n",
    "    return super_set, best_len, best_ss_ind, best_ss\n",
    "\n",
    "def find_best_extra_size(status, targets, experts, epsilon):\n",
    "    #final_set = status[0].reshape(-1,1)\n",
    "    overlaps = status[0].reshape(-1,1)\n",
    "    for i in range(1,experts):\n",
    "        #final_set = np.bitwise_or(final_set, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        overlaps = np.bitwise_and(overlaps, status[i].reshape(1,-1)).reshape(-1,1)\n",
    "        #combined = np.unique(np.concatenate((final_set,overlaps), axis=1), axis=0)\n",
    "        #print(combined.shape)\n",
    "        #final_set = combined[:,0].reshape(-1,1)\n",
    "        #overlaps = combined[:,1].reshape(-1,1)\n",
    "        #print(i)\n",
    "        overlaps = np.unique(overlaps.reshape(-1)).reshape(-1,1)\n",
    "    overlaps = overlaps.reshape(-1,1)\n",
    "    # print(overlaps.shape)\n",
    "    cand = []\n",
    "    for i in range(experts):\n",
    "        o_s_map = (np.bitwise_and(overlaps, status[i].reshape(1,-1))==overlaps)\n",
    "        # print(o_s_map.sum(axis=1))\n",
    "        cand.append([status[i][np.where(o_s_map[j]==True)] for j in range(len(overlaps))])\n",
    "    best_len = 1000000\n",
    "    best_ss = -1\n",
    "    best_ss_ind = None\n",
    "    best_ss_id = -1\n",
    "    for ov_id in range(len(overlaps)):\n",
    "        ov_len = countSetBits(overlaps[ov_id][0])\n",
    "        extra_len = 0\n",
    "        min_vals = []\n",
    "        for i in range(experts):\n",
    "            l = []\n",
    "            for j in range(len(cand[i][ov_id])):\n",
    "                l.append(countSetBits(cand[i][ov_id][j] ^ overlaps[ov_id][0]))\n",
    "                # print(\"Candidate: \"+str(cand[i][ov_id][j])+\" Binary: \"+str(get_binary(cand[i][ov_id][j])))\n",
    "            cand_min_id = np.argmin(l)\n",
    "            #print(l)\n",
    "            extra_len+=l[cand_min_id]\n",
    "            min_vals.append(cand[i][ov_id][cand_min_id])\n",
    "        if(extra_len<best_len):\n",
    "            best_ss = overlaps[ov_id][0]\n",
    "            best_ss_id = ov_id\n",
    "            best_ss_ind = copy.deepcopy(min_vals)\n",
    "            # print(\"Overlap: \"+str(overlaps[ov_id][0])+\" Binary: \"+str(get_binary(overlaps[ov_id][0])))\n",
    "            # print(\"Overlap length: \"+str(ov_len))\n",
    "            # print(\"Extra length: \"+str(extra_len))\n",
    "            # for i in range(experts):\n",
    "            #     print(\"Candidate: \"+str(min_vals[i])+\" Binary: \"+str(get_binary(min_vals[i])))\n",
    "            best_len = extra_len\n",
    "            #print()\n",
    "    if(not (best_len <= 100)):\n",
    "        print(\"Weird: \"+str(best_len))\n",
    "        best_len = -1\n",
    "    if(best_len==-1):\n",
    "        return None, -1, None, None\n",
    "    ############## Verification #################\n",
    "    for i in range(experts):\n",
    "        assert(best_ss_ind[i] in status[i])\n",
    "    assert(overlaps[best_ss_id][0] == reduce(lambda x, y: int(x) & int(y), best_ss_ind))\n",
    "    super_set = reduce(lambda x, y: x | y, best_ss_ind)\n",
    "    return super_set, best_len, best_ss_ind, best_ss\n",
    "\n",
    "def find_sparsest(status, targets, experts, epsilon):\n",
    "    subsets = np.zeros(experts)\n",
    "    for i in range(experts):\n",
    "        best = 100000000\n",
    "        for j in range(len(status[i])):\n",
    "            l = countSetBits(status[i][j])\n",
    "            if(l<best):\n",
    "                best = l\n",
    "                subsets[i] = status[i][j]\n",
    "    overlap = int(subsets[0])\n",
    "    final = int(subsets[0])\n",
    "    for i in range(1,experts):\n",
    "        overlap = overlap & int(subsets[i])\n",
    "        final = final | int(subsets[i])\n",
    "    extra_len = 0\n",
    "    for i in range(experts):\n",
    "        extra_len += countSetBits(overlap ^ int(subsets[i]))\n",
    "    overlap_len = countSetBits(overlap)\n",
    "    best_len = overlap_len + extra_len\n",
    "    return final, best_len, list(subsets), overlap\n",
    "\n",
    "def find_representational_bins(status, targets, experts, epsilon):\n",
    "    targets = (np.floor(targets/(2*epsilon))*2 + 1)*epsilon\n",
    "    return find_sparsest(status, targets, experts, epsilon)\n",
    "\n",
    "def verify(c, rand_vars, targets, epsilon):\n",
    "    for i in range(len(c)):\n",
    "        assert((np.sum(get_binary(c[i], len(rand_vars))*rand_vars) - targets[i])<=epsilon)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "4a996daa-aace-4e9f-8e5a-2e87e9e67e1c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0.6\n",
      "60\n",
      "16.7\n",
      "60\n",
      "0.9333333333333333\n",
      "60\n",
      "15.533333333333333\n",
      "60\n",
      "1.0666666666666667\n",
      "60\n",
      "15.55\n",
      "60\n",
      "1.05\n",
      "60\n",
      "15.533333333333333\n",
      "60\n",
      "0.5333333333333333\n",
      "60\n",
      "16.216666666666665\n",
      "60\n",
      "0.5333333333333333\n",
      "60\n",
      "16.216666666666665\n",
      "60\n",
      "\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_7976\\2964554752.py:9: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  n &= int(n-1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.66015625\n",
      "256\n",
      "17.73046875\n",
      "256\n",
      "1.12109375\n",
      "256\n",
      "16.20703125\n",
      "256\n",
      "1.4140625\n",
      "256\n",
      "16.36328125\n",
      "256\n",
      "1.28125\n",
      "256\n",
      "16.22265625\n",
      "256\n",
      "0.4609375\n",
      "256\n",
      "17.3515625\n",
      "256\n",
      "0.4609375\n",
      "256\n",
      "17.3515625\n",
      "256\n",
      "\n",
      "0\n",
      "0.6701570680628273\n",
      "573\n",
      "18.001745200698082\n",
      "573\n",
      "1.350785340314136\n",
      "573\n",
      "15.732984293193716\n",
      "573\n",
      "2.099476439790576\n",
      "573\n",
      "16.212914485165793\n",
      "573\n",
      "1.7643979057591623\n",
      "573\n",
      "15.823734729493891\n",
      "573\n",
      "0.31413612565445026\n",
      "573\n",
      "17.289703315881326\n",
      "573\n",
      "0.31413612565445026\n",
      "573\n",
      "17.289703315881326\n",
      "573\n",
      "\n",
      "0\n",
      "0.727710843373494\n",
      "830\n",
      "17.64096385542169\n",
      "830\n",
      "1.6481927710843374\n",
      "830\n",
      "14.636144578313253\n",
      "830\n",
      "2.985542168674699\n",
      "830\n",
      "15.539759036144579\n",
      "830\n",
      "2.4373493975903613\n",
      "830\n",
      "14.872289156626506\n",
      "830\n",
      "0.2433734939759036\n",
      "830\n",
      "16.61566265060241\n",
      "830\n",
      "0.2433734939759036\n",
      "830\n",
      "16.61566265060241\n",
      "830\n",
      "\n",
      "0\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[141], line 100\u001b[0m\n\u001b[0;32m     96\u001b[0m     len_stats[\u001b[38;5;241m1\u001b[39m][\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mind_lens\u001b[39m\u001b[38;5;124m'\u001b[39m]\u001b[38;5;241m.\u001b[39mappend(\u001b[38;5;28;01mNone\u001b[39;00m)\n\u001b[0;32m     97\u001b[0m \u001b[38;5;66;03m# print_stats(a,b,c)\u001b[39;00m\n\u001b[0;32m     98\u001b[0m \n\u001b[0;32m     99\u001b[0m \u001b[38;5;66;03m# print(\"Extra optimal\")\u001b[39;00m\n\u001b[1;32m--> 100\u001b[0m a,b,c,d \u001b[38;5;241m=\u001b[39m find_best_overlap_size(status, targets, experts, epsilon)\n\u001b[0;32m    101\u001b[0m a1,b1,c1,d1,e1 \u001b[38;5;241m=\u001b[39m find_stats(a,b,c)\n\u001b[0;32m    102\u001b[0m verify(c, rand_vars[it], targets, epsilon)\n",
      "Cell \u001b[1;32mIn[89], line 207\u001b[0m, in \u001b[0;36mfind_best_overlap_size\u001b[1;34m(status, targets, experts, epsilon)\u001b[0m\n\u001b[0;32m    201\u001b[0m     overlaps \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mbitwise_and(overlaps, status[i]\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m))\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n\u001b[0;32m    202\u001b[0m     \u001b[38;5;66;03m#combined = np.unique(np.concatenate((final_set,overlaps), axis=1), axis=0)\u001b[39;00m\n\u001b[0;32m    203\u001b[0m     \u001b[38;5;66;03m#print(combined.shape)\u001b[39;00m\n\u001b[0;32m    204\u001b[0m     \u001b[38;5;66;03m#final_set = combined[:,0].reshape(-1,1)\u001b[39;00m\n\u001b[0;32m    205\u001b[0m     \u001b[38;5;66;03m#overlaps = combined[:,1].reshape(-1,1)\u001b[39;00m\n\u001b[0;32m    206\u001b[0m     \u001b[38;5;66;03m#print(i)\u001b[39;00m\n\u001b[1;32m--> 207\u001b[0m     overlaps \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39munique(overlaps\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m))\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n\u001b[0;32m    208\u001b[0m overlaps \u001b[38;5;241m=\u001b[39m overlaps\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n\u001b[0;32m    209\u001b[0m \u001b[38;5;66;03m# print(overlaps.shape)\u001b[39;00m\n",
      "File \u001b[1;32mC:\\ProgramData\\anaconda3\\Lib\\site-packages\\numpy\\lib\\arraysetops.py:274\u001b[0m, in \u001b[0;36munique\u001b[1;34m(ar, return_index, return_inverse, return_counts, axis, equal_nan)\u001b[0m\n\u001b[0;32m    272\u001b[0m ar \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39masanyarray(ar)\n\u001b[0;32m    273\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m axis \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m--> 274\u001b[0m     ret \u001b[38;5;241m=\u001b[39m _unique1d(ar, return_index, return_inverse, return_counts, \n\u001b[0;32m    275\u001b[0m                     equal_nan\u001b[38;5;241m=\u001b[39mequal_nan)\n\u001b[0;32m    276\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _unpack_tuple(ret)\n\u001b[0;32m    278\u001b[0m \u001b[38;5;66;03m# axis was specified and not None\u001b[39;00m\n",
      "File \u001b[1;32mC:\\ProgramData\\anaconda3\\Lib\\site-packages\\numpy\\lib\\arraysetops.py:336\u001b[0m, in \u001b[0;36m_unique1d\u001b[1;34m(ar, return_index, return_inverse, return_counts, equal_nan)\u001b[0m\n\u001b[0;32m    334\u001b[0m     aux \u001b[38;5;241m=\u001b[39m ar[perm]\n\u001b[0;32m    335\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m--> 336\u001b[0m     ar\u001b[38;5;241m.\u001b[39msort()\n\u001b[0;32m    337\u001b[0m     aux \u001b[38;5;241m=\u001b[39m ar\n\u001b[0;32m    338\u001b[0m mask \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mempty(aux\u001b[38;5;241m.\u001b[39mshape, dtype\u001b[38;5;241m=\u001b[39mnp\u001b[38;5;241m.\u001b[39mbool_)\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def subsets(arr,status,curr = 0):\n",
    "    global s_g\n",
    "    if(curr>=arr.shape[1]):\n",
    "        s_g.append(np.sum(arr*status, axis=1))\n",
    "        return\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 1\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 0\n",
    "\n",
    "experts = 4\n",
    "\n",
    "epsilon = 0.01\n",
    "iterations = 1000\n",
    "\n",
    "final_stats = {}\n",
    "for set_size in range(10,16):\n",
    "    len_stats = {}\n",
    "    len_stats['mean'] = []\n",
    "    len_stats['diff'] = []\n",
    "    for i in range(6):\n",
    "        len_stats[i] = {}\n",
    "        len_stats[i]['best'] = []\n",
    "        len_stats[i]['overlap'] = []\n",
    "        len_stats[i]['extra'] = []\n",
    "        len_stats[i]['total'] = []\n",
    "        len_stats[i]['overall'] = []\n",
    "        len_stats[i]['ind_lens'] = []\n",
    "    rand_vars = np.random.uniform(-1,1,(iterations, set_size))\n",
    "    s_g = []\n",
    "    subsets(rand_vars, np.zeros_like(rand_vars[1]))\n",
    "    s_g = np.array(s_g).T\n",
    "    for it in range(iterations):\n",
    "        targets = np.random.uniform(-1/2,1/2,experts)\n",
    "        # targets = np.random.normal(0,1,experts)\n",
    "        \n",
    "        if(it%1000==0):\n",
    "           print(it)\n",
    "        # rand_vars = np.random.normal(0,1,set_size)\n",
    "\n",
    "    \n",
    "        s = np.array(s_g[it]).reshape(-1)\n",
    "        status = []\n",
    "        for i in range(experts):\n",
    "            status.append(np.argwhere(np.abs(s-targets[i])<epsilon))\n",
    "        # print(\"Smallest superset\")\n",
    "        flag = False\n",
    "        for i in range(experts):\n",
    "            if(len(status[i])==0):\n",
    "                flag = True\n",
    "        if flag:\n",
    "            continue\n",
    "        len_stats['mean'].append(np.mean(targets))\n",
    "        len_stats['diff'].append(abs(targets[1]-targets[0]))\n",
    "        \n",
    "        a,b,c,d = find_best_subset_size(status, targets, experts, epsilon)\n",
    "        # print(c)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[0]['best'].append(a1)\n",
    "            len_stats[0]['overlap'].append(b1)\n",
    "            len_stats[0]['extra'].append(c1)\n",
    "            len_stats[0]['total'].append(b1+c1)\n",
    "            len_stats[0]['overall'].append(d1)\n",
    "            len_stats[0]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[0]['best'].append(None)\n",
    "            len_stats[0]['overlap'].append(None)\n",
    "            len_stats[0]['extra'].append(None)\n",
    "            len_stats[0]['total'].append(None)\n",
    "            len_stats[0]['overall'].append(None)\n",
    "            len_stats[0]['ind_lens'].append(None)\n",
    "        # print(c)\n",
    "        # print_stats(a,b,c)\n",
    "        \n",
    "        # print(\"Overall optimal\")\n",
    "        a,b,c,d = find_best_overall_size(status, targets, experts, epsilon)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[1]['best'].append(a1)\n",
    "            len_stats[1]['overlap'].append(b1)\n",
    "            len_stats[1]['extra'].append(c1)\n",
    "            len_stats[1]['total'].append(b1+c1)\n",
    "            len_stats[1]['overall'].append(d1)\n",
    "            len_stats[1]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[1]['best'].append(None)\n",
    "            len_stats[1]['overlap'].append(None)\n",
    "            len_stats[1]['extra'].append(None)\n",
    "            len_stats[1]['total'].append(None)\n",
    "            len_stats[1]['overall'].append(None)\n",
    "            len_stats[1]['ind_lens'].append(None)\n",
    "        # print_stats(a,b,c)\n",
    "        \n",
    "        # print(\"Extra optimal\")\n",
    "        a,b,c,d = find_best_overlap_size(status, targets, experts, epsilon)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[2]['best'].append(a1)\n",
    "            len_stats[2]['overlap'].append(b1)\n",
    "            len_stats[2]['extra'].append(c1)\n",
    "            len_stats[2]['total'].append(b1+c1)\n",
    "            len_stats[2]['overall'].append(d1)\n",
    "            len_stats[2]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[2]['best'].append(None)\n",
    "            len_stats[2]['overlap'].append(None)\n",
    "            len_stats[2]['extra'].append(None)\n",
    "            len_stats[2]['total'].append(None)\n",
    "            len_stats[2]['overall'].append(None)\n",
    "            len_stats[2]['ind_lens'].append(None)\n",
    "\n",
    "        a,b,c,d = find_best_extra_size(status, targets, experts, epsilon)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[3]['best'].append(a1)\n",
    "            len_stats[3]['overlap'].append(b1)\n",
    "            len_stats[3]['extra'].append(c1)\n",
    "            len_stats[3]['total'].append(b1+c1)\n",
    "            len_stats[3]['overall'].append(d1)\n",
    "            len_stats[3]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[3]['best'].append(None)\n",
    "            len_stats[3]['overlap'].append(None)\n",
    "            len_stats[3]['extra'].append(None)\n",
    "            len_stats[3]['total'].append(None)\n",
    "            len_stats[3]['overall'].append(None)\n",
    "            len_stats[3]['ind_lens'].append(None)\n",
    "\n",
    "        a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[4]['best'].append(a1)\n",
    "            len_stats[4]['overlap'].append(b1)\n",
    "            len_stats[4]['extra'].append(c1)\n",
    "            len_stats[4]['total'].append(b1+c1)\n",
    "            len_stats[4]['overall'].append(d1)\n",
    "            len_stats[4]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[4]['best'].append(None)\n",
    "            len_stats[4]['overlap'].append(None)\n",
    "            len_stats[4]['extra'].append(None)\n",
    "            len_stats[4]['total'].append(None)\n",
    "            len_stats[4]['overall'].append(None)\n",
    "            len_stats[4]['ind_lens'].append(None)\n",
    "\n",
    "        a,b,c,d = find_representational_bins(status, targets, experts, epsilon)\n",
    "        a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "        verify(c, rand_vars[it], targets, epsilon)\n",
    "        if(a1 is not None):\n",
    "            len_stats[5]['best'].append(a1)\n",
    "            len_stats[5]['overlap'].append(b1)\n",
    "            len_stats[5]['extra'].append(c1)\n",
    "            len_stats[5]['total'].append(b1+c1)\n",
    "            len_stats[5]['overall'].append(d1)\n",
    "            len_stats[5]['ind_lens'].append(copy.deepcopy(e1))\n",
    "        else:\n",
    "            len_stats[5]['best'].append(None)\n",
    "            len_stats[5]['overlap'].append(None)\n",
    "            len_stats[5]['extra'].append(None)\n",
    "            len_stats[5]['total'].append(None)\n",
    "            len_stats[5]['overall'].append(None)\n",
    "            len_stats[5]['ind_lens'].append(None)\n",
    "\n",
    "        \n",
    "        # print_stats(a,b,c)\n",
    "        # print()\n",
    "        # print(\"#\"*100)\n",
    "        \n",
    "    final_stats[set_size] = len_stats\n",
    "    # print(len_stats)\n",
    "    print(np.mean(len_stats[0]['overlap']))\n",
    "    print(len(len_stats[0]['overlap']))\n",
    "    print(np.mean(len_stats[0]['total']))\n",
    "    print(len(len_stats[0]['total']))\n",
    "    print(np.mean(len_stats[1]['overlap']))\n",
    "    print(len(len_stats[1]['overlap']))\n",
    "    print(np.mean(len_stats[1]['total']))\n",
    "    print(len(len_stats[1]['total']))\n",
    "    print(np.mean(len_stats[2]['overlap']))\n",
    "    print(len(len_stats[2]['overlap']))\n",
    "    print(np.mean(len_stats[2]['total']))\n",
    "    print(len(len_stats[2]['total']))\n",
    "    print(np.mean(len_stats[3]['overlap']))\n",
    "    print(len(len_stats[3]['overlap']))\n",
    "    print(np.mean(len_stats[3]['total']))\n",
    "    print(len(len_stats[3]['total']))\n",
    "    print(np.mean(len_stats[4]['overlap']))\n",
    "    print(len(len_stats[4]['overlap']))\n",
    "    print(np.mean(len_stats[4]['total']))\n",
    "    print(len(len_stats[4]['total']))\n",
    "    print(np.mean(len_stats[5]['overlap']))\n",
    "    print(len(len_stats[5]['overlap']))\n",
    "    print(np.mean(len_stats[5]['total']))\n",
    "    print(len(len_stats[5]['total']))\n",
    "    \n",
    "    torch.save(final_stats, \"dummy.pth\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "6e42ca88-7582-42a5-9c5c-ab53476469aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_7976\\3468170144.py:9: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  n &= int(n-1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def subsets(arr,status,curr = 0):\n",
    "    global s_g\n",
    "    if(curr>=arr.shape[1]):\n",
    "        s_g.append(np.sum(arr*status, axis=1))\n",
    "        return\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 1\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 0\n",
    "\n",
    "experts = 2\n",
    "\n",
    "epsilon = 0.001\n",
    "iterations = 10000\n",
    "interval = 1000\n",
    "final_stats = {}\n",
    "for set_size in range(10,18):\n",
    "    len_stats = {}\n",
    "    len_stats['mean'] = []\n",
    "    len_stats['diff'] = []\n",
    "    len_stats['source'] = []\n",
    "    len_stats['target'] = []\n",
    "    for i in range(6):\n",
    "        len_stats[i] = {}\n",
    "        len_stats[i]['best'] = []\n",
    "        len_stats[i]['overlap'] = []\n",
    "        len_stats[i]['extra'] = []\n",
    "        len_stats[i]['total'] = []\n",
    "        len_stats[i]['overall'] = []\n",
    "        len_stats[i]['ind_lens'] = []\n",
    "        len_stats[i]['cand'] = []\n",
    "    for inter in range(int(iterations/interval)):\n",
    "        rand_vars = np.random.uniform(-1,1,(interval, set_size))\n",
    "        s_g = []\n",
    "        subsets(rand_vars, np.zeros_like(rand_vars[1]))\n",
    "        s_accumulated = np.array(s_g).T\n",
    "        \n",
    "        #rand_vars = []\n",
    "        #for i in range(experts):\n",
    "        #    rand_vars.append(np.random.uniform(-1,1,(interval, set_size)))\n",
    "        #s_accumulated = []\n",
    "        #for i in range(experts):\n",
    "        #    s_g = []\n",
    "        #    subsets(rand_vars[i], np.zeros_like(rand_vars[0][1]))\n",
    "        #    s_accumulated.append(np.array(s_g).T)\n",
    "        for it in range(interval):\n",
    "            targets = np.random.uniform(-1/2,1/2,experts)\n",
    "            # targets = np.random.normal(0,1,experts)\n",
    "            \n",
    "            if((interval*inter + it)%1000==0):\n",
    "              print((interval*inter + it))\n",
    "            # rand_vars = np.random.normal(0,1,set_size)\n",
    "\n",
    "            status = []\n",
    "            for i in range(experts):\n",
    "                s = np.array(s_accumulated[it]).reshape(-1)\n",
    "                status.append(np.argwhere(np.abs(s-targets[i])<epsilon).reshape(-1))\n",
    "            # print(\"Smallest superset\")\n",
    "            flag = False\n",
    "            for i in range(experts):\n",
    "                if(len(status[i])==0):\n",
    "                    flag = True\n",
    "            if flag:\n",
    "                continue\n",
    "            len_stats['mean'].append(np.mean(targets))\n",
    "            len_stats['diff'].append(abs(targets[1]-targets[0]))\n",
    "            len_stats['target'].append(targets)\n",
    "            len_stats['source'].append(rand_vars[it])\n",
    "            a,b,c,d = find_best_subset_size(status, targets, experts, epsilon)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[0]['best'].append(a1)\n",
    "                len_stats[0]['overlap'].append(b1)\n",
    "                len_stats[0]['extra'].append(c1)\n",
    "                len_stats[0]['total'].append(b1+c1)\n",
    "                len_stats[0]['overall'].append(d1)\n",
    "                len_stats[0]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[0]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[0]['best'].append(None)\n",
    "                len_stats[0]['overlap'].append(None)\n",
    "                len_stats[0]['extra'].append(None)\n",
    "                len_stats[0]['total'].append(None)\n",
    "                len_stats[0]['overall'].append(None)\n",
    "                len_stats[0]['ind_lens'].append(None)\n",
    "                len_stats[0]['cand'].append(None)\n",
    "            # print(c)\n",
    "            # print_stats(a,b,c)\n",
    "            \n",
    "            # print(\"Overall optimal\")\n",
    "            a,b,c,d = find_best_overall_size(status, targets, experts, epsilon)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[1]['best'].append(a1)\n",
    "                len_stats[1]['overlap'].append(b1)\n",
    "                len_stats[1]['extra'].append(c1)\n",
    "                len_stats[1]['total'].append(b1+c1)\n",
    "                len_stats[1]['overall'].append(d1)\n",
    "                len_stats[1]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[1]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[1]['best'].append(None)\n",
    "                len_stats[1]['overlap'].append(None)\n",
    "                len_stats[1]['extra'].append(None)\n",
    "                len_stats[1]['total'].append(None)\n",
    "                len_stats[1]['overall'].append(None)\n",
    "                len_stats[1]['ind_lens'].append(None)\n",
    "                len_stats[1]['cand'].append(None)\n",
    "            # print_stats(a,b,c)\n",
    "            \n",
    "            # print(\"Extra optimal\")\n",
    "            a,b,c,d = find_best_overlap_size(status, targets, experts, epsilon)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[2]['best'].append(a1)\n",
    "                len_stats[2]['overlap'].append(b1)\n",
    "                len_stats[2]['extra'].append(c1)\n",
    "                len_stats[2]['total'].append(b1+c1)\n",
    "                len_stats[2]['overall'].append(d1)\n",
    "                len_stats[2]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[2]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[2]['best'].append(None)\n",
    "                len_stats[2]['overlap'].append(None)\n",
    "                len_stats[2]['extra'].append(None)\n",
    "                len_stats[2]['total'].append(None)\n",
    "                len_stats[2]['overall'].append(None)\n",
    "                len_stats[2]['ind_lens'].append(None)\n",
    "                len_stats[2]['cand'].append(None)\n",
    "\n",
    "            a,b,c,d = find_best_extra_size(status, targets, experts, epsilon)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[3]['best'].append(a1)\n",
    "                len_stats[3]['overlap'].append(b1)\n",
    "                len_stats[3]['extra'].append(c1)\n",
    "                len_stats[3]['total'].append(b1+c1)\n",
    "                len_stats[3]['overall'].append(d1)\n",
    "                len_stats[3]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[3]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[3]['best'].append(None)\n",
    "                len_stats[3]['overlap'].append(None)\n",
    "                len_stats[3]['extra'].append(None)\n",
    "                len_stats[3]['total'].append(None)\n",
    "                len_stats[3]['overall'].append(None)\n",
    "                len_stats[3]['ind_lens'].append(None)\n",
    "                len_stats[3]['cand'].append(None)\n",
    "\n",
    "            a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "            # print(a,b,c,d)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[4]['best'].append(a1)\n",
    "                len_stats[4]['overlap'].append(b1)\n",
    "                len_stats[4]['extra'].append(c1)\n",
    "                len_stats[4]['total'].append(b1+c1)\n",
    "                len_stats[4]['overall'].append(d1)\n",
    "                len_stats[4]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[4]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[4]['best'].append(None)\n",
    "                len_stats[4]['overlap'].append(None)\n",
    "                len_stats[4]['extra'].append(None)\n",
    "                len_stats[4]['total'].append(None)\n",
    "                len_stats[4]['overall'].append(None)\n",
    "                len_stats[4]['ind_lens'].append(None)\n",
    "                len_stats[4]['cand'].append(None)\n",
    "\n",
    "            targets = (np.floor((targets-(-0.5))/(epsilon)) + 0.5)*epsilon + (-0.5)\n",
    "            status = []\n",
    "            for i in range(experts):\n",
    "                s = np.array(s_accumulated[it]).reshape(-1)\n",
    "                status.append(np.argwhere(np.abs(s-targets[i])<epsilon).reshape(-1))\n",
    "            flag = False\n",
    "            for i in range(experts):\n",
    "                if(len(status[i])==0):\n",
    "                    flag = True\n",
    "            if flag:\n",
    "                len_stats[5]['best'].append(None)\n",
    "                len_stats[5]['overlap'].append(None)\n",
    "                len_stats[5]['extra'].append(None)\n",
    "                len_stats[5]['total'].append(None)\n",
    "                len_stats[5]['overall'].append(None)\n",
    "                len_stats[5]['ind_lens'].append(None)\n",
    "                len_stats[5]['cand'].append(None)\n",
    "                continue\n",
    "            a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "            verify(c, rand_vars[it], targets, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[5]['best'].append(a1)\n",
    "                len_stats[5]['overlap'].append(b1)\n",
    "                len_stats[5]['extra'].append(c1)\n",
    "                len_stats[5]['total'].append(b1+c1)\n",
    "                len_stats[5]['overall'].append(d1)\n",
    "                len_stats[5]['ind_lens'].append(copy.deepcopy(e1))\n",
    "                len_stats[5]['cand'].append(c)\n",
    "            else:\n",
    "                len_stats[5]['best'].append(None)\n",
    "                len_stats[5]['overlap'].append(None)\n",
    "                len_stats[5]['extra'].append(None)\n",
    "                len_stats[5]['total'].append(None)\n",
    "                len_stats[5]['overall'].append(None)\n",
    "                len_stats[5]['ind_lens'].append(None)\n",
    "                len_stats[5]['cand'].append(None)\n",
    "\n",
    "        \n",
    "        # print_stats(a,b,c)\n",
    "        # print()\n",
    "        # print(\"#\"*100)\n",
    "        \n",
    "    final_stats[set_size] = len_stats\n",
    "    def remove_none(a):\n",
    "        return a[a != None]\n",
    "    # print(len_stats)\n",
    "    # print(np.mean(remove_none(len_stats[0]['overlap'])))\n",
    "    # print(len(len_stats[0]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[0]['total'])))\n",
    "    # print(len(len_stats[0]['total']))\n",
    "    # print(np.mean(remove_none(len_stats[1]['overlap'])))\n",
    "    # print(len(len_stats[1]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[1]['total'])))\n",
    "    # print(len(len_stats[1]['total']))\n",
    "    # print(np.mean(remove_none(len_stats[2]['overlap'])))\n",
    "    # print(len(len_stats[2]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[2]['total'])))\n",
    "    # print(len(len_stats[2]['total']))\n",
    "    # print(np.mean(remove_none(len_stats[3]['overlap'])))\n",
    "    # print(len(len_stats[3]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[3]['total'])))\n",
    "    # print(len(len_stats[3]['total']))\n",
    "    # print(np.mean(remove_none(len_stats[4]['overlap'])))\n",
    "    # print(len(len_stats[4]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[4]['total'])))\n",
    "    # print(len(len_stats[4]['total']))\n",
    "    # print(np.mean(remove_none(len_stats[5]['overlap'])))\n",
    "    # print(len(len_stats[5]['overlap']))\n",
    "    # print(np.mean(remove_none(len_stats[5]['total'])))\n",
    "    # print(len(len_stats[5]['total']))\n",
    "    torch.save(final_stats, \"final_stats_ssa_\"+str(experts)+\"_exp\"+str(epsilon)+\".pth\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "78a8f13f-4614-458a-81e4-4e5311e94499",
   "metadata": {},
   "outputs": [],
   "source": [
    "remove_none(len_stats[5]['overlap'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "8bf3899a-a2df-481e-8f5f-7333a966f6aa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-0.13, -0.45,  0.11, -0.29])"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# np.argwhere(np.abs(s_accumulated[it] - new_targets[0])<epsilon)\n",
    "new_targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ffa05ad7-aa50-4b5a-9f26-957b00720e37",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_9564\\1495535208.py:9: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  n &= int(n-1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.7240226858416042\n",
      "9874\n",
      "21.20599554385254\n",
      "9874\n",
      "1.289345756532307\n",
      "9874\n",
      "19.94379177638242\n",
      "9874\n",
      "5.828742151103909\n",
      "9874\n",
      "23.80372695969212\n",
      "9874\n",
      "3.552562284788333\n",
      "9874\n",
      "21.29035851731821\n",
      "9874\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.7288971041281578\n",
      "9738\n",
      "21.16153214212364\n",
      "9738\n",
      "1.3087903060176627\n",
      "9738\n",
      "19.891353460669542\n",
      "9738\n",
      "4.878722530293695\n",
      "9738\n",
      "22.818751283631137\n",
      "9738\n",
      "3.104333538714315\n",
      "9738\n",
      "20.83117683302526\n",
      "9738\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.7305325694886484\n",
      "9426\n",
      "21.055060471037557\n",
      "9426\n",
      "1.304476978569913\n",
      "9426\n",
      "19.77753023551878\n",
      "9426\n",
      "3.953851050286442\n",
      "9426\n",
      "21.79047315934649\n",
      "9426\n",
      "2.722469764481222\n",
      "9426\n",
      "20.387332908975175\n",
      "9426\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.7291454442558007\n",
      "8835\n",
      "20.96049801924165\n",
      "8835\n",
      "1.2855687606112054\n",
      "8835\n",
      "19.683644595359365\n",
      "8835\n",
      "3.050028296547821\n",
      "8835\n",
      "20.8893039049236\n",
      "8835\n",
      "2.2865874363327676\n",
      "8835\n",
      "20.010413129598188\n",
      "8835\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.7215447154471545\n",
      "7380\n",
      "20.781436314363145\n",
      "7380\n",
      "1.228590785907859\n",
      "7380\n",
      "19.51951219512195\n",
      "7380\n",
      "2.184959349593496\n",
      "7380\n",
      "20.071002710027102\n",
      "7380\n",
      "1.8101626016260162\n",
      "7380\n",
      "19.63929539295393\n",
      "7380\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.6889028739249003\n",
      "4767\n",
      "20.281099223830502\n",
      "4767\n",
      "1.0985945038808476\n",
      "4767\n",
      "19.14789175582127\n",
      "4767\n",
      "1.5170967065240193\n",
      "4767\n",
      "19.334591986574367\n",
      "4767\n",
      "1.3790644010908328\n",
      "4767\n",
      "19.181875393329136\n",
      "4767\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.6411901983663943\n",
      "1714\n",
      "19.25087514585764\n",
      "1714\n",
      "0.911318553092182\n",
      "1714\n",
      "18.378646441073514\n",
      "1714\n",
      "1.0647607934655776\n",
      "1714\n",
      "18.43757292882147\n",
      "1714\n",
      "1.017502917152859\n",
      "1714\n",
      "18.38681446907818\n",
      "1714\n",
      "\n",
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "0.625\n",
      "400\n",
      "17.67\n",
      "400\n",
      "0.79\n",
      "400\n",
      "17.155\n",
      "400\n",
      "0.845\n",
      "400\n",
      "17.18\n",
      "400\n",
      "0.8225\n",
      "400\n",
      "17.1575\n",
      "400\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def subsets(arr,status,curr = 0):\n",
    "    global s_g\n",
    "    if(curr>=arr.shape[1]):\n",
    "        s_g.append(np.sum(arr*status, axis=1))\n",
    "        return\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 1\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 0\n",
    "\n",
    "experts = 4\n",
    "\n",
    "epsilon = 0.001\n",
    "iterations = 10000\n",
    "interval = 500\n",
    "final_stats = {}\n",
    "for set_size in reversed(range(10,18)):\n",
    "    len_stats = {}\n",
    "    len_stats['mean'] = []\n",
    "    len_stats['diff'] = []\n",
    "    for i in range(6):\n",
    "        len_stats[i] = {}\n",
    "        len_stats[i]['best'] = []\n",
    "        len_stats[i]['overlap'] = []\n",
    "        len_stats[i]['extra'] = []\n",
    "        len_stats[i]['total'] = []\n",
    "        len_stats[i]['overall'] = []\n",
    "        len_stats[i]['ind_lens'] = []\n",
    "    for inter in range(int(iterations/interval)):\n",
    "        rand_vars = []\n",
    "        for i in range(experts):\n",
    "            rand_vars.append(np.random.uniform(-1,1,(interval, set_size)))\n",
    "        s_accumulated = []\n",
    "        for i in range(experts):\n",
    "            s_g = []\n",
    "            subsets(rand_vars[i], np.zeros_like(rand_vars[0][1]))\n",
    "            s_accumulated.append(np.array(s_g).T)\n",
    "        for it in range(interval):\n",
    "            targets = np.random.uniform(-1/2,1/2,experts)\n",
    "            # targets = np.random.normal(0,1,experts)\n",
    "            \n",
    "            if((interval*inter + it)%1000==0):\n",
    "              print((interval*inter + it))\n",
    "            # rand_vars = np.random.normal(0,1,set_size)\n",
    "\n",
    "            status = []\n",
    "            for i in range(experts):\n",
    "                s = np.array(s_accumulated[i][it]).reshape(-1)\n",
    "                status.append(np.argwhere(np.abs(s-targets[i])<epsilon))\n",
    "            # print(\"Smallest superset\")\n",
    "            flag = False\n",
    "            for i in range(experts):\n",
    "                if(len(status[i])==0):\n",
    "                    flag = True\n",
    "            if flag:\n",
    "                continue\n",
    "            len_stats['mean'].append(np.mean(targets))\n",
    "            len_stats['diff'].append(abs(targets[1]-targets[0]))\n",
    "            \n",
    "            a,b,c,d = find_best_subset_size(status, targets, experts, epsilon)\n",
    "            # print(c)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[0]['best'].append(a1)\n",
    "                len_stats[0]['overlap'].append(b1)\n",
    "                len_stats[0]['extra'].append(c1)\n",
    "                len_stats[0]['total'].append(b1+c1)\n",
    "                len_stats[0]['overall'].append(d1)\n",
    "                len_stats[0]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[0]['best'].append(None)\n",
    "                len_stats[0]['overlap'].append(None)\n",
    "                len_stats[0]['extra'].append(None)\n",
    "                len_stats[0]['total'].append(None)\n",
    "                len_stats[0]['overall'].append(None)\n",
    "                len_stats[0]['ind_lens'].append(None)\n",
    "            # print(c)\n",
    "            # print_stats(a,b,c)\n",
    "            \n",
    "            # print(\"Overall optimal\")\n",
    "            a,b,c,d = find_best_overall_size(status, targets, experts, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[1]['best'].append(a1)\n",
    "                len_stats[1]['overlap'].append(b1)\n",
    "                len_stats[1]['extra'].append(c1)\n",
    "                len_stats[1]['total'].append(b1+c1)\n",
    "                len_stats[1]['overall'].append(d1)\n",
    "                len_stats[1]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[1]['best'].append(None)\n",
    "                len_stats[1]['overlap'].append(None)\n",
    "                len_stats[1]['extra'].append(None)\n",
    "                len_stats[1]['total'].append(None)\n",
    "                len_stats[1]['overall'].append(None)\n",
    "                len_stats[1]['ind_lens'].append(None)\n",
    "            # print_stats(a,b,c)\n",
    "            \n",
    "            # print(\"Extra optimal\")\n",
    "            a,b,c,d = find_best_overlap_size(status, targets, experts, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[2]['best'].append(a1)\n",
    "                len_stats[2]['overlap'].append(b1)\n",
    "                len_stats[2]['extra'].append(c1)\n",
    "                len_stats[2]['total'].append(b1+c1)\n",
    "                len_stats[2]['overall'].append(d1)\n",
    "                len_stats[2]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[2]['best'].append(None)\n",
    "                len_stats[2]['overlap'].append(None)\n",
    "                len_stats[2]['extra'].append(None)\n",
    "                len_stats[2]['total'].append(None)\n",
    "                len_stats[2]['overall'].append(None)\n",
    "                len_stats[2]['ind_lens'].append(None)\n",
    "\n",
    "            a,b,c,d = find_best_extra_size(status, targets, experts, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[3]['best'].append(a1)\n",
    "                len_stats[3]['overlap'].append(b1)\n",
    "                len_stats[3]['extra'].append(c1)\n",
    "                len_stats[3]['total'].append(b1+c1)\n",
    "                len_stats[3]['overall'].append(d1)\n",
    "                len_stats[3]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[3]['best'].append(None)\n",
    "                len_stats[3]['overlap'].append(None)\n",
    "                len_stats[3]['extra'].append(None)\n",
    "                len_stats[3]['total'].append(None)\n",
    "                len_stats[3]['overall'].append(None)\n",
    "                len_stats[3]['ind_lens'].append(None)\n",
    "\n",
    "            a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[4]['best'].append(a1)\n",
    "                len_stats[4]['overlap'].append(b1)\n",
    "                len_stats[4]['extra'].append(c1)\n",
    "                len_stats[4]['total'].append(b1+c1)\n",
    "                len_stats[4]['overall'].append(d1)\n",
    "                len_stats[4]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[4]['best'].append(None)\n",
    "                len_stats[4]['overlap'].append(None)\n",
    "                len_stats[4]['extra'].append(None)\n",
    "                len_stats[4]['total'].append(None)\n",
    "                len_stats[4]['overall'].append(None)\n",
    "                len_stats[4]['ind_lens'].append(None)\n",
    "\n",
    "            a,b,c,d = find_representational_bins(status, targets, experts, epsilon)\n",
    "            a1,b1,c1,d1,e1 = find_stats(a,b,c)\n",
    "            if(a1 is not None):\n",
    "                len_stats[5]['best'].append(a1)\n",
    "                len_stats[5]['overlap'].append(b1)\n",
    "                len_stats[5]['extra'].append(c1)\n",
    "                len_stats[5]['total'].append(b1+c1)\n",
    "                len_stats[5]['overall'].append(d1)\n",
    "                len_stats[5]['ind_lens'].append(copy.deepcopy(e1))\n",
    "            else:\n",
    "                len_stats[5]['best'].append(None)\n",
    "                len_stats[5]['overlap'].append(None)\n",
    "                len_stats[5]['extra'].append(None)\n",
    "                len_stats[5]['total'].append(None)\n",
    "                len_stats[5]['overall'].append(None)\n",
    "                len_stats[5]['ind_lens'].append(None)\n",
    "\n",
    "        \n",
    "        # print_stats(a,b,c)\n",
    "        # print()\n",
    "        # print(\"#\"*100)\n",
    "        \n",
    "    final_stats[set_size] = len_stats\n",
    "    # print(len_stats)\n",
    "    print(np.mean(len_stats[0]['overlap']))\n",
    "    print(len(len_stats[0]['overlap']))\n",
    "    print(np.mean(len_stats[0]['total']))\n",
    "    print(len(len_stats[0]['total']))\n",
    "    print(np.mean(len_stats[1]['overlap']))\n",
    "    print(len(len_stats[1]['overlap']))\n",
    "    print(np.mean(len_stats[1]['total']))\n",
    "    print(len(len_stats[1]['total']))\n",
    "    print(np.mean(len_stats[2]['overlap']))\n",
    "    print(len(len_stats[2]['overlap']))\n",
    "    print(np.mean(len_stats[2]['total']))\n",
    "    print(len(len_stats[2]['total']))\n",
    "    print(np.mean(len_stats[3]['overlap']))\n",
    "    print(len(len_stats[3]['overlap']))\n",
    "    print(np.mean(len_stats[3]['total']))\n",
    "    print(len(len_stats[3]['total']))\n",
    "    torch.save(final_stats, \"final_stats_ssa_4_exp_diff.pth\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "566bd685-b2e3-40bd-9f7a-08a2631d0c2e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_7976\\358030600.py:5: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  final_stats = torch.load(\"final_stats_ssa_4_exp.pth\")\n",
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_7976\\358030600.py:6: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  final_stats_diff = torch.load(\"final_stats_ssa_4_exp_diff.pth\")\n"
     ]
    },
    {
     "data": {
      "image/png": "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EB8fD19fX7i6uiIsLAxnzpyxT7JERKX0wgsvICkpCbNmzULr1q2xf/9+7NixAwEBAQCAjIwMXL16VR2vUqkQGxuL1q1bo127dli2bBnmzZuHWbNm2eshEBEREREREVmM2WdST5s2DbNnz0ZMTAzc3d3V5T169MCSJUuM1o+Li8MHH3yAN998U30N69TUVEyePBmXL1/G7NmzzU2JiIiIiCqwnJwchISEIDo6GoMGDdLavmDBAixevBjJyclo0qQJZs+ejfDwcPz+++8a70eJiMq7cePGYdy4cTq3JScna9x/8803edY0ERERERERVVpmT1KfOnUK69at0yqvU6cObt++bbT+8uXL8X//938YNmyYuuzZZ59Fq1at8Oabb3KSmoiIiKiKiYyMRGRkpM5tQggkJSVh+vTpeO655wAAa9asQb169bBu3TqMGTPGlqlSGQVO225w++V5fWyUCRERERERERER2ZPZk9Q1atRARkYGGjZsqFF+4sQJ1K9f32j9goICtGvXTqu8bdu2yM/PNzcdIiIiIqrELl26hMzMTERERKjLZDIZunfvjkOHDnGS2lzxnibE3LV+HkREREREREREVKWZPUk9fPhwTJ06FRs2bIBEIoFKpcLPP/+Mt99+GyNHjjRa/6WXXsLy5cuxePFijfKVK1fixRdfNDcdIiIiIqrEMjMzAQD16tXTKK9Xrx6uXLmit55CoYBCoVDfz8rKAgAolUoolUqT9i1zFEZj1G05uDwqe3hbWawMD+NkkJnephmM5aorTwPBZu/fVCbnqae8NH1T2ZXmudd5jBYGF7Zp5Di1xjGq0a6x49RKryceX0RERERERES2Y/Yk9Zw5czBq1CjUr18fQgi0aNECBQUFGD58ON577z2ddWJiYtS3JRIJPv30U6SkpOCJJ54AABw+fBh//fWXSZPcRERERFT1SCQSjftCCK2y4hITE5GQkKBVnpKSAjc3N5P2uaCD8ZgdO3YU3ghZqbVNHry0eCAAIK5GnOltmsFYroby1BFs9v5NZXKeesjlcgtmUzmU5bnXOEYLgwEYP06tcYxqtGvsOLXS6yk3N9fkWCIiIiIiIiIqG7MnqaVSKb788kvMmjULJ06cgEqlQmhoKB5//HG9dU6cOKFxv23btgCAP//8E0Dh9azr1KmDM2fOmJsOUYUXvCbY4PZTUadslAkREVH5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IiIiIiIiIiIiIiIiIirHzD6TWqVS4X//+x/q16+P6tWr4+LFiwCAuLg4rFq1ymj9c+fO4eWXX9YqHz16NM6ePWtuOkREREREREREREREREREVIGYfSb17NmzsWbNGixYsACvvvqqujw4OBgffPCBzgno4urUqYP09HQ8/vjjGuXp6emoW7euuekQlU/xnibE3LV+HkRERERERERERERERETljNmT1GvXrsXKlSvRs2dPjB07Vl3eqlUr/Pbbb0brv/rqq3jttddw8eJFdO7cGRKJBAcPHsT8+fPx1ltvmZsOERERERFVYcFrgo3GnIo6ZYNMiIiIiIiIiIjIVGZPUl+/fh2NGzfWKlepVFAqlUbrx8XFwd3dHe+//z5iY2MBAL6+voiPj8eECRPMTUctMTER7777LiZOnIikpKRSt0NERERERGQyYyvocPUcIiIiIiIiIiItZk9SBwUF4cCBAwgICNAo37BhA0JDQ43Wl0gkmDx5MiZPnox79+4BANzd3c1NQ8PRo0excuVKtGrVqkztEBERERERERERERERERGRdZk9ST1z5kyMGDEC169fh0qlwqZNm/D7779j7dq12LZtm1ltlXVyGgCys7Px4osv4v/+7/8we/bsMrdHRERERERERERERERERETWY/Ykdb9+/bB+/XrMnTsXEokEM2bMQJs2bfD9998jPDzcGjkaNH78ePTp0wdPP/200UlqhUIBhUKhvp+VlQUAUCqVJi1VXhZF7Vt7PxWRzFEYjVH3m4PLo7KHt5XFyvAwTgaZ6W1aQ/Gc9CcAwHiutjxmeJxqY18QERERERERERERERFZltmT1ADQq1cv9OrVy9K5mO3rr7/G8ePHcfToUZPiExMTkZCQoFWekpICNzc3S6enk1wut8l+KpIFHYzH7Nixo/BGyEqtbfLgpcUDAQBxNeJMb9MadOSpIwEAxnO1ap568Dh9JDc3194pEBERERERERERERERVSpmT1IfPXoUKpUKHTt21Cg/cuQIHB0d0a5dO4slZ8hff/2FiRMnIiUlBS4uJpy1CiA2NhYxMTHq+1lZWfDz80NERAQ8PDyslSqAwrMx5XI5wsPDIZVKrbqviqZl/C6jMafjH/4oIrGBukzp4AJ58FKEn5oAqSqvsDD2GgCg07pORttMHZ5qfrKmKpanXibmatU8S+Bxqq1oxQUiIiIi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OXHgwAHde++9evvtt/XXX3/p/PPP19KlS9WlSxd/hwYAAAAAAADATT4fpJ42bZrNck5Ojnbu3Kn169fr7rvvdqutX375RWPHjtXBgwcVHh6ujh07av369Ro0aJAHIwYAAIA//f777+rdu7cGDBigt99+W5GRkfr2229Vp04df4cGAAAAAAAAoBR8Pkh9xx13OCx/5plntH37drfaWrp0qSdCAgAAQDk2Z84cRUVFadmyZdayli1b+i8gAAAAAAAAAGVSqkHqb7/9VsuWLdO3336r+fPnKzIyUuvXr1dUVJTat29fqkDi4uKUkJBgc/ARAAAAeP311zV48GBdddVVysjIUNOmTTVp0iTdfPPNxa6TnZ2t7Oxs63JWVpak/Fl8cnJyXNpucHXjtI61rWohZ8v+/junUJn+rhesYNfbdIOzWB3FWULl/DadxOrLOH3dp6V974upmN9mOXrvHfZnfuX8Nv3w3tu066c+Lc3rQuUT83xMic/vGbfHR5EAAAAAQOXm9iB1RkaG4uLi1Lt3b23atEmPPPKIIiMjtXv3bv373//WK6+8UqpAXnnlFUVERJRqXQCoarg3K4Cq5LvvvtOiRYsUHx+v++67Tx999JGmTp2q4OBgXX/99Q7XSU5OVlJSkl15WlqawsLCXNru3O7O66xbty7/j05L7J5Lj1lQuKIkaWadma636QZnsZYUp4PKkpzH6o84fdWnZX3vi1SUVD7fe5v+zK8syT/vvU27furTkydPulwXAAAAAACUjduD1DNmzNDs2bMVHx+vWrVqWcsHDBig+fPnO12/c+fOslgs1mVjjA4dOqQjR45o4cKF7oYDAFUO92YFUNXk5eWpa9euevTRRyXlf5/87LPPtGjRomIHqRMSEhQfH29dzsrKUlRUlGJjY1W7dm2XttshcYPTOp8mDs7/I7mZtSynWojSYxZo0J6pCsw79XdAP0mSeq7o6bTNzDGZLsXnTqyO4iyWi7H6Mk5f92lp33uHyuF777A/3YjVG3EWF6tDXurTghkXAAAAAACA97k9SL1nzx6tWLHCrrxBgwY6evSo0/WHDx9us1ytWjU1aNBA/fv3V5s2bdwNBwCqHO7NCqCqady4sdq1a2dT1rZtW61evbrYdYKDgxUcbD8VcGBgoAIDA13abnauxWkda1uFB/oKnss7dXYA8O962cq2q1dsm25w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Baun3X777Xr99de1adMmNWvWrNh6CQkJio+Pty5nZWUpKipKsbGxql27tldjzMnJUXp6ugYNGqTAwECvbsttycX3mVXCT5Kknit6llgtc0ym25vvkLjBaZ1PEwfn/1Eo1pxqIUqPWaBBe6YqMO+UW3F6K1ZHcRbLi31aWuV6P/WTghkXAADlw7Zt27RkyRJ17NjR36EAAAAAAAAAKCWXB6kTExPVv39/6yD1nj17dOONN2r8+PFq27atHn/8cTVp0kSJiYneitWOMUa333671qxZo40bNyo6OrrE+sHBwQ4H0QMDA302IOfLbbmsYIC3JH/HnK1sJ9Xcf23ZuRYXNv93uw5iDcw7dXaQ2sU4bdp0g7NYS4rTQeX8Nr3Qp2VVLvdTP6EfAKD8OH78uK699lr961//0uzZs/0dDgAAAAAAAIBScnmQeteuXXr44YetyytXrlSPHj30r3/9S5IUFRWlWbNm+XSQevLkyVqxYoVee+011apVS4cOHZIkhYeHKzQ01GdxlFctZ7xV4vPfPzbER5EA8BamvAVQlUyePFlDhgzRpZdeyiA1AAAAAAAAUIG5PEj9+++/q2HDhtbljIwM/d///Z91uVu3bvrxxx89G50TixYtkiT179/fpnzZsmUaP368T2MBAF9jylsAVcnKlSv18ccfa9u2bS7Vz87OVnb22dlKCm7fkJOTo5ycHJfaCK5unNaxtlUt5GzZ33/nFCrT3/WC5fzWOK7GV5izWB3FWULl/DadxOrLOH3dp6V974upmN9mOXrvHfZnfuX8Nv3w3tu066c+Lc3rAgAAAAAApePyIHXDhg21b98+RUVF6fTp0/r444+VlJRkff7PP//0+bS4xjg/0AEAlRFT3gKoSn788UfdcccdSktLU0iIC4Osyp9povB31QJpaWkKCwtzqY253Z3XWbduXf4fnZbYPZces6BwRUnSzDozXW/TDc5iLSlOB5UlOY/VH3H6qk/L+t4XqSipfL73Nv2ZX1mSf957m3b91KcnT550uS4AAAAAACgblwep/+///k8zZszQnDlztHbtWoWFheniiy+2Pr979261atXKK0ECAGwx5S2AqmTHjh06fPiwunTpYi3Lzc3Vpk2b9PTTTys7O1vVq1e3WSchIUHx8fHW5aysLEVFRSk2Nla1a9d2absdEjc4rfNp4uD8P5KbWctyqoUo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AuXxWG5JvH08I8BrLaPKef/99zVt2jRddtllWrNmjQICzu5e11xzjUaMGKE77rhDnTt3Vu/evX0W119//aWQkBCfba+sOnfu7O8QAHjZRRddZLPcoEEDVatWza68omrQoIEaNGjg7zAAlDMdOnRQ165dfb7dkydPKiwszGfbIwcC7uO3pOe1a9fOK+2+8soruvLKK9WqVSu1atXKWn7q1ClJ0nnnnVdpvtNWltdRlWzfvl2ffPKJhgwZorfeektLly5Vjx49fBqDMUanTp1SaGioT7cL7yuc86oqX3+v9tc2vYUcBW8iR7kmNzdXZ86cUXBwsL9D8aiK/Lq4khoek5ycLIvFokWLFtkcVJCkgIAALVy4UBaLRY899pgkae3atbJYLPrf//5n19aiRYtksVi0e/dua9n27dv1j3/8QxEREQoJCVHnzp310ksv2axXMA1bWlqabrjhBjVo0EBhYWHKzs52GHN6erqGDRumZs2aKSQkROeee65uvfVWu+nTCqZV27lzp6644grVrl1b4eHhuu6663TkyBGX++izzz7TwIEDVaNGDTVo0EBTpkzRyZMnbeoUnhZi48aN6tatmyRpwoQJ1inTCqYc++6773TNNdeoSZMmCg4OVsOGDTVw4ECuugYqgd9++02TJk1S06ZNFRQUpHPOOUf333+/TT6zWCw6ceKEnn/+eWt+KJjW8ciRI5o0aZLatWunmjVrKjIyUpdccok2b95cprjy8vL0yCOPqHnz5goJCVHXrl3t8njRKTH79++vt956Sz/88IPN9I8FFi1apE6dOqlmzZqqVauW2rRpo/vuu69McQKoeFauXCmLxWJ3teSsWbNUvXp1paen6/vvv7cOACclJdlNJ1vwne3jjz/WyJEjVbduXeuP9e3bt+uaa65Ry5YtFRoaqpYtW2r06NH64YcfXI6RHAh4B78l3fPjjz86bavwdN/OcueRI0d0yy23KCoqSsHBwWrQoIF69+6td955x6bNL774Qnv37tWVV17pcqzPPfecOnXqpJCQEEVERGjEiBH6/PPPrc+PHz/eehV24RxZkEOfeeYZ9e3bV5GRkapRo4ZiYmI0d+5c5eTkuNNldjZv3qyLLrpIoaGhatq0qWbOnKnc3FybOoV/e6empuqqq66SJA0YMMAaZ2pqqiRp586dGjp0qCIjIxUcHKwmTZpoyJAh+umnn8oUJ9yzdOlSSdJjjz2mXr16aeXKldZjLjk5OYqMjNTYsWPt1vvjjz8UGhqq+Ph4a1lWVpbuuusuRUdHKygoSE2bNtW0adN04sQJm3UtFoumTJmixYsXq23btgoODtbzzz8vKf/z1qNHD0VERKh27dq68MILtXTpUhljbNrIzs7WnXfeqUaNGiksLEx9+/bVjh07HE4beujQId16661q1qyZgoKCFB0draSkJJ05c8alPlqxYoV69uypmjVrqmbNmrrgggus/VbA2edWOntbuy+++EKDBw9WjRo11LhxY2ue/uCDD9SnTx/VqFFD559/vrVPChTk3PT0dE2YMEERERGqUaOGLr/8cn333Xc2dYubPrVwnnN2/MyV74HOPueOpnY9deqUEhISbPaTyZMn648//rB7DUOHDtX69et14YUXKjQ0VG3atLFeVVvg5MmT1v2uoP+7du2qF1980e71l7Y/Jemdd97RwIEDVbt2bYWFhal37952/1NL+l7taPsl9Z27/zMdbdOTnxNn/xe9hRzlHDmqcuYoSfr00081bNgw1a1bVyEhIbrgggts+v3IkSMKCgpyOAvPF198IYvFogULFljLXNnXCm7bNXfuXM2ePVvR0dEKDg7We++9V2yc3vruWcATx3Kdva7XXntNHTt2VHBwsM455xzNnz/fml8LM8Zo4cKFuuCCCxQaGqq6detq5MiRNvu4T45nGMADzpw5Y8LCwkyPHj1KrNe9e3cTFhZmzpw5Y3JyckxkZKS59tprHda78MILrcvvvvuuCQoKMhdffLFZtWqVWb9+vRk/fryRZJYtW2att2zZMiPJNG3a1Nxyyy3m7bffNq+88oo5c+aM9bl9+/ZZ6y9atMgkJyeb119/3WRkZJjnn3/edOrUybRu3dqcPn3aWm/WrFlGkmnRooW5++67zYYNG8y8efNMjRo1TOfOnW3qOjJu3DgTFBRkmjdvbh555BGTlpZmEhMTTUBAgBk6dKhN3RYtWphx48YZY4w5duyYNe4HHnjAZGZmmszMTPPjjz8aY4xp3bq1Offcc81//vMfk5GRYVavXm3uvPNO895775UYD4DyZdy4caZGjRrW5b/++st07NjR1KhRwzzxxBMmLS3NzJw50wQEBJjLLrvMWi8zM9OEhoaayy67zJofPvvsM2OMMV988YW57bbbzMqVK83GjRvNm2++aW688UZTrVo1uxwhycyaNavEGPft22ckmaioKNOnTx+zevVq8/LLL5tu3bqZwMBAs3XrVmvdovn2s88+M7179zaNGjWyxpmZmWmMMebFF180ksztt99u0tLSzDvvvGMWL15spk6dWoYeBVCeFOSEDz74wOTk5Ng8zpw5Y1N34sSJJigoyGzbts0YY8z//vc/U61aNfPAAw8YY4w5deqUWb9+vZFkbrzxRms++eabb4wxtt/Z7r33XpOenm7Wrl1rjDHm5ZdfNg8++KBZs2aNycjIMCtXrjT9+vUzDRo0MEeOHCnxNZADAe/ht2TJvyULc6etfv36mX79+hljnOfOwYMHmwYNGpglS5aYjRs3mrVr15oHH3zQrFy50mb7s2fPNk2bNjV5eXl2sb333ntGknn55ZetZY8++qiRZEaPHm3eeusts3z5cnPOOeeY8PBw89VXXxljjPnmm2/MyJEjjSSbHHnq1CljjDHTp083ixYtMuvXrzfvvvuuefLJJ039+vXNhAkTbLY/btw406JFC6d92K9fP1OvXj3TpEkTs2DBArNhwwYzdepUI8lMnjzZpm7h78iHDx+2vp5nnnnGGufhw4fN8ePHTb169UzXrl3NSy+9ZDIyMsyqVavMxIkTzd69e53GBM84efKkCQ8PN926dTPGGPPvf//bSDKpqanWOtOnTzehoaHm2LFjNusuXLjQSDK7d+82xhhz4sQJc8EFF5j69eubefPmmXfeecfMnz/fhIeHm0suucTmM1CQNzp27GhWrFhh3n33XfPpp58aY4wZP368Wbp0qUlPTzfp6enm4YcfNqGhoSYpKclm+6NHjzbVqlUzM2bMMGlpaSYlJcVERUWZ8PBw6/EhY4w5ePCgiYqKMi1atDDPPvuseeedd8zDDz9sgoODzfjx45320cyZM40kc8UVV5iXX37ZpKWlmXnz5pmZM2da67jyuTXm7HGutm3bmvnz55v09HQzYcIEI8kkJCSY888/3yxdutRs2LDBDB061Egy27dvt65fkFejoqLMDTfcYN5++22zZMkSExkZaaKioszvv/9urVv4OFlhhfOcs+NnrnwPLOlzXvCaC+eZvLw8M3jwYBMQEGBmzpxp0tLSzBNPPGHNyQV5rOA1NGvWzLRr184sX77cbNiwwVx11VVGksnIyLDWu/XWW01YWJiZN2+eee+998ybb75pHnvsMfPUU0+V+N6605//+c9/jMViMcOHDzevvvqqeeONN8zQoUNN9erVzTvvvGOtV9L36qKc9V1p/mcW3aYnPyfO/i96AzmKHFWVc9QXX3xhatWqZVq1amWWL19u3nrrLTN69GgjycyZM8dab8SIESYqKsrk5ubarH/PPfeYoKAg8+uvvxpjXN/XCn7HN23a1AwYMMC88sorJi0tzeY7fVFl+e5Z3L5QmCeO5Zb0ut5++21TrVo1079/f7NmzRrz8ssvmx49epiWLVuaosPBN998swkMDDR33nmnWb9+vVmxYoVp06aNadiwoTl06JAxxjfHMxikhkccOnTISDLXXHNNifVGjRplJJlffvnFGGNMfHy8CQ0NNX/88Ye1zt69e40km+TWpk0b07lzZ5OTk2PT3tChQ03jxo2tiasg2V9//fV223Z0YKGwvLw8k5OTY3744Qcjybz22mvW5wq+JE2fPt1mnf/+979GknnhhRdKfN3jxo0zksz8+fNtyh955BEjyWzZssVaVjSZbdu2ze4AijHG/Prrr0aSSUlJKXHbAMq/ooPUixcvNpLMSy+9ZFNvzpw5RpJJS0uzltWoUcPpFyBjjPWA7sCBA82IESNsnnNnkLpJkybmr7/+spZnZWWZiIgIc+mll1rLHOXbIUOGODxwOGXKFFOnTh2n8QOouApygqNH9erVbeqeOnXKdO7c2URHR5u9e/eahg0bmn79+tkMZh85cqTYvFXwne3BBx90GteZM2fM8ePHTY0aNey+oxVFDgS8h9+SJf+WLMydtgofGDWm5NxZs2ZNM23aNKfbv+CCC8ztt9/u8Lmig9S///679QBcYfv37zfBwcFmzJgx1rLJkyfbHTRzJDc31+Tk5Jjly5eb6tWrm99++836nDuD1EXfI2PyD9JVq1bN/PDDD9ayov318ssvG0l2J3xu377dSCp28Aa+sXz5ciPJLF682BhjzJ9//mlq1qxpLr74Ymud3bt3G0lmyZIlNut2797ddOnSxbqcnJxsqlWrZj1prsArr7xiJJl169ZZyySZ8PBwm/3RkYL996GHHjL16tWzDiJ99tlnRpK59957beoXHPgt/Fvv1ltvNTVr1rTZT40x5oknnjCSrAe5Hfnuu+9M9erVHZ7cU8Cdz23Bca7Vq1dby3JyckyDBg2MJPPxxx9by48ePWqqV69u4uPjrWUFebXob9P333/fSDKzZ8+2lrkyAGRM8cfPHCnue2Bxn/OC11w4zxQMcs6dO9em3qpVq+z2sxYtWpiQkBCb9+6vv/4yERER5tZbb7WWdejQwQwfPtxp/EW52p8nTpwwERER5vLLL7epl5ubazp16mS6d+9uLXPne7UxJfddYa78zyy6TW98Tkr6v+gN5ChyVFXOUddcc40JDg42+/fvtymPi4szYWFh1u/zr7/+ut1xzzNnzpgmTZqYK6+80lrm6r5W8Du+VatWbp0YWsDd756uDFIbU/ZjuSW9rm7dupmoqCiTnZ1tLfvzzz9NvXr1bL5vZ2ZmGknmn//8p836P/74owkNDTX33HOPtczbxzOY7hs+Zf6eLqRgSoAbbrhBf/31l1atWmWts2zZMgUHB2vMmDGSpG+++UZffPGFrr32WknSmTNnrI/LLrtMBw8e1JdffmmzHVenHzt8+LAmTpyoqKgoBQQEKDAwUC1atJAku2lCJFljKHD11VcrICCgxCkiSlq/4DW6un5hERERatWqlR5//HHNmzdPO3fuVF5entvtACh/3n33XdWoUUMjR460KS+YPsjR1JaOLF68WBdeeKFCQkKsOe5///ufw/zmqiuuuMLm3oy1atXS5Zdfrk2bNtlNkeiK7t27648//tDo0aP12muv2U33BaDyWL58ubZt22bz+PDDD23qBAcH66WXXtLRo0d14YUXyhijF198UdWrV3drW46+Cx4/flz33nuvzj33XAUEBCggIEA1a9bUiRMnXM6L5EDAf6r6b0lvtSXl56LU1FTNnj1bH3zwgcPpDL/77jvt2rXL5f7JzMzUX3/9ZTf9ZVRUlC655BKXv8/u3LlT//jHP1SvXj1Vr15dgYGBuv7665Wbm6uvvvrKpTaKqlWrlv7xj3/YlI0ZM0Z5eXnatGmT2+2de+65qlu3ru69914tXrxYe/fuLVVcKJulS5cqNDRU11xzjSSpZs2auuqqq7R582Z9/fXXkqSYmBh16dJFy5Yts673+eef66OPPtINN9xgLXvzzTfVoUMHXXDBBTZ5Y/DgwbJYLNq4caPNti+55BLVrVvXLqZ3331Xl156qcLDw63774MPPqijR4/q8OHDkqSMjAxJ+Z/jwkaOHGl3+4M333xTAwYMUJMmTWziiouLs2nLkfT0dOXm5mry5MnF1nH3c2uxWHTZZZdZlwMCAnTuueeqcePG6ty5s7U8IiJCkZGRDm+xUjSf9erVSy1atCh1PiuOJ74HFvXuu+9Kkl1/XXXVVapRo4Zdf11wwQVq3ry5dTkkJETnn3++Tb90795db7/9tmbMmKGNGzfqr7/+cismZ/25detW/fbbbxo3bpzNPpSXl6f/+7//07Zt2+ymi3bnFg/Fcfd/ZtFt+upz4k3kKHJUSSp7jnr33Xc1cOBARUVF2ZSPHz9eJ0+eVGZmpiQpLi5OjRo1svkMbNiwQT///LPdZ8Cdfe0f//iHAgMDXYrVG9893eHOsdyir+vEiRPavn27hg8frqCgIGt5zZo1dfnll9us++abb8pisei6666z6cNGjRqpU6dOdnnEEU8dz2CQGh5Rv359hYWFad++fSXW+/777xUWFqaIiAhJUvv27dWtWzdr4snNzdULL7ygYcOGWev88ssvkqS77rpLgYGBNo9JkyZJkt0HoHHjxk5jzsvLU2xsrF599VXdc889+t///qePPvpIH3zwgSQ5TLKNGjWyWQ4ICFC9evV09OhRp9srqOuoPVfWL6rgHmyDBw/W3LlzdeGFF6pBgwaaOnWq/vzzT7fbA1B+HD16VI0aNbK7V0hkZKQCAgJcyhnz5s3Tbbfdph49emj16tX64IMPtG3bNv3f//2f2z90CyuaBwvKTp8+rePHj7vd3tixY/Xcc8/phx9+0JVXXqnIyEj16NFD6enppY4RQPnUtm1bde3a1ebRpUsXu3rnnnuuLr74Yp06dUrXXnutS9/rinK0zpgxY/T000/rpptu0oYNG/TRRx9p27ZtatCggct5kRwIeB6/Jd3/LejJtiRp1apVGjdunP7973+rZ8+eioiI0PXXX69Dhw5Z67zyyiuKjIxUnz59XGqzIBZH/dmkSROXYt2/f78uvvhiHThwQPPnz9fmzZu1bds26z2sS/udtmHDhnZlZfltHh4eroyMDF1wwQW677771L59ezVp0kSzZs3y2P0LUbJvvvlGmzZt0pAhQ2SM0R9//KE//vjDetJv4Xtq3nDDDcrMzNQXX3wh6ezJLaNHj7bW+eWXX7R79267vFGrVi0ZY1zKGx999JFiY2MlSf/617/0/vvva9u2bbr//vslnd1/C/a5ovulo2NIv/zyi9544w27uNq3by/JPp8VVnDf+mbNmhVbx93PbVhYmM3Je5IUFBRkzcFFy0+dOmVXXtx3q9Lms+J44ntgUUePHlVAQID13sYFLBaLw9dQ9P2U8k/QLLz9BQsW6N5779XatWs1YMAARUREaPjw4dZBTGec9WfB/8WRI0fa7Udz5syRMUa//fabzfql+S5eWGn+Zxbdpq8+J95CjiJHOVPZc9TRo0eLfd8Knpfy96uxY8dqzZo11vtmp6amqnHjxho8eLB1PXf3NVfzmLe+e7rK3WO5RV/X77//LmOMw++6Rct++eUXa92i/fjBBx+4lCs9dTwjwHkVwLnq1atrwIABWr9+vX766SeH/1B++ukn7dixQ3FxcTZXw0yYMEGTJk3S559/ru+++04HDx7UhAkTrM/Xr19fkpSQkKArrrjC4fZbt25ts1x0YMeRTz/9VJ988olSU1M1btw4a/k333xT7DqHDh1S06ZNrctnzpzR0aNHHSbxohzVLfjR78r6jrRo0UJLly6VJH311Vd66aWXlJiYqNOnT2vx4sWlahOA/9WrV08ffvihjDE2+ezw4cM6c+aMNS+W5IUXXlD//v21aNEim/KynsRS+GBl4bKgoCDVrFmzVG1OmDBBEyZM0IkTJ7Rp0ybNmjVLQ4cO1VdffWU9uxpA1fHvf/9bb731lrp3766nn35ao0aNUo8ePdxqo+h3wWPHjunNN9/UrFmzNGPGDGt5dna23YG4kpADAc/jt6T7vwU92ZaU308pKSlKSUnR/v379frrr2vGjBk6fPiw1q9fL0lavXq1hg8f7vLMFgWxHDx40O65n3/+2aXvs2vXrtWJEyf06quv2uTDXbt2uRRDcQoGaQor62/zmJgYrVy5UsYY7d69W6mpqXrooYcUGhpq838H3vHcc8/JGKNXXnlFr7zyit3zzz//vGbPnq3q1atr9OjRio+PV2pqqh555BH95z//0fDhw22uMqxfv75CQ0NtBo4KK7r/OsobK1euVGBgoN58802bQZK1a9fa1CvY53755ReHn+ui2+3YsaMeeeQRh3EVHOx3pGCQ4qeffrK7kq1oLGX53LqruO9W5557rnU5JCRE2dnZdvV+/fVXl2Ly1PfAourVq6czZ87oyJEjNoNAxhgdOnRI3bp1c7vNGjVqKCkpSUlJSfrll1+sVyxefvnl1kHLkjjrz4L+euqpp3TRRRc5bKPoQIYr/xdLUpr/mUW36avPibeQo/KRoxyrCjmqXr16xb5vku0+O2HCBD3++ONauXKlRo0apddff13Tpk2z+Q7q7r7mah7z1ndPV7l7LLfo66pbt64sFkuJ33UL1K9fXxaLRZs3b1ZwcLBdfUdljnjieAZXUsNjEhISZIzRpEmT7KY7zM3N1W233SZjjBISEmyeGz16tEJCQpSamqrU1FQ1bdrUeiaXlH/Q4LzzztMnn3xid/VNwaNWrVpux1vwIS76gXv22WeLXee///2vzfJLL72kM2fOqH///i5ts+j6K1askKQS1y+Iz9mZOueff74eeOABxcTE6OOPP3YpHgDl08CBA3X8+HG7HwfLly+3Pl+g6FmNBSwWi11+2717t3UKndJ69dVXbc4u/fPPP/XGG2/o4osvLvGgZXFxFlajRg3FxcXp/vvv1+nTp/XZZ5+VKVYAFc+ePXs0depUXX/99dq8ebM6duyoUaNG6ffff7fWcfW7UWEWi0XGGLu8+O9//9utabrJgYB38FvSPaVpy9Xc2bx5c02ZMkWDBg2y/q788ccftW3bNremfO3Zs6dCQ0P1wgsv2JT/9NNP1ikfncXmqJ+NMfrXv/7lchyO/Pnnn3r99ddtylasWKFq1aqpb9++xa7nSh9aLBZ16tRJTz75pOrUqcNvcx/Izc3V888/r1atWum9996ze9x55506ePCg3n77bUn5B3CHDx+u5cuX680339ShQ4dsphCVpKFDh+rbb79VvXr1HOaNli1bOo3LYrEoICDA5vvBX3/9pf/85z829Qr2ucK3LpDyZy84c+aMXVyffvqpWrVq5TCukgaAYmNjVb16dbsD34W587n1lKL5bOvWrfrhhx9s8lnLli21e/dum3pfffWV3e0aSsolrn4PdOd7ZkF/FO2v1atX68SJE2Xur4YNG2r8+PEaPXq0vvzyS508edLpOs76s3fv3qpTp4727t1b7P/FwlPEusOdXC6V/D+zKG98Tkrzm6I0yFHkqAJVOUcNHDhQ7777rnVQusDy5csVFhZmc9JM27Zt1aNHDy1btkwrVqxQdna2zUmoUtn2tZJ467tnUd46llujRg117dpVa9eu1enTp63lx48f15tvvmlTd+jQoTLG6MCBAw77MCYmxmm8Rbdd2uMZXEkNj+ndu7dSUlI0bdo09enTR1OmTFHz5s21f/9+PfPMM/rwww+VkpKiXr162axXp04djRgxQqmpqfrjjz901113qVo12/Mnnn32WcXFxWnw4MEaP368mjZtqt9++02ff/65Pv74Y7388stux9umTRu1atVKM2bMkDFGEREReuONN0qcjuDVV19VQECABg0apM8++0wzZ85Up06d7O7L4UhQUJD++c9/6vjx4+rWrZu2bt2q2bNnKy4ursQp01q1aqXQ0FD997//Vdu2bVWzZk01adJEv/76q6ZMmaKrrrpK5513noKCgvTuu+9q9+7dnKkNVHDXX3+9nnnmGY0bN07ff/+9YmJitGXLFj366KO67LLLdOmll1rrxsTEaOPGjXrjjTfUuHFj1apVS61bt9bQoUP18MMPa9asWerXr5++/PJLPfTQQ4qOjrb7IeGO6tWra9CgQYqPj1deXp7mzJmjrKwsJSUllbheTEyMXn31VS1atEhdunRRtWrV1LVrV918880KDQ1V79691bhxYx06dEjJyckKDw8v1VmdAMqvTz/91GH+adWqlRo0aKATJ07o6quvVnR0tBYuXKigoCC99NJLuvDCCzVhwgTriTu1atVSixYt9Nprr2ngwIGKiIhQ/fr1SzwYU7t2bfXt21ePP/64tW5GRoaWLl2qOnXquPwayIGAd/Bb0j2laau43Fm3bl0NGDBAY8aMUZs2bVSrVi1t27ZN69evt159vnr1atWpU0cDBgxwOcY6depo5syZuu+++3T99ddr9OjROnr0qJKSkhQSEqJZs2ZZ6xYcBJszZ471avmOHTtq0KBBCgoK0ujRo3XPPffo1KlTWrRokc2JS6VRr1493Xbbbdq/f7/OP/98rVu3Tv/6179022232dyLsagOHTpIkpYsWaJatWopJCRE0dHRyszM1MKFCzV8+HCdc845Msbo1Vdf1R9//KFBgwaVKVY49/bbb+vnn3/WnDlzHJ6o0aFDBz399NNaunSphg4dKil/Ot1Vq1ZpypQpatasmc3vK0maNm2aVq9erb59+2r69Onq2LGj8vLytH//fqWlpenOO+90OsvLkCFDNG/ePI0ZM0a33HKLjh49qieeeMLu4HP79u01evRo/fOf/1T16tV1ySWX6LPPPtM///lPhYeH2+S0hx56SOnp6erVq5emTp2q1q1b69SpU/r++++1bt06LV68uNipclu2bKn77rtPDz/8sP766y+NHj1a4eHh2rt3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nJysbt26qVatWoqMjNTw4cP15ZdfOl0vIyNDXbp0UUhIiM455xwtXrzYrs7q1avVrl07BQcHq127dlqzZo03XgIAlBtnzpzRAw88oOjoaIWGhuqcc87RQw89pLy8PH+HBgBeVaEHqV9//XV17dpVV111lSIjI9W5c2f961//8ndYAAAAcENcXJxmz56tK664wuHz999/vy677DLNnTtXnTt31jnnnKMhQ4YoMjLSx5ECAABAyh9snjx5sj744AOlp6frzJkzio2N1YkTJ4pdZ9++fbrssst08cUXa+fOnbrvvvs0depUrV692lonMzNTo0aN0tixY/XJJ59o7Nixuvrqq/Xhhx/64mUBgF/MmTNHixcv1tNPP63PP/9cc+fO1eOPP66nnnrK36EBgFdV6Om+v/vuOy1atEjx8fG677779NFHH2nq1KkKDg7W9ddfb1c/Oztb2dnZ1uWsrCxJUk5OjnJycrwaa0H73t5OVVJSnwYr2OX1cRb7qT36AgD8Ky8vT2+99ZbuueceDR48WDt37lR0dLQSEhLspgQHAACAb6xfv95medmyZYqMjNSOHTvUt29fh+ssXrxYzZs3V0pKiiSpbdu22r59u5544gldeeWVkqSUlBQNGjRICQkJkqSEhARlZGQoJSVFL774ovdeEAD4UWZmpoYNG6YhQ/JvJ9WyZUu9+OKL2r59u58jAwDvqtCD1Hl5eerataseffRRSVLnzp312WefadGiRQ4HqZOTk5WUlGRXnpaWprCwMK/HK0np6ek+2U5V4qhPZ9aZ6XS9devWeSOcSoH99KyTJ0/6OwQAqNIOHz6s48eP67HHHtPs2bM1Z84crV+/XldccYXee+899evXz+F6njg5Mbi6cVrHUVuc9OV59Kln0Z+O0R8AUHrHjh2TJEVERBRbJzMzU7GxsTZlgwcP1tKlS5WTk6PAwEBlZmZq+vTpdnUKBrYBoDLq06ePFi9erK+++krnn3++PvnkE23ZsoXcB6DSq9CD1I0bN1a7du1sytq2bWszTVBhCQkJio+Pty5nZWUpKipKsbGxql27tldjzcnJUXp6ugYNGqTAwECvbquqKKlPe67o6XT9zDGZ3gqtwmI/tVcwqAEA8I+Ce3ANGzbMesDyggsu0NatW7V48eJiB6k9cXLi3O7O65R00hsnfXkefepZ9KctTk4EgNIxxig+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S0tTr169/BEeAPhE79699eWXX9qUffXVV2rRooWfIgIA33B7kFqSfvvtN2VkZGjjxo3auHGjPv30U9WrV0/9+vXzdHwAgBIcO3ZMFotFderU8XcoAFBq27dv14ABA6zLBVOWjRs3TomJiXr99dclSRdccIHNeu+995769+/vqzABAABQSEknGjZv3lwJCQk6cOCAli9fLklKSUlRy5Yt1b59e50+fVovvPCCVq9ebXOl4B133KG+fftqzpw5GjZsmF577TW988472rJli89fHwD4yvTp09WrVy89+uijuvrqq/XRRx9pyZIlWrLEhfsBA0AF5vYgdceOHbV3715FRESob9++uvnmm9W/f3916NDBpfU//vhjBQYGKiYmRpL02muvadmyZWrXrp0SExO5GgYAXHTq1CnNmDFDY8aMKfFeM9nZ2TazXBTcfyInJ0c5OTkubSu4unFax9pWtZCzZX//nVOoTH/XC5b9lETFtukGZ7E6irOEym5v31UVpU9LG2cxFc+26yRWX773ZelTb8Rp066Lferp9740r6ss+vfvL2OK75eSngMAAIB/lHSiYWpqqg4ePKj9+/dbnz99+rTuuusuHThwQKGhoWrfvr3eeustXXbZZdY6vXr10sqVK/XAAw9o5syZatWqlVatWqUePXr47oUBVUjM8zElPr9n3B4fRVKyihJnaXXr1k1r1qxRQkKCHnroIUVHRyslJUXXXnutv0MDKh1n+UQqPzmlsuc+qRSD1Lfccotbg9JF3XrrrZoxY4ZiYmL03Xff6ZprrtGIESP08ssv6+TJk0pJSSlVuwBQleTk5Oiaa65RXl6eFi5cWGLd5ORkJSUl2ZWnpaUpLCzMpe3N7e68zrp16/L/6GR/lmd6zILCFSVJM+vMdL1NNziLtaQ4HVR2e/uuqih9WtY4i1S0/uksVn+896XpU2/EadOui33q6ff+5MmTLtdF+dByxlslPv/9Y0N8FAkAAKgqnJ1omJqaarN8zz336J577nHa7siRIzVy5MiyhgcAFcrQoUM1dOhQf4cBAD7l9iD1b7/9pnPOOceu/K+//tLjjz+uBx98sMT1v/rqK+tUjS+//LL69u2rFStW6P3339c111zDIDUAOJGTk6Orr75a+/bt07vvvlviVdSSlJCQYD2jXcq/kjoqKkqxsbFO1y3QIXGD0zqfJg7O/yO5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AwZ49LUBQE3OnDmj3r17a/Lkybr33nvt1j927JiGDRumBx98UK+++qr27t2r6dOnq3Xr1ub9c3NzNXbsWD399NMaPXq0tm7dqjFjxmjPnj30fwAahf3792v16tW6+eabvZ0KALid04PUo0aNsngeEBCg1q1ba/Dgwerevbvd/e+44w6tX79eTz/9tCTJYDCooqJCzz33nIYMGeJsOmbl5eV6/fXXdebMGUVHR9usU1paqtLSS+shlZSUSJLKyspUVlZW52M7oiq+u4/jj0ICTXbrmNstIPRS2cXHZdXKdLFeiOxPeKjLe2EvV1t51lK5MqadXD35meFzao22AADvu+2227Ry5Ur9+9//1o033qgPP/xQe/bsUWpqqrdTAwCz6dOna/r06Ta3VQ08V9m1a5dDMe+77z7dd9999cwMANwjPj5e8fHxDtdfuXKlOnToYP4Nd9NNN+nAgQN6/vnnzYPUqampio2NVVJSkqTKO1Hs3r1bqampyszMdPlrAABfcvr0ad1///3605/+pAULFng7HQBwO6cHqefOnVuvAz733HMaPHiwDhw4oPPnz+vRRx/VJ598ov/973/au3ev0/EOHTqk6OhonTt3TldddZW2bt2qHj162KybkpKiefPmWZVnZ2fbvLrbHS5fUwzSs7far5OVlVX5oPdqq23GyLTqFSVJc5rPcTymE+zlWlueNipLsp9rXfKsLz6nl5w9e9bbKVi5cOGCkpOT9dprr6moqEjXXHONJk2apCeffFIBAS5bxQEAfMZjjz2mU6dOqXv37goMDFR5ebkWLlyoX//61zXu44rJiUykc/1Eurrm6ek2ret7X0PFypg+9N7bbM/KypUxvfDeW8T1UpsyOREA3Cs3N1dxcXEWZUOHDtWaNWtUVlamoKAg5ebmatasWVZ1apuc6InfffxGaby/USxierFN3XFuIvnWb/4aKlfGdGGevvybLyEhQcOHD9ddd91ld5DaX/u+hnouIbn4e1pZuTJuA/meWsR1EP8v0/D7PoPJZLL/Ll+mvLxcf/vb33TkyBEZDAb16NFD99xzjwIDAx3av6ioSOnp6crLy1NFRYX69eunhIQEXXPNNU6/gPPnz6ugoEA//PCDNm/erJdfflm7d++2OVBtq+Nu3769Tpw4obCwMKeP7YyysjIZjUbFxsYqKCjIrcfyN72Sd9it83Hy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",
      "text/plain": [
       "<Figure size 2400x800 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "plt.rcParams[\"figure.figsize\"] = (24,8)\n",
    "\n",
    "final_stats = torch.load(\"final_stats_ssa_4_exp.pth\")\n",
    "final_stats_diff = torch.load(\"final_stats_ssa_4_exp_diff.pth\")\n",
    "centers = {15:-0.25, 16:-0, 17:0.25}\n",
    "experts = 4\n",
    "\n",
    "fig, axs = plt.subplots(2, 6)\n",
    "for set_size in range(15,18):\n",
    "    vals= []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['overlap']))\n",
    "    axs[0,0].bar(np.arange(6)+centers[set_size], vals, width = 0.2, label=\"|S|=\"+str(set_size))\n",
    "axs[0,0].set_title(\"Overlap bits\")\n",
    "axs[0,0].grid(True)\n",
    "axs[0,0].legend()\n",
    "axs[0,0].set_ylabel(\"Same source network\\nNumber of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals= []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats_diff[set_size][i]['overlap']))\n",
    "    axs[1,0].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,0].set_title(\"Overlap bits\")\n",
    "axs[1,0].grid(True)\n",
    "axs[1,0].set_ylabel(\"Different source networks\\nNumber of bits\")\n",
    "#plt.show()\n",
    "\n",
    "#fig, (axs,axs) = plt.subplots(1, 2)\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['total']))\n",
    "    axs[0,1].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[0,1].set_title(\"Total bits\")\n",
    "axs[0,1].grid(True)\n",
    "#axs[0,1].set_ylabel(\"Number of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats_diff[set_size][i]['total']))\n",
    "    axs[1,1].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,1].set_title(\"Total bits\")\n",
    "axs[1,1].grid(True)\n",
    "#axs[1,1].set_ylabel(\"Number of bits\")\n",
    "#plt.ylim(17,21)\n",
    "#plt.show()\n",
    "\n",
    "#fig, (axs,axs) = plt.subplots(1, 2)\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['extra']))\n",
    "    axs[0,2].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[0,2].set_title(\"Extra bits\")\n",
    "#plt.ylim(15,18)\n",
    "axs[0,2].grid(True)\n",
    "#axs[0,2].set_ylabel(\"Number of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats_diff[set_size][i]['extra']))\n",
    "    axs[1,2].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,2].set_title(\"Extra bits\")\n",
    "#plt.ylim(15,18)\n",
    "axs[1,2].grid(True)\n",
    "#axs[1,2].set_ylabel(\"Number of bits\")\n",
    "#plt.show()\n",
    "\n",
    "#fig, (axs,axs) = plt.subplots(1, 2)\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(np.array(final_stats[set_size][i]['overlap'])/np.array(final_stats[set_size][i]['total'])))\n",
    "    axs[0,3].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[0,3].set_title(\"Overlap bits/Total bits\")\n",
    "axs[0,3].grid(True)\n",
    "#axs[0,3].set_ylabel(\"Number of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(np.array(final_stats_diff[set_size][i]['overlap'])/np.array(final_stats_diff[set_size][i]['total'])))\n",
    "    axs[1,3].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,3].set_title(\"Overlap_bits/Total bits\")\n",
    "axs[1,3].grid(True)\n",
    "#axs[1,3].set_ylabel(\"Number of bits\")\n",
    "#plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.mean([countSetBits(final_stats[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats[set_size][it]['ind_lens']))]))\n",
    "    axs[0,4].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[0,4].set_title(\"Average computations per target\")\n",
    "axs[0,4].grid(True)\n",
    "#axs[0,4].set_ylabel(\"Number of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.mean([countSetBits(final_stats_diff[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats_diff[set_size][it]['ind_lens']))]))\n",
    "    axs[1,4].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,4].set_title(\"Average computations per target\")\n",
    "axs[1,4].grid(True)\n",
    "#axs[1,4].set_ylabel(\"Number of bits\")\n",
    "# plt.ylim(1.5,2.1)\n",
    "# plt.show()\n",
    "\n",
    "#fig, (axs,axs) = plt.subplots(1, 2)\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.sum([countSetBits(final_stats[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats[set_size][it]['ind_lens']))]))\n",
    "    axs[0,5].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[0,5].set_title(\"Average computations over all targets\")\n",
    "axs[0,5].grid(True)\n",
    "#axs[0,5].set_ylabel(\"Number of bits\")\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.sum([countSetBits(final_stats_diff[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats_diff[set_size][it]['ind_lens']))]))\n",
    "    axs[1,5].bar(np.arange(6)+centers[set_size], vals, width = 0.2)\n",
    "axs[1,5].set_title(\"Average computations over all targets\")\n",
    "axs[1,5].grid(True)\n",
    "#axs[1,5].set_ylabel(\"Number of bits\")\n",
    "#plt.ylim(7,9)\n",
    "plt.show()\n",
    "\n",
    "fig.set_size_inches(24, 8)\n",
    "fig.savefig('stats_approaches.png', dpi=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "633bebae-77ae-4b03-b4ff-0aa8ac00ac43",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_9564\\817433149.py:3: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  final_stats = torch.load(\"final_stats_ssa_4_exp_diff.pth\")\n"
     ]
    },
    {
     "data": {
      "image/png": "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UlZWli644AINGjTIe3/Hjh118cUX69NPP1VSUlK5t9jY2IDzlpUZl8vls37RokUVbvPcc8/5LL/44os6ffq0+vfvX6nn/Pn22dnZknTW7cvylbeH50wdOnTQH//4R3Xt2lWffPJJpfIAKB97VIAI1LdvX82fP19TpkxRv379NHHiRLVu3Vp79+7Vk08+qY8++kjz589Xnz59fLY777zzdPXVVysrK0vHjh3TnXfeqTp1fP8/s2jRIqWmpurKK6/UuHHjdMEFF+j7779XXl6ePvnkE7300ksB5+3UqZPatWunadOmybIsNW7cWG+88YZycnIq3OaVV15RVFSUUlJSvO/66d69u0aOHHnO56tXr54ee+wxnThxQr179/a+6yc1NVX9+vWrcLt27dqpfv36eu6559S5c2c1bNhQLVu2VH5+viZOnKhrr71WF198serVq6d3331XW7du1bRp0wKeDwBnsPdcXgChtG7dOuuaa66xzj//fCsqKspq1qyZNWLECGvt2rUVbrNy5UpLkiXJ2r59e7ljPv30U2vkyJFWs2bNLKfTaTVv3tz61a9+ZT399NPeMWXv7NmwYYPf9uW96+fzzz+3UlJSrNjYWOsXv/iFde2111p79+61JFkzZszwjit718+mTZusoUOHWg0bNrRiY2Ot6667zvsOprNJS0uzGjRoYG3dutXq37+/Vb9+fatx48bW73//e+vEiRM+Y3/+rh/Lsqznn3/e6tSpk+V0Or3ZDh06ZI0bN87q1KmT1aBBA6thw4ZWt27drHnz5lmnT58+ZyYAFXNY1n9O/QeAMJCRkaGZM2fqu+++854zAyBycY4KAAAwFkUFAAAYi0M/AADAWOxRAQAAxqKoAAAAY1FUAACAscL6gm+lpaX69ttvFRsbW6nLdAMAAPtZlqXjx4+rZcuWfheV/LmwLirffvutEhIS7I4BAACqYN++feV+HtmZwrqolH2myL59+xQXF2dzmqrzeDxauXKlBg0aJKfTaXecsMLcVQ/zV3XMXdUxd1UXKXNXWFiohISESn02WFgXlbLDPXFxcWFfVGJiYhQXFxfW33h2YO6qh/mrOuau6pi7qou0uavMaRu2n0z7zTff6Prrr1eTJk0UExOjHj16aNOmTXbHAgAABrB1j8rRo0fVt29fDRgwQG+++aaaNWumnTt36rzzzrMzFgAAMISt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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjMAAAGxCAYAAACXwjeMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAApgElEQVR4nO3de3hU9Z3H8c8kJBMuCTxAQqBcjAhUSAAhNgRvQRtsvFSWuoviKrjWy3IndVHMoySKiYBFpEi6rBZC98lircRLqUCKElCgBSQPl1LlDioYuZiQRCYhmf2DMhImk8yZTDLzw/frefI8zJlzTj58PfPw8ZwzMzan0+kUAACAoUICHQAAAKApKDMAAMBolBkAAGA0ygwAADAaZQYAABiNMgMAAIxGmQEAAEajzAAAAKNRZgAAgNEoMwC8YrPZvPpZv359o/vKzs7WO++80+Q8mZmZDa5z+PBh2Ww2vfzyy43ub9myZbLZbDp8+LBrWX5+vhYsWNCknACaX6tABwBghs2bN9d5/MILL+ijjz7Shx9+WGd5//79G91Xdna27r33Xo0aNcqfEZvkzjvv1ObNm9W1a1fXsvz8fO3evVvTpk0LXDAAjaLMAPDKsGHD6jyOjo5WSEiI23JTRUdHKzo6OtAxAPiAy0wA/Ob06dOaMGGCfvSjHyk8PFxXX321MjIy5HA4XOvYbDZVVFQoLy/PdWkqJSVFkvTNN99owoQJ6t+/v9q1a6eYmBjdeuut2rhxY5Ny1dbW6sUXX1TPnj0VERGhxMRErVu3rs46l19mSklJ0apVq3TkyJE6l9Euys3N1aBBg9SuXTtFRkbqxz/+sZ555pkm5QTgG87MAPCLc+fOacSIETpw4ICysrI0cOBAbdy4UTk5OSouLtaqVaskXbhcdeutt2rEiBF69tlnJUlRUVGSLpQhSZo1a5ZiY2NVXl6ugoICpaSkaN26da7SY9WiRYvUq1cvLViwQLW1tZo7d67S0tJUVFSk5OTkerdZvHixHnvsMR04cEAFBQV1nluxYoUmTJigyZMn6+WXX1ZISIj279+vv//97z7lA9A0lBkAfpGXl6edO3fqD3/4g/71X/9VkpSamqp27drpqaeeUmFhoVJTUzVs2DCFhIQoOjra7RJVv379tHjxYtfjmpoa3X777Tp8+LAWLlzoc5mpqalRYWGhIiIiJEm33367rrrqKj333HMqLCysd5v+/furQ4cOstvtbjk/+eQTdejQQQsXLnQtu+2223zKBqDpuMwEwC8+/PBDtW3bVvfee2+d5ePHj5ckt8s6nvz2t7/VkCFDFBERoVatWiksLEzr1q3T3r17fc42evRoV5GRpMjISN19993asGGDampqLO/vJz/5ib799lvdf//9evfdd3Xy5EmfswFoOsoMAL84deqUYmNj69xXIkkxMTFq1aqVTp061eg+5s+fr//8z/9UUlKS3n77bW3ZskVbt27Vz372M3333Xc+Z4uNja13WVVVlcrLyy3v78EHH9Tvfvc7HTlyRL/4xS8UExOjpKQkj2d5ADQvygwAv+jUqZO+/vprOZ3OOstLSkp0/vx5de7cudF9/O///q9SUlKUm5urO++8U0lJSUpMTNTZs2eblO3EiRP1LgsPD1e7du182ufDDz+sTZs2qbS0VKtWrZLT6dRdd92lI0eONCkrAOsoMwD84rbbblN5ebnbh+EtX77c9fxFdru93jMtNptNdru9zrKdO3e6fcaNVStXrtS5c+dcj8+ePav3339fN910k0JDQz1u5ynnpdq2bau0tDRlZGSoqqpKe/bsaVJWANZxAzAAv3jooYf02muvady4cTp8+LASEhL08ccfKzs7W3fccYd++tOfutZNSEjQ+vXr9f7776tr166KjIxUv379dNddd+mFF17QrFmzdMstt+izzz7T888/r7i4OJ0/f97nbKGhoUpNTVV6erpqa2s1Z84clZWVKSsrq8HtEhIStHLlSuXm5mro0KEKCQlRYmKiHn30UbVu3Vo33HCDunbtqhMnTignJ0ft27fX9ddf73NOAL6hzADwi4iICH300UfKyMjQvHnz9M033+hHP/qRnnzySc2aNavOuq+++qomTpyo++67T5WVlbrlllu0fv16ZWRkqLKyUm+88Ybmzp2r/v3767e//a0KCgq8+poETyZNmqRz585pypQpKikp0YABA7Rq1SrdcMMNDW43depU7dmzR88884xKS0vldDrldDp10003admyZfrDH/6gM2fOqHPnzrrxxhu1fPlyPngPCACb8/IL3AAAAAbhnhkAAGA0ygwAADAaZQYAABiNMgMAAIxGmQEAAEajzAAAAKNd8Z8zU1tbq6+++kqRkZFu3xkDAACCk9Pp1NmzZ9WtWzeFhDR87uWK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jmOMiRMn6s4779RPf/rTQEcxyr59+9StWzfFxcXpvvvu08GDBwMdqcUE/dcZ/NCdPHlSNTU1bt8S3qVLF7dvEweag9PpVHp6um688UbFx8cHOo4Rdu3apeTkZJ07d07t2rVTQUGB+vfvH+hYRlixYoU+/fRTbd26NdBRjJKUlKTly5erb9+++vrrrzV79mwNHz5ce/bsUadOnQIdr9lRZgxhs9nqPHY6nW7LgOYwadIk7dy5Ux9//HGgoxijX79+Ki4u1rfffqu3335b48aNU1FREYWmEceOHdPUqVO1du1aRUREBDqOUdLS0lx/TkhIUHJysnr37q28vDylp6cHMFnLoMwEuc6dOys0NNTtLExJSYnb2RrA3yZPnqz33ntPGzZsUPfu3QMdxxjh4eG65pprJEmJiYnaunWrXn31Vf33f/93gJMFt+3bt6ukpERDhw51LaupqdGGDRu0aNEiORwOhYaGBjChOdq2bauEhATt27cv0FFaBPfMBLnw8HANHTpUhYWFdZYXFhZq+PDhAUqFK53T6dSkSZO0cuVKffjhh4qLiwt0JKM5nU45HI5Axwh6t912m3bt2qXi4mLXT2Jioh544AEVFxdTZCxwOBzau3evunbtGugoLYIzMwZIT0/Xgw8+qMTERCUnJ2vJkiU6evSonnjiiUBHC2rl5eXav3+/6/GhQ4dUXFysjh07qmfPngFMFvwmTpyo/Px8vfvuu4qMjHSdGWzfvr1at24d4HTB7ZlnnlFaWpp69Oihs2fPasWKFVq/fr1Wr14d6GhBLzIy0u2+rLZt26pTp07cr9WIJ598Unfffbd69uypkpISzZ49W2VlZRo3blygo7UIyowBxowZo1OnTun555/X8ePHFR8frz//+c/q1atXoKMFtW3btmnEiBGuxxevG48bN07Lli0LUCozXPwYgJSUlDrLly5dqvHjx7d8IIN8/fXXevDBB3X8+HG1b99eAwcO1OrVq5WamhroaLiCffHFF7r//vt18uRJRUdHa9iwYdqyZcsP5t8JPmcGAAAYjXtmAACA0SgzAADAaJQZAABgNMoMAAAwGmUGAAAYjTIDAACMRpkBAABGo8wAAACjUWYAAIDRKDMAAMBolBkAAGC0/wcf3HDUuW1KHAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAGxCAYAAACKvAkXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA69klEQVR4nO3deXhU5d3/8c8EwgQwgUYgIbJFRGSJ7EuwItQmNlgeqFDAWEGrUn8iIKlFA6JB0YgLRGSxVmSpV4RaNisWCCqJC1i2KCBF0EhcEhHURIhMhuT8/qAMDDNZJjPDzHDer+ua68q5577vfOf7TPHznHNmYjEMwxAAAICJhAW6AAAAgAuNAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAATAL5YuXSqLxVLlY8uWLR7tV1ZWpoyMDI/XeeOLL76QxWLRM888U+PcM6/3iy++cIxlZ2crKyvLfwUCqLP6gS4AwMVtyZIluuqqq1zGO3fu7NE+ZWVlmjlzpiRp0KBBvijNp2688UZt3bpVLVu2dIxlZ2dr7969uu+++wJXGAC3CEAA/Kpr167q3bv3Bf+9ZWVlatSo0QX7fc2bN1fz5s0v2O8D4B0ugQEIqBUrVshisWj+/PlO44888ojq1aunnJwcffHFF45wMXPmTMdltNtuu02SlJGRIYvFol27dmnkyJH6xS9+ofbt20uSduzYoTFjxqhdu3Zq2LCh2rVrp5tvvlmHDx+udY2VlZV6/PHH1aZNG0VERKh379566623nOacfwls0KBBWr9+vQ4fPux06e+MRYsWqVu3brrkkksUGRmpq666StOmTfO0fQDqiDNAAPyqoqJCp06dchqzWCyqV6+eJGnMmDHKzc3Vn//8Z/Xv31+9e/fW22+/rVmzZmnatGlKSkqSzWbThg0b9Jvf/EZ33HGH7rzzTklyOeNy0003acyYMbr77rt14sQJSafv4+nYsaPGjBmj6OhoFRUVadGiRerTp48++eQTNWvWrMbXMH/+fLVt21ZZWVmqrKzUU089pZSUFOXm5ioxMdHtmoULF2r8+PH67LPPtGbNGqfnVqxYoXvuuUcTJ07UM888o7CwMB06dEiffPJJ7ZoKwHsGAPjBkiVLDEluH/Xq1XOae/LkSaNHjx5GfHy88cknnxgxMTHGddddZ5w6dcox57vvvjMkGY888ojL73rkkUcMScbDDz9cY12nTp0yjh8/bjRu3Nh47rnnqp1bUFBgSDLi4uKMn3/+2TFeWlpqREdHG7/+9a9dXm9BQYFj7MYbbzTatm3rsu+9995rNG3atMZaAfgPl8AA+NXy5cu1fft2p8eHH37oNMdqteof//iHjh07pp49e8owDL366quOs0S1NWLECJex48eP64EHHtAVV1yh+vXrq379+rrkkkt04sQJ7d+/v1b73nTTTYqIiHAcR0ZGaujQocrLy1NFRYVHNUpS37599eOPP+rmm2/WunXrdPToUY/3AOAdLoEB8KtOnTrV6iboK664Qtdee63Wr1+v//f//p/Tp6lqy92a1NRUvfXWW5oxY4b69OmjqKgoWSwWDRkyRD///HOt9o2NjXU7Vl5eruPHj6tJkyYe1Xnrrbfq1KlT+tvf/qYRI0aosrJSffr00axZs5SUlOTRXgDqhjNAAILCSy+9pPXr16tv376aP3++y1mi2jj3JmNJKikp0RtvvKGpU6fqwQcf1PXXX68+ffooISFB33//fa33LS4udjvWoEEDXXLJJR7XKUm33367PvjgA5WUlGj9+vUyDEO//e1vPbo5G0DdEYAABNyePXs0adIkjR07Vu+++66uvvpqjR49Wj/88INjjtVqlaRan7WRTgciwzAca8946aWXPLp0tXr1ap08edJx/NNPP+lf//qXrr322mov01mt1hrrbdy4sVJSUjR9+nSVl5dr3759ta4LQN1xCQyAX+3du9flU2CS1L59ezVv3lwnTpzQqFGjFB8fr4ULF6pBgwb6xz/+oZ49e+r222/X2rVrJZ2+76Zt27Zat26drr/+ekVHR6tZs2Zq165dlb87KipKAwcO1NNPP+2Ym5ubq8WLF6tp06a1fg316tVTUlKS0tLSVFlZqdmzZ6u0tNTxxYxVSUhI0OrVq7Vo0SL16tVLYWFh6t27t+666y41bNhQ11xzjVq2bKni4mJlZmaqSZMm6tOnT63rAuCFAN+EDeAiVd2nwCQZf/vb3wzDMIw//OEPRqNGjYx9+/Y5rX/ttdcMScbcuXMdY5s3bzZ69OhhWK1WQ5Ixbtw4wzDOfgrsu+++c6njq6++MkaMGGH84he/MCIjI43f/OY3xt69e422bds61lflzKfAZs+ebcycOdNo1aqV0aBB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HiAAAABfIgABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTIQABAADTCWgAysvL09ChQxUXFyeLxaK1a9c6PX/bbbfJYrE4Pfr371/jvqtWrVLnzp1ltVrVuXNnrVmzxk+vAAAAhKKABqATJ06oW7dumj9/fpVzfvOb36ioqMjxePPNN6vdc+vWrRo9erRuvfVWffTRR7r11ls1atQoffjhh74uHwAAhKj6gfzlKSkpSklJqXaO1WpVbGxsrffMyspSUlKS0tPTJUnp6enKzc1VVlaWXn31VbdrbDabbDab47i0tFSSZLfbZbfba/27a8sqq1frXWoKi6h67v+es1c157y9rPUM39bmY0HVu9Mbnq2N3p2d62HvJO/6R++C971H7+qO3vl3T4thGN69Ah+xWCxas2aNhg8f7hi77bbbtHbtWjVo0EBNmzbVddddp8cff1wtWrSocp82bdpoypQpmjJlimNs7ty5ysrK0uHDh92uycjI0MyZM13Gs7Oz1ahRo7q/KAAAcMGUlZUpNTVVJSUlioqKqnZuQM8A1SQlJUW///3v1bZtWxUUFGjGjBn61a9+pZ07d8pqdZ+Mi4uLFRMT4zQWExOj4uLiKn9Penq60tLSHMelpaVq3bq1kpOTa2xgXSRmJ3q1fmvqVueBzFZVzrWHRSgnYZ6S9kxSeOVJ1wnpXzkdds3Y6FVtezNu8Gp9TYKqd5JT/+jdWZ72TvKuf/QueN979K7u6J3nzlzBqY2gDkCjR492/Ny1a1f17t1bbdu21fr163XTTTdVuc5isTgdG4bhMnYuq9XqNlCFh4crPDy8DpVXzyZbzZOq4VJTVW/Wc9dUnnT/pj5vL1tF1X2qDX/061xB1bvTGzp+pHdu1tSyd5J3/aN3wfveo3d1R+/8u2dIfQy+ZcuWatu2rQ4ePFjlnNjYWJezPUeOHHE5KwQAAMwrpALQsWPH9OWXX6ply5ZVzklMTFROTo7T2KZNmzRgwAB/lwcAAEJEQC+BHT9+XIcOHXIcFxQUKD8/X9HR0YqOjlZGRoZGjBihli1b6osvvtC0adPUrFkz/e53v3OsGTt2rC677DJlZmZKkiZPnqyBAwdq9uzZGjZsmNatW6fNmzfrvffeu+CvDwAABKeABqAdO3Zo8ODBjuMzNyKPGzdOixYt0p49e7R8+XL9+OOPatmypQYPHqyVK1cqMjLSsaawsFBhYWdPZA0YMEArVqzQQw89pBkzZqh9+/ZauXKl+vXrd+FeGAAACGoBDUCDBg1SdZ/C37ix5jvMt2zZ4jI2cuRIjRw50pvSAADARSyk7gECAADwBQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHY8D0K5du7Rnzx7H8bp16zR8+HBNmzZN5eXlPi0OAADAHzwOQH/605/06aefSpI+//xzjRkzRo0aNdJrr72mqVOn+rxAAAAAX/M4AH366afq3r27JOm1117TwIEDlZ2draVLl2rVqlW+rg8AAMDnPA5AhmGosrJSkrR582YNGTJEktS6dWsdPXrUt9UBAAD4gccBqHfv3po1a5b+/ve/Kzc3VzfeeKMkqaCgQDExMT4vEAAAwNc8DkBz587Vrl27dO+992r69Om64oorJEn//Oc/NWDAAJ8XCAAA4Gv1PV3QrVs3p0+BnfH000+rfn2PtwMAALjgPD4DdPnll+vYsWMu4ydPntSVV17pk6IAAAD8yeMA9MUXX6iiosJl3Gaz6auvvvJJUQAAAP5U62tWr7/+uuPnjRs3qkmTJo7jiooKvfXWW4qPj/dtdQAAAH5Q6wA0fPhwSZLFYtG4ceOcngsPD1e7du307LPP+rQ4AAAAf6h1ADrz3T/x8fHavn27mjVr5reiAAAA/Mnjj20VFBT4ow4AAIALplYBaN68eRo/frwiIiI0b968audOmjTJJ4UBAAD4S60C0Ny5c3XLLbcoIiJCc+fOrXKexWIhAAEAgKBXqwB07mUvLoEBAIBQ5/H3AJ3LMAwZhlHn9Xl5eRo6dKji4uJksVi0du1ax3N2u10PPPCAEhIS1LhxY8XFxWns2LH65ptvqt1z6dKlslgsLo+TJ0/WuU4AAHBxqVMAWrx4sbp27aqIiAhFRESoa9eueumllzze58SJE+rWrZvmz5/v8lxZWZl27dqlGTNmaNeuXVq9erU+/fRT/d///V+N+0ZFRamoqMjpERER4XF9AADg4uTxp8BmzJihuXPnauLEiUpMTJQkbd26VVOmTNEXX3yhWbNm1XqvlJQUpaSkuH2uSZMmysnJcRp7/vnn1bdvXxUWFqpNmzZV7muxWBQbG1vrOmw2m2w2m+O4tLRU0umzUHa7vdb71JZVVq/Wu9QUVnW4s//vOXtVc87by1qv7mf03NbmY0HVu9Mbnq2N3p2d62HvJO/6R++C971H7+qO3vl3T4vh4TWsZs2a6fnnn9fNN9/sNP7qq69q4sSJOnr0qCfbnS3EYtGaNWscX7jozubNm5WcnKwff/xRUVFRbucsXbpUd955py677DJVVFSoe/fueuyxx9SjR48q983IyNDMmTNdxrOzs9WoUSOPXwsAALjwysrKlJqaqpKSkipzwhkeB6Bf/OIX+s9//qMOHTo4jX/66afq27evfvzxR48LlmoOQCdPntQvf/lLXXXVVXrllVeq3Gfbtm06dOiQEhISVFpaqueee05vvvmmPvroI5eaz3B3Bqh169Y6evRojQ2si8TsRK/Wb03d6jyQ2arKufawCOUkzFPSnkkKr3RzH1S6899v65qx0ava9mbc4NX6mgRV7ySn/tG7szztneRd/+hd8L736F3d0TvPlZaWqlmzZrUKQB5fAvvDH/6gRYsWac6cOU7jL774om655RZPt6sVu92uMWPGqLKyUgsXLqx2bv/+/dW/f3/H8TXXXKOePXvq+eefr/I7jKxWq6xW11ON4eHhCg8P9654N2yy1TypGi41VfVmPXdN5Un3b+rz9rJVWLwpzS/9OldQ9e70ho4f6Z2bNbXsneRd/+hd8L736F3d0Tv/7lmrAJSWlub42WKx6KWXXtKmTZscQWPbtm368ssvNXbsWA9LrZndbteoUaNUUFCgt99+2+MzMmFhYerTp48OHjzo89oAAEBoqlUA2r17t9Nxr169JEmfffaZJKl58+Zq3ry59u3b59PizoSfgwcP6p133tGll17q8R6GYSg/P18JCQk+rQ0AAISuWgWgd955xy+//Pjx4zp06JDjuKCgQPn5+YqOjlZcXJxGjhypXbt26Y033lBFRYWKi4slSdHR0WrQoIEkaezYsbrs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8kqVz1utVlmtrqcaw8PDFR4e7vHvq4lNtponVcOlpqrerOeuqTzp/k193l62Cos3pfmlX+cKqt6d3tDxI71zs6aWvZO86x+9C973Hr2rO3rn3z2DOgAZhqGJEydqzZo12rJli+Lj4+u0z+7du9WyZUsfVwcAAEJVUAegCRMmKDs7W+vWrVNkZKSKi4slSU2aNFHDhg0lSenp6fr666+1fPlySVJWVpbatWunLl26qLy8XK+88opWrVqlVatWBex1AACA4BLUAWjRokWSpEGDBjmNL1myRLfddpskqaioSIWFhY7nysvLdf/99+vrr79Ww4YN1aVLF61fv15Dhgy5UGUDAIAgF9QBqDb3Zy9dutTpeOrUqZo6daqfKgIAABeDoP4maAAAAH8gAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMhAAEAANMJiQC0cOFCxcfHKyIiQr169dK7775b7fzc3Fz16tVLERERuvzyy/XCCy9coEoBAEAoCPoAtHLlSt13332aPn26du/erWuvvVYpKSkqLCx0O7+goEBDhgzRtddeq927d2vatGmaNGmSVq1adYErBwAAwSroA9CcOXN0xx136M4771SnTp2UlZWl1q1ba9GiRW7nv/DCC2rTpo2ysrLUqVMn3XnnnfrjH/+oZ5555gJXDgAAglX9QBdQnfLycu3cuVMPPvig03hycrI++OADt2u2bt2q5ORkp7EbbrhBixcvlt1uV3h4uMsam80mm83mOC4pKZEkff/997Lb7d6+DBf1f/au7ceOHXMeKG9Q5Vx7WAOVlZXpWHkDhVdWutvMubZTJ3xbm48FVe9Ob3i2Nnrn4GnvJO/6R++C971H7+qO3nnup59+kiQZhlHzZCOIff3114Yk4/3333caf/zxx40rr7zS7ZoOHToYjz/+uNPY+++/b0gyvvnmG7drHnnkEUMSDx48ePDgweMieHz55Zc1ZoygPgN0hsVicTo2DMNlrKb5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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pKen37AmoCrgFBhQDRn/PRVSfDrjiSee0KVLl7RmzRprn+XLl8vX11fDhg2TJH399df697//rccee0ySdPXqVeurX79+ys7Otjt98Zvf/Mahek6fPq1x48apefPm8vLykre3t4KCgiRJmZmZdv2Layg2ZMgQeXl5adu2bda27du368yZM3r44YcdqqF47M+PYnXr1k3t27cv8RRhSbZu3ar7779fgYGB8vT0lLe3t6ZNm6bc3FydPn3aoW046le/+pV+8YtflKmGtLQ0FRYWavz48RVWz9atW3XfffepefPmNu2jRo3SxYsX7e5A/PWvf22zXHyksfgIFFCVEYCAKqR+/fry9/fXsWPHbtjv+PHj8vf3V926dSVJd955p+6++24tX75c0rVTaa+//roGDhxo7fP9999Lkp566il5e3vbvKKjoyXJ7pqdJk2a3LTmoqIiRUVFaf369Xr66af1wQcf6OOPP9aePXskXbt4+ucaN25ss+zl5aV69eopNzfX2vbPf/5ToaGhatmy5U1rkGQdW1LNTZs2tdl2aT7++GNFRUVJkv72t79p165d2rdvn6ZOnVrqvpRHSbU6WkPxNVMVeRdXbm5uqfNXvP569erVs1n29fW1qRGoyrgGCKhCPD091adPH7333nv67rvvSvzl9t133+nAgQPq27evzXUWjz/+uKKjo5WZmamjR48qOztbjz/+uHV9/fr1JUnx8fGlHlVp27atzfL1F8yW5siRIzp06JBSUlI0cuRIa/vXX39d6picnBzddttt1uWrV68qNzfX+gu1qKhIGzZs0MSJE2/6/sWKx2ZnZ9vN26lTp6z7fyOrV6+Wt7e33nnnHZs73t58802H63BGSfPraA0NGjSQdO3z8PMjNmVVr149ZWdn27WfOnVKkhyaQ6C64AgQUMXEx8fLMAxFR0ersLDQZl1hYaH++Mc/yjAMxcfH26x79NFH5efnp5SUFKWkpOi2226zHkmQroWb1q1b69ChQwoLCyvxVadOHafrLf4lXvy//2JLliwpdcwbb7xhs/yPf/xDV69etT5YcPfu3crJyXH4FJx07XSSJL3++us27fv27VNmZqbNBeK+vr4lHqWwWCzy8vKyCZaXLl3S3//+d4frKC9Ha4iKipKnp6eSk5NvuL3S9rUk9913n7Zu3WoNPMVWrlwpf39/bptHjcIRIKCK6dmzp5KSkhQTE6N77rlHEyZMUIsWLawPQty7d6+SkpIUERFhM+7WW2/VoEGDlJKSoh9//FFPPfWUPDxs/4+zZMkS9e3bVw888IBGjRql2267TWfPnlVmZqY++eQTrV271ul627Vrp1atWmny5MkyDEN169bV22+/rbS0tFLHrF+/Xl5eXoqMjLTeBXbXXXdpyJAhkq6d/urYsaPatGnjcB1t27bV2LFjtWDBAnl4eKhv377Wu8CaN2+u2NhYa99OnTpp/fr1Sk5OVmhoqDw8PBQWFqb+/ftrzpw5GjZsmMaOHavc3Fy99NJLduHOlRytoWXLlpoyZYpmzZqlS5cu6dFHH1VgYKA+//xznTlzRjNmzLjhvpZk+vTpeuedd9SnTx9NmzZNdevW1RtvvKF3331XL7zwggIDA12+/0Clce812ABKk56ebgwePNho1KiR4eXlZTRs2NB4+OGHjd27d5c6ZsuWLYYkQ5Lx5Zdfltjn0KFDxpAhQ4yGDRsa3t7eRuPGjY1f/epXxuLFi619fn6H1fVKugvs888/NyIjI406deoYv/jFL4zf/va3RlZWlt1dRsV3gR04cMAYMGCAUbt2baNOnTrGo48+ar2jzTAMo3nz5jbjSlJSjYWFhcbzzz9vtGnTxvD29jbq169v/O53vzNOnDhhM/bs2bPG4MGDjVtvvdWwWCzG9f8Uvvbaa0bbtm0NX19f4/bbbzcSExONZcuW2e1zRdwFNn78+BLHOFqDYRjGypUrjbvvvtvw8/MzateubXTp0sVYvny5Q/v6878fwzCMw4cPGwMGDDACAwMNHx8f46677rLZnmH8/11ga9eutWk/duyYIcmuP1AVWQyjDE/3AoAySEhI0IwZM/TDDz+Uej3Jxx9/rO7du+vTTz9Vp06dKrlCAGbBKTAAVUq3bt3K9NRlAHAGF0EDAADT4RQYAAAwHY4AAQAA0yEAAQAA0yEAAQAA0+EusBIUFRXp1KlTqlOnjkNfBQAAANzPMAz99NNPatq0qd2DYH+OAFSCU6dOVdh36wAAgMp14sSJm35RMAGoBMXfh3TixAkFBAS4uZryKSgo0JYtWxQVFSVvb293l1OtMHdlx9yVHXNXdsxd2dWUucvLy1Pz5s0d+l5DAlAJik97BQQE1IgA5O/vr4CAgGr9oXYH5q7smLuyY+7Kjrkru5o2d45cvsJF0AAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHQIQAAAwHTcHoAWLVqk4OBg+fn5KTQ0VDt37iy17/r16xUZGakGDRooICBA4eHh2rx5s02flJQUWSwWu9fly5ddvSsAAKCacGsAWrNmjWJiYjR16lQdPHhQvXr1Ut++fZWVlVVi/x07digyMlKbNm3SgQMH1KdPHw0YMEAHDx606RcQEKDs7Gybl5+fX2XsEgAAqAbc+lUYc+bM0ejRozVmzBhJUlJSkjZv3qzk5GQlJiba9U9KSrJZfvbZZ7Vx40a9/fbb6tKli7XdYrGocePGDteRn5+v/Px863JeXp6ka48GLygocGaXqpzi+qv7frgDc1d2zF3ZMXdlx9yVXU2ZO2fqd1sAunLlig4cOKDJkyfbtEdFRWn37t0ObaOoqEg//fST6tata9N+/vx5BQUFqbCwUCEhIZo1a5ZNQPq5xMREzZgxw659y5Yt8vf3d6iWqi4tLc3dJVRbzF3ZMXdlx9yVHXNXdtV97i5evOhwX7cFoDNnzqiwsFCNGjWyaW/UqJFycnIc2sbLL7+sCxcuaMiQIda2du3aKSUlRZ06dVJeXp7mzZunnj176tChQ2rdunWJ24mPj1dcXJx1ufjbZKOiomrEl6GmpaUpMjKyRnzBXWVi7sqOuSs75q7smLuyqylzV3wGxxFu/zb4n39jq2EYDn2L66pVq5SQkKCNGzeqYcOG1vYePXqoR48e1uWePXuqa9euWrBggebPn1/itnx9feXr62vX7u3tXa0/CNerSftS2Zi7smPuyo65Kzvmruyq+9w5U7vbAlD9+vXl6elpd7Tn9OnTdkeFfm7NmjUaPXq01q5dq/vvv/+GfT08PHT33Xfrq6++KnfNQHXWaUWnco0/PPJwBVUCAO7ntrvAfHx8FBoaane+MS0tTREREaWOW7VqlUaNGqXU1FT179//pu9jGIYyMjLUpEmTctcMAABqBreeAouLi9Pw4cMVFham8PBwLV26VFlZWRo3bpyka9fmnDx5UitXrpR0LfyMGDFC8+bNU48ePaxHj2rVqqXAwEBJ0owZM9SjRw+1bt1aeXl5mj9/vjIyMrRw4UL37CQAAKhy3BqAhg4dqtzcXM2cOVPZ2dnq2LGjNm3apKCgIElSdna2zTOBlixZoqtXr2r8+PEaP368tX3kyJFKSUmRJP34448aO3ascnJyFBgYqC5dumjHjh3q1q1bpe4bAACoutx+EXR0dLSio6NLXFccaop9+OGHN93e3LlzNXfu3AqoDAAA1FRu/yoMAACAykYAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApkMAAgAApuPl7gIAVFMJgaWv8/CT7loqJTaTii6XMv6ca+oCAAdwBAgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJgOAQgAAJiO2wPQokWLFBwcLD8/P4WGhmrnzp2l9l2/fr0iIyPVoEEDBQQEKDw8XJs3b7brt27dOnXo0EG+vr7q0KGDNmzY4MpdAAAA1YxbA9CaNWsUExOjqVOn6uDBg+rVq5f69u2rrKysEvvv2LFDkZGR2rRpkw4cOKA+ffpowIABOnjwoLVPenq6hg4dquHDh+vQoUMaPny4hgwZor1791bWbgEAgCrOy51vPmfOHI0ePVpjxoyRJCUlJWnz5s1KTk5WYmKiXf+kpCSb5WeffVYbN27U22+/rS5dulj7REZGKj4+XpIUHx+v7du3KykpSatWrSqxjvz8fOXn51uX8/LyJEkFBQUqKCgo9366U3H91X0/3KGmzZ2vfMs13m4ePPxK7/vfdQU36KMaMq8VraZ97ioTc1d2NWXunKnfYhiG4cJaSnXlyhX5+/tr7dq1GjRokLV90qRJysjI0Pbt22+6jaKiIrVs2VJPP/20JkyYIElq0aKFYmNjFRsba+03d+5cJSUl6dtvvy1xOwkJCZoxY4Zde2pqqvz9/Z3dNQAA4AYXL17UsGHDdO7cOQUEBNywr9uOAJ05c0aFhYVq1KiRTXujRo2Uk5Pj0DZefvllXbhwQUOGDLG25eTkOL3N+Ph4xcXFWZfz8vLUvHlzRUVF3XQCq7qCggKlpaUpMjJS3t7e7i6nWqlpcxeeGl6u8enD0m0bEpuV2rfAw09pneYr8vBEeRddLrlT/Hflqqemqmmfu8rE3JVdTZm74jM4jnDrKTBJslgsNsuGYdi1lWTVqlVKSEjQxo0b1bBhw3Jt09fXV76+9qcHvL29q/UH4Xo1aV8qW02Zu3zl37zTDdjNQWnB5voxRZdLD0A1YE5dqaZ87tyBuSu76j53ztTutgBUv359eXp62h2ZOX36tN0RnJ9bs2aNRo8erbVr1+r++++3Wde4ceMybRMAAJiH2+4C8/HxUWhoqNLS0mza09LSFBERUeq4VatWadSoUUpNTVX//v3t1oeHh9ttc8uWLTfcJgAAMBe3ngKLi4vT8OHDFRYWpvDwcC1dulRZWVkaN26cpGvX5pw8eVIrV66UdC38jBgxQvPmzVOPHj2sR3pq1aqlwMBASdcuor733nv1/PPPa+DAgdq4caPef/99ffTRR+7ZSQAAUOW49TlAQ4cOVVJSkmbOnKmQkBDt2LFDmzZtUlBQkCQpOzvb5plAS5Ys0dWrVzV+/Hg1adLE+po0aZK1T0REhFavXq3ly5erc+fOSklJ0Zo1a9S9e/dK3z8AAFA1uf0i6OjoaEVHR5e4LiUlxWb5ww8/dGibgwcP1uDBg8tZGQAAqKnc/lUYAAAAlY0ABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATIcABAAATMfL3QUAgCS1nPxumccef65/BVYCwAw4AgQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEyHAAQAAEzHy90FAEBV12lFp3KNPzzycAVVAqCicAQIAACYjtMB6JNPPtHhw///v5mNGzfqoYce0pQpU3TlypUKLQ4AAMAVnA5Af/jDH/Tll19Kko4ePapHHnlE/v7+Wrt2rZ5++ukKLxAAAKCiOR2AvvzyS4WEhEiS1q5dq3vvvVepqalKSUnRunXrKro+AACACud0ADIMQ0VFRZKk999/X/369ZMkNW/eXGfOnKnY6gAAAFzA6QAUFham2bNn6+9//7u2b9+u/v37S5KOHTumRo0aVXiBAAAAFc3pADR37lx98sknmjBhgqZOnao77rhDkvTPf/5TERERFV4gAABARXP6OUB33XWXzV1gxV588UV5efFYIQAAUPU5fQTo9ttvV25url375cuX1aZNmwopCgAAwJWcDkDHjx9XYWGhXXt+fr6+++67CikKAADAlRw+Z/XWW29Z/7x582YFBgZalwsLC/XBBx8oODi4YqsDAABwAYcD0EMPPSRJslgsGjlypM06b29vtWzZUi+//HKFFgcAAOAKDgeg4mf/BAcHa9++fapfv77LigIAAHAlp2/bOnbsmCvqAAAAqDQOBaD58+dr7Nix8vPz0/z582/Yd+LEiRVSGAAAgKs4FIDmzp2rxx57TH5+fpo7d26p/SwWCwEIAABUeQ4FoOtPe3EKDAAAVHdOPwfoeoZhyDCMiqoFAACgUpQpAC1btkwdO3aUn5+f/Pz81LFjR7366qsVXRsAAIBLOB2AnnnmGU2aNEkDBgzQ2rVrtXbtWg0YMECxsbH6y1/+4nQBixYtUnBwsPz8/BQaGqqdO3eW2jc7O1vDhg1T27Zt5eHhoZiYGLs+KSkpslgsdq/Lly87XRsAAKiZnL4NPjk5WX/729/06KOPWtt+/etfq3PnznryySc1e/Zsh7e1Zs0axcTEaNGiRerZs6eWLFmivn376vPPP1eLFi3s+ufn56tBgwaaOnXqDS/GDggI0BdffGHT5ufn53BdAACgZnM6ABUWFiosLMyuPTQ0VFevXnVqW3PmzNHo0aM1ZswYSVJSUpI2b96s5ORkJSYm2vVv2bKl5s2bJ0l67bXXSt2uxWJR48aNHa4jPz9f+fn51uW8vDxJUkFBgQoKChzeTlVUXH913w93qGlz5yvfco23mweP0v9TUfDfdQU36KOfbc/Xs+zXE7r676jC586BvjXlc1eZmLuyqylz50z9FsPJq5iffPJJeXt7a86cOTbtTz31lC5duqSFCxc6tJ0rV67I399fa9eu1aBBg6ztkyZNUkZGhrZv337D8b1791ZISIiSkpJs2lNSUjRmzBjddtttKiwsVEhIiGbNmqUuXbqUuq2EhATNmDHDrj01NVX+/v4O7Q8AAHCvixcvatiwYTp37pwCAgJu2NehI0BxcXHWP1ssFr366qvasmWLevToIUnas2ePTpw4oREjRjhc5JkzZ1RYWKhGjRrZtDdq1Eg5OTkOb+fn2rVrp5SUFHXq1El5eXmaN2+eevbsqUOHDql169YljomPj7fZx7y8PDVv3lxRUVE3ncCqrqCgQGlpaYqMjJS3t7e7y6lWatrchaeGl2t8+rB024bEZqX2LfDwU1qn+Yo8PFHeRaVcfxf/nc1ix4TNZa7tSMIDZR7riKo+d7impv3MVqaaMnfFZ3Ac4VAAOnjwoM1yaGioJOmbb76RJDVo0EANGjTQZ5995vAbF7NYLDbLhmHYtTmjR48e1mAmST179lTXrl21YMGCUp9i7evrK19f+0Pc3t7e1fqDcL2atC+VrabMXb7yb97pBuzmoLRfztePKbpc+i/xn20vv7DsP/eu/vup6nMHWzXlZ9YdqvvcOVO7QwFo27ZtZS6mNPXr15enp6fd0Z7Tp0/bHRUqDw8PD91999366quvKmybAACgeivXgxDLw8fHR6GhoUpLS7NpT0tLU0RERIW9j2EYysjIUJMmTSpsmwAAoHpz+i6wihQXF6fhw4crLCxM4eHhWrp0qbKysjRu3DhJ167NOXnypFauXGkdk5GRIUk6f/68fvjhB2VkZMjHx0cdOnSQJM2YMUM9evRQ69atlZeXp/nz5ysjI8Phi7MBAEDN59YANHToUOXm5mrmzJnKzs5Wx44dtWnTJgUFBUm69uDDrKwsmzHX38114MABpaamKigoSMePH5ck/fjjjxo7dqxycnIUGBioLl26aMeOHerWrVul7RcAAKja3BqAJCk6OlrR0dElrktJSbFru9ld+3Pnzr3hQxIBAAAcugaoa9eu+s9//iNJmjlzpi5evOjSogAAAFzJoQCUmZmpCxcuSLp2jc358+ddWhQAAIArOXQKLCQkRI8//rjuueceGYahl156SbVr1y6x77Rp0yq0QAAAgIrmUABKSUnR9OnT9c4778hisehf//qXvLzsh1osFgIQAACo8hwKQG3bttXq1aslXXuw4AcffKCGDRu6tDAAAABXcfousKKiIlfUAQAAUGnKdBv8N998o6SkJGVmZspisah9+/aaNGmSWrVqVdH1AQAAVDinvwpj8+bN6tChgz7++GN17txZHTt21N69e3XnnXfafa0FAABAVeT0EaDJkycrNjZWzz33nF37n//8Z0VGRlZYcQAAAK7g9BGgzMxMjR492q79iSee0Oeff14hRQEAALiS0wGoQYMG1i8kvV5GRgZ3hgEAgGrB6VNgv//97zV27FgdPXpUERERslgs+uijj/T888/rT3/6kytqBAAAqFBOB6BnnnlGderU0csvv6z4+HhJUtOmTZWQkKCJEydWeIEAAAAVzekAZLFYFBsbq9jYWP3000+SpDp16lR4YQAAAK5SpucAFSP4AID7tZz8brnGH3+ufwVVAlQfTl8EDQAAUN0RgAAAgOkQgAAAgOk4FYAKCgrUp08fffnll66qBwAAwOWcCkDe3t46cuSILBaLq+oBAABwOadPgY0YMULLli1zRS0AAACVwunb4K9cuaJXX31VaWlpCgsL0y233GKzfs6cORVWHAAAgCs4HYCOHDmirl27SpLdtUCcGgMAANWB0wFo27ZtrqgDAACg0pT5Nvivv/5amzdv1qVLlyRJhmFUWFEAAACu5HQAys3N1X333ac2bdqoX79+ys7OliSNGTOGb4MHAADVgtMBKDY2Vt7e3srKypK/v7+1fejQoXrvvfcqtDgAAABXcPoaoC1btmjz5s1q1qyZTXvr1q317bffVlhhAAAAruL0EaALFy7YHPkpdubMGfn6+lZIUQAAAK7kdAC69957tXLlSuuyxWJRUVGRXnzxRfXp06dCiwMAAHAFp0+Bvfjii+rdu7f279+vK1eu6Omnn9Znn32ms2fPateuXa6oEQAAoEI5fQSoQ4cO+vTTT9WtWzdFRkbqwoULevjhh3Xw4EG1atXKFTUCAABUKKePAElS48aNNWPGjIquBQAAoFKUKQD95z//0bJly5SZmSmLxaL27dvr8ccfV926dSu6PgAAgArn9Cmw7du3Kzg4WPPnz9d//vMfnT17VvPnz1dwcLC2b9/uihoBAAAqlNNHgMaPH68hQ4YoOTlZnp6ekqTCwkJFR0dr/PjxOnLkSIUXCQAAUJGcPgL0zTff6E9/+pM1/EiSp6en4uLi9M0331RocQAAAK7gdADq2rWrMjMz7dozMzMVEhJSETUBAAC4lEOnwD799FPrnydOnKhJkybp66+/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IAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDoEIAAAYDpe7i4AqClaTn63XOOPP9e/gioBANwMAQjmlhBY+joPP+mupVJiM6nocinjz7mmLgCASxGAUK10WtGpXOMPjzxcQZUAAKozrgECAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACm4/YAtGjRIgUHB8vPz0+hoaHauXPnDftv375doaGh8vPz0+23367FixfbrE9JSZHFYrF7Xb582ZW7AQAAqhG3BqA1a9YoJiZGU6dO1cGDB9WrVy/17dtXWVlZJfY/duyY+vXrp169eungwYOaMmWKJk6cqHXr1tn0CwgIUHZ2ts3Lz8+vMnYJAABUA17ufPM5c+Zo9OjRGjNmjCQpKSlJmzdvVnJyshITE+36L168WC1atFBSUpIkqX379tq/f79eeukl/eY3v7H2s1gsaty4caXsAwAAqH7cFoCuXLmiAwcOaPLkyTbtUVFR2r17d4lj0tPTFRUVZdP2wAMPaNmyZSooKJC3t7ck6fz58woKClJhYaFCQkI0a9YsdenSpdRa8vPzlZ+fb13Oy8uTJBUUFKigoKBM+1dVFNdf3fejmK98yzXebh48Sj8yWPDfdQU36KPrtufraVRsbRWsKs+dVL75Y+6q9mevstS0f+8qU02ZO2fqtxiGUb6fnDI6deqUbrvtNu3atUsRERHW9meffVYrVqzQF198YTemTZs2GjVqlKZMmWJt2717t3r27KlTp06pSZMm2rNnj77++mt16tRJeXl5mjdvnjZt2qRDhw6pdevWJdaSkJCgGTNm2LWnpqbK39+/AvYWAAC42sWLFzVs2DCdO3dOAQEBN+zr1lNg0rXTVdczDMOu7Wb9r2/v0aOHevToYV3fs2dPde3aVQsWLND8+fNL3GZ8fLzi4uKsy3l5eWrevLmioqJuOoFVXUFBgdLS0hQZGWk9QladhaeGl2t8+rB024bEZqX2LfDwU1qn+Yo8PFHeRaVc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v/xFzzzzjFq1aqU1a9aoe/fulb5/VYGvr6+mT59ud4oPN8fclR1zV3bMXdkxd2VnxrmzGIYj94oBAADUHG7/KgwAAIDKRgACAACmQwACAACmQwACAACmQwACAACmQwCqwRYtWqTg4GD5+fkpNDRUO3fudHdJ1cKOHTs0YMAANW3aVBaLRW+++aa7S6oWEhMTdffdd6tOnTpq2LChHnroIX3xxRfuLqtaSE5OVufOna1P4Q0PD9e//vUvd5dVLSUmJspisSgmJsbdpVQLCQkJslgsNq/GjRu7u6xKQQCqodasWaOYmBhNnTpVBw8eVK9evdS3b1+b5yqhZBcuXNBdd92lV155xd2lVCvbt2/X+PHjtWfPHqWlpenq1auKiorShQvl+8ZoM2jWrJmee+457d+/X/v379evfvUrDRw4UJ999pm7S6tW9u3bp6VLl6pz587uLqVaufPOO5WdnW19HT582N0lVQqeA1RDde/eXV27dlVycrK1rX379nrooYeUmJjoxsqqF4vFog0bNuihhx5ydynVzg8//KCGDRtq+/btuvfee91dTrVTt25dvfjiixo9erS7S6kWzp8/r65du2rRokWaPXu2QkJClJSU5O6yqryEhAS9+eabysjIcHcplY4jQDXQlStXdODAAUVFRdm0R0VFaffu3W6qCmZz7tw5Sdd+kcNxhYWFWr16tS5cuKDw8HB3l1NtjB8/Xv3799f999/v7lKqna+++kpNmzZVcHCwHnnkER09etTdJVUKt34VBlzjzJkzKiwsVKNGjWzaGzVqpJycHDdVBTMxDENxcXG655571LFjR3eXUy0cPnxY4eHhunz5smrXrq0NGzaoQ4cO7i6rWli9erU++eQT7du3z92lVDvdu3fXypUr1aZNG33//feaPXu2IiIi9Nlnn6levXruLs+lCEA1mMVisVk2DMOuDXCFCRMm6NNPP+VLiJ3Qtm1bZWRk6Mcff9S6des0cuRIbd++nRB0EydOnNCkSZO0ZcsW+fn5ubucaqdv377WP3fq1Enh4eFq1aqVVqxYobi4ODdW5noEoBqofv368vT0tDvac/r0abujQkBFe/LJJ/XWW29px44datasmbvLqTZ8fHx0xx13SJLCwsK0b98+zZs3T0uWLHFzZVXbgQMHdPr0aYWGhlrbCgsLtWPHDr3yyivKz8+Xp6enGyusXm655RZ16tRJX331lbtLcTmuAaqBfHx8FBoaqrS0NJv2tLQ0RUREuKkq1HSGYWjChAlav369tm7dquDgYHeXVK0ZhqH8/Hx3l1Hl3XfffTp8+LAyMjKsr7CwMD322GPKyMgg/DgpPz9fmZmZatKkibtLcTmOANVQcXFxGj58uMLCwhQeHq6lS5cqKytL48aNc3dpVd758+f19ddfW5ePHTumjIwM1a1bVy1atHBjZVXb+PHjlZqaqo0bN6pOnTrWI5CBgYGqVauWm6ur2qZMmaK+ffuqefPm+umnn7R69Wp9+OGHeu+999xdWpVXp04du+vMbrnlFtWrV4/rzxzw1FNPacCAAWrRooVOnz6t2bNnKy8vTyNHjnR3aS5HAKqhhg4dqtzcXM2cOVPZ2dnq2LGjNm3apKCgIHeXVuXt379fffr0sS4XnwcfOXKkUlJS3FRV1Vf8yIXevXvbtC9fvlyjRo2q/IKqke+//17Dhw9Xdna2AgMD1blzZ7333nuKjIx0d2mo4b777js9+uijOnPmjBo0aKAePXpoz549pvhdwXOAAACA6XANEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMB0CEAAAMJ3/A44lH48X+dsGAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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3/sJDQ21P5+nQoUKCggIcBgrX768QkJCnNYvX768Lly44DReq1atfMeufa3iGjhwoN59910NGTJEq1ev1nfffaeNGzeqRo0abp8AfuLECfn6+qpGjRoO4zabLd/3cO3PU5L8/f0dXn/q1KkaNWqUli1bpq5duyokJER9+/a1B/TruV4/jxw5IulKKLj2c/Taa6/JGKOTJ086rJ/f58EVubm5io6O1pIlSzRy5Eh99dVX+u677/Ttt99KUr79v/Y1b9TvCazN9/pTgNJj1qxZMsbok08+0SeffOL0/Ny5czVx4kT5+PhowIABiouL05w5c/Tyyy/rww8/VN++fR32vFSvXl2BgYEOoehq1atXd1i22WxOcz7++GP5+flp+fLlDgFg2bJlDvPy/mE+cuSI6tSpYx+/dOmS0x/H6tWrq2XLlnr55ZfzrSs0NDTfcUn2P8C///67wsLC8p2TV0tGRobTc4cOHXJ6355w+PDhfMcaNmxoXw4ICFB2drbTvOPHjxeppszMTC1fvlwTJkzQ6NGj7ePZ2dlOf8hdUa1aNV26dEnHjh1zCDjGGB0+fFi33nqry9usWLGiEhISlJCQoCNHjtj34tx99932QF6Y6/Uzr1/vvPOO2rdvn+82rg0Q+X2+XbFjxw798MMPmjNnjmJiYuzje/bsKXCda1/zRv2ewNoINygzLl++rLlz56pBgwaaOXOm0/PLly/Xm2++qZUrV6pPnz6qWrWq+vbtq3nz5ikqKkqHDx92OCQlSX369NErr7yiatWqKSIiwq26bDabfH195ePjYx87f/68PvzwQ4d5nTt3liQtXLhQbdu2tY9/8sknunTpklNdK1asUIMGDfI9DFaY6Oho+fj4aNq0aYqKisp3TlRUlAIDAzV//nzdd9999vHff/9da9asse8J86SPPvrI4RDEhg0btG/fPg0ZMsQ+Vr9+fW3bts1hvZ9++km7d+92CDf+/v6SnPcE2Gw2GWPsz+eZOXOmLl++7DBW0Dbyc+edd+r111/X/PnzFRsbax9fvHixsrKydOedd153G4W56aabNGjQIP3www9KTEzUuXPnVKFChULXuV4/O3bsqCpVqmjXrl168skni1XftQrr/9XP5/nggw+KvO2S+D1x5WcNayDcoMxYuXKlDh06pNdee01dunRxer558+Z69913lZSUpD59+ki6cmhq4cKFevLJJ1W3bl3dddddDus888wzWrx4sTp37qzY2Fi1bNlSubm52r9/v5KTk/Xss8/q9ttvL7Su3r17a8qUKRo4cKAef/xxnThxQpMnT3b6B75Zs2YaMGCA3nzzTfn4+Khbt27auXOn3nzzTQUHB6tcuf8/Svziiy8qJSVFHTp00IgRI9SkSRNduHBBv/32m1asWKHp06cXeNipfv36Gjt2rF566SWdP39eAwYMUHBwsHbt2qXjx48rISFBVapU0fjx4zV27Fg9/PDDGjBggE6cOKGEhAQFBARowoQJRfmRuGTTpk0aMmSI7rvvPh04cEDjxo1TnTp1NGzYMPuchx56SA8++KCGDRumfv36ad++fXr99dedDgc1aNBAgYGB+uijj9S0aVNVqlRJoaGhCg0NVefOnfXGG2+oevXqql+/vlJTU5WUlKQqVao4bCPvztYzZsxQUFCQAgICFBERke8hpe7du6tHjx4aNWqUTp8+rY4dO2rbtm2aMGGC2rRpo4ceesjlftx+++3q06ePWrZsqapVqyo9PV0ffvihoqKirhtsitLPSpUq6Z133lFMTIxOnjypv/3tb6pZs6aOHTumH374QceOHdO0adNcrlsquHd/+tOf1KBBA40ePVrGGIWEhOjzzz9XSkpKkbddEr8nQUFBCg8P16effqo777xTISEh9s8HLMqLJzMDLunbt68pX768/ZLT/PTv39/4+vqaw4cPG2OuXBkSFhZmJJlx48blu87Zs2fN888/b5o0aWLKly9vgoODTYsWLUxsbKx9O8b8/31u8jNr1izTpEkT4+/vb26++WYzadIkk5SUZCSZvXv32ufl3b+jZs2aJiAgwLRv396kpaWZ4OBgh3vvGHPlCo8RI0aYiIgI4+fnZ0JCQkxkZKQZN26c0z148jNv3jxz6623moCAAFOpUiXTpk0bp6uLZs6caVq2bGl/3/fcc4/TlVh597m51h133GGaNWvmNJ53n5c8V9+X5aGHHjJVqlSxX6n1888/O6ybm5trXn/9dXPzzTebgIAA065dO7NmzRqnq6WMuXL1TN79hnTVlTC///676devn/2eQ3/5y1/Mjh078r0SKzEx0URERBgfH58i3edm1KhRJjw83Pj5+ZnatWub//7v/y7wPjf59evq9zB69GjTrl07U7VqVfvnJjY21hw/ftxp3au50k9j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ACyJLx11X1nvHefcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAAS/FquFm3bp3uvvtuhYaGymazadmyZYXOX7t2rWw2m9Pjxx9/vDEFAwCAUs/lcPP9999r+/bt9uVPP/1Uffv21dixY3Xx4kWXtpWVlaVWrVrp3XffdWm93bt3KyMjw/5o1KiRS+sDAADrcjncPPHEE/rpp58kSb/++qv69++vChUqaNGiRRo5cqRL2+rZs6cmTpyoe++916X1atasqVq1atkfPj4+Lq0PAACsy9fVFX766Se1bt1akrRo0SJ17txZCxYs0Pr169W/f38lJiZ6uERnbdq00YULF3TLLbfo+eefV9euXQucm52drezsbPvy6dOnJUk5OTnKycnxeG3+8i/W+k41lQsoeO7/PZdTyBxdsz1/H+O52jyM3rnPyr27srmS6x+9cx+9cx+9K9lt2owxLr2DypUra/PmzWrUqJG6d++uPn366Omnn9b+/fvVpEkTnT9/3uWCJclms2np0qXq27dvgXN2796tdevWKTIyUtnZ2frwww81ffp0rV27Vp07d853nfj4eCUkJDiNL1iwQBUqVHCrVgAAcGOdO3dOAwcOVGZmpipXrlzoXJfDTbdu3RQWFqa77rpLgwcP1q5du9SwYUOlpqYqJiZGv/32m1tFFyXc5Ofuu++WzWbTZ599lu/z+e25CQsL0/Hjx6/bHHdELYgq1vppA9McBybVLXBuTrkApbSYqu7bR8gv90L+k8b87rDYPH6127XtiO/h9rpFQe/cZ+XeSSXbP3rn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5MiRN6AqAABQVnn96xcAAAA8iXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAsxevh5v3331dERIQCAgIUGRmpb775ptD5qampioyMVEBAgG6++WZNnz79BlUKAADKAq+Gm4ULF+qZZ57RuHHjtGXLFnXq1Ek9e/bU/v37852/d+9e9erVS506ddKWLVs0duxYjRgxQosXL77BlQMAgNLKq+FmypQpGjx4sIYMGaKmTZsqMTFRYWFhmjZtWr7zp0+frnr16ikxMVFNmzbVkCFD9Oijj2ry5Mk3uHIAAFBa+XrrhS9evKjNmzdr9OjRDuPR0dHasGFDvuukpaUpOjraYaxHjx5KSkpSTk6O/Pz8nNbJzs5Wdna2fTkzM1OSdPLkSeXk5BT3bTjxPV+8lp44ccJx4GL5AufmlCuvc+fO6cTF8vLLzS1og471XcryXG0eRu/cZ+Xe5VufB9E799E799E71505c0aSZIy5/mTjJQcPHjSSzPr16x3GX375ZdO4ceN812nUqJF5+eWXHcbWr19vJJlDhw7lu86ECROMJB48ePDgwYOHBR4HDhy4bsbw2p6bPDabzWHZGOM0dr35+Y3nGTNmjOLi4uzLubm5OnnypKpVq1bo65QFp0+fVlhYmA4cOKDKlSt7u5wyhd65j965j965j965zyq9M8bozJkzCg0Nve5cr4Wb6tWry8fHR4cPH3YYP3r0qG666aZ816lVq1a+8319fVWtWrV81/H395e/v7/DWJUqVdwvvBSqXLlymf7AehO9cx+9cx+9cx+9c58VehccHFykeV47obh8+fKKjIxUSkqKw3hKSoo6dOiQ7zpRUVFO85OTk9WuXbt8z7cBAAB/PF69WiouLk4zZ87UrFmzlJ6ertjYWO3fv19Dhw6VdOWQ0sMPP2yfP3ToUO3bt09xcXFKT0/XrFmzlJSUpOeee85bbwEAAJQyXj3n5v7779eJEyf04osvKiMjQ82bN9eKFSsUHh4uScrIyHC4501ERIRWrFih2NhYvffeewoNDdXUqVPVr18/b70Fr/L399eECROcDrvh+uid++id++id++id+/6IvbMZU5RrqgAAAMoGr3/9AgAAgCcRbgAAgKUQbgAAgKUQbgAAgKUQbgAAgKUQbsqo999/XxEREQoICFBkZKS++eYbb5dUJqxbt0533323QkNDZbPZtGzZMm+XVCZMmjRJt956q4KCglSzZk317dtXu3fv9nZZZca0adPUsmVL+x1io6KitHLlSm+XVeZMmjRJNptNzzzzjLdLKRPi4+Nls9kcHrVq1fJ2WTcE4aYMWrhwoZ555hmNGzdOW7ZsUadOndSzZ0+HewIhf1lZWWrVqpXeffddb5dSpqSmpmr48OH69ttvlZKSokuXLik6OlpZWcX75uA/irp16+rVV1/Vpk2btGnTJnXr1k333HOPdu7c6e3SyoyNGzdqxowZatmypbdLKVOaNWumjIwM+2P79u3eLumG4D43ZdDtt9+utm3batq0afaxpk2bqm/fvpo0aZIXKytbbDabli5dqr59+3q7lDLn2LFjqlmzplJTU9W5c2dvl1MmhYSE6I033tDgwYO9XUqpd/bsWbVt21bvv/++Jk6cqNatWysxMdHbZZV68fHxWrZsmbZu3ertUm449tyUMRcvXtTmzZsVHR3tMB4dHa0NGzZ4qSr80WRmZkq68gcarrl8+bI+/vhjZWVlKSoqytvllAnDhw9X7969ddddd3m7lDLn559/VmhoqCIiItS/f3/9+uuv3i7phvDq1y/AdcePH9fly5edvjn9pptucvrGdKAkGGMUFxenP//5z2revLm3yykztm/frqioKF24cEGVKlXS0qVLdcstt3i7rFLv448/1vfff6+NGzd6u5Qy5/bbb9e8efPUuHFjHTlyRBMnTlSHDh20c+dOVatWzdvllSjCTRlls9kclo0xTmNASXjyySe1bds2/etf//J2KWVKkyZNtHXrVv3nP//R4sWLFRMTo9TUVAJOIQ4cOKCnn35aycnJCggI8HY5ZU7Pnj3t/92iRQtFRUWpQYMGmjt3ruLi4rxYWckj3JQx1atXl4+Pj9NemqNHjzrtzQE87amnntJnn32mdevWqW7dut4up0wpX768GjZsKElq166dNm7cqLffflsffPCBlysrvTZv3qyjR48qMjLSPnb58mWtW7dO7777rrKzs+Xj4+PFCsuWihUrqkWLFvr555+9XUqJ45ybMqZ8+fKKjIxUSkqKw3hKSoo6dOjgpapgdcYYPfnkk1qyZInWrFmjiIgIb5dU5hljlJ2d7e0ySrU777xT27dv19atW+2Pdu3a6YEHHtDWrVsJNi7Kzs5Wenq6ateu7e1SShx7bsqguLg4PfTQQ2rXrp2ioqI0Y8YM7d+/X0OHDvV2aaXe2bNntWfPHvvy3r17tXXrVoWEhKhevXperKx0Gz58uBYsWKBPP/1UQUFB9j2HwcHBCgwM9HJ1pd/YsWPVs2dPhYWF6cyZM/r444+1du1arVq1ytullWpBQUFO53VVrFhR1apV43yvInjuued09913q169ejp69KgmTpyo06dPKyYmxtullTjCTRl0//3368SJE3rxxReVkZGh5s2ba8WKFQoPD/d2aaXepk2b1LVrV/ty3nHnmJgYzZkzx0tVlX55tx3o0qWLw/js2bM1aNCgG19QGXPkyBE99NBDysjIUHBwsFq2bKlVq1ape/fu3i4NFvb7779rwIABOn78uGrUqKH27dvr22+//UP8reA+NwAAwFI45wYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFjK/wL1YEpUG503UQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAGxCAYAAABMeZ2uAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA4VElEQVR4nO3dd3RUZf7H8c+kVwIhIC1ChAWRABGCGFCkCCxLWGNhpUiJqKyiNAttgQTRUASBVWGRviviAQQVBZIVKWpYAwtSRNFVAaW3AAFCSJ7fH/4yMkwCmWTCXOD9OifnMM889+Z7v7nJfLhlxmaMMQIAALAgL08XAAAAUBiCCgAAsCyCCgAAsCyCCgAAsCyCCgAAsCyCCgAAsCyCCgAAsCyCCgAAsCyCCgAAsCyCClwybdo02Ww2RUdHe7oUXGP79+9XUlKStm7dWux1fPPNN0pKStLPP//s9Fzv3r1Vo0aNYq8brimo3zVq1FDv3r2vuuyrr76q5cuXl0pdpWHhwoWaMmWKp8tAMRFU4JI5c+ZIknbu3Kn//Oc/Hq4G19L+/fuVnJxc4qCSnJxcYFAZOXKkli1bVvwCcc0QVHAtEVRQZJs2bdLXX3+tjh07SpJmz559zWswxujcuXPX/Pui9NWsWVN33nmnp8uwvNzcXGVnZ3u6DLe7UbcLJUdQQZHlB5Nx48apWbNmWrRokc6ePStJysnJUcWKFdWjRw+n5U6ePKnAwEANHjzYPnbq1Cm98MILioqKkp+fn6pWraqBAwcqKyvLYVmbzaZnn31WM2bMUN26deXv76/58+dLkpKTk9W0aVOFh4erTJkyatSokWbPnq3LP2czOztbzz//vCpVqqSgoCC1aNFCmzdvLvAw98GDB9W3b19Vq1ZNfn5+ioqKUnJysi5evFikHi1cuFBxcXEKCQlRSEiIYmJinALdnDlz1LBhQwUEBCg8PFwPPvigdu3a5TCnd+/eCgkJ0bfffqv27dsrODhYlStX1rhx4yRJGzdu1D333KPg4GDVrl3b3pN88+bNk81mU1pamhITExUeHq7g4GB16tRJP/74o8Pcwg73t2zZUi1btpQkrV27Vk2aNJEkJSYmymazyWazKSkpSdJvIbZLly6qUaOGAgMDVaNGDXXt2lV79uxxqKlz586SpFatWtnXMW/ePPs2X34q4vz58xo2bJjDftKvXz+dPHnSaRvi4+O1atUqNWrUSIGBgbr99tvtRwDznT171r7f5fc/NjZW7777rtP2X27Hjh164IEHVK5cOQUEBCgmJsah70eOHJGfn59GjhzptOy3334rm82madOm2ceKsq/9/PPPstlsmjBhgsaOHauoqCj5+/vrs88+K7TON998Uy1atFDFihUVHBys+vXra8KECcrJybnqNhaFzWZTVlaW5s+fb/8Z5u8nR44c0TPPPKM77rhDISEhqlixolq3bq0NGzY4rONq2/XBBx+oQYMG8vf312233aapU6cqKSlJNpvNYT3GGL311luKiYlRYGCgypUrp0ceecRhH2/ZsqU+/vhj7dmzx17vpeuZPn26GjZsqJCQEIWGhur222/X8OHD3dIruIkBiuDs2bMmLCzMNGnSxBhjzKxZs4wkM2/ePPucQYMGmcDAQJOZmemw7FtvvWUkmW3bthljjMnKyjIxMTEmIiLCTJ482fz73/82U6dONWFhYaZ169YmLy/PvqwkU7VqVdOgQQOzcOFCs2bNGrNjxw5jjDG9e/c2s2fPNmlpaSYtLc28/PLLJjAw0CQnJzt8/65duxovLy8zdOhQk5qaaqZMmWIiIyNNWFiY6dWrl33egQMHTGRkpKlevbr5xz/+Yf7973+bl19+2fj7+5vevXtftUcjR440ksxDDz1kFi9ebFJTU83kyZPNyJEj7XNeffVVI8l07drVfPzxx2bBggXmtttuM2FhYWb37t32eb169TJ+fn6mbt26ZurUqSYtLc0kJiYaSWbYsGGmdu3aZvbs2Wb16tUmPj7eSDKbNm2yLz937lwjyURGRprHH3/crFy50sycOdNUrFjRREZGmhMnTtjnVq9e3aEP+e677z5z3333GWOMyczMtK/zb3/7m0lPTzfp6elm3759xhhjFi9ebEaNGmWWLVtm1q1bZxYtWmTuu+8+U6FCBXPkyBFjjDGHDx+2b/+bb75pX8fhw4ft21y9enX798/LyzPt27c3Pj4+ZuTIkSY1NdW89tprJjg42Nx5553m/PnzDttQrVo1c8cdd5gFCxaY1atXm86dOxtJZt26dfZ5ffv2NUFBQWby5Mnms88+MytWrDDjxo0zf//736/4s/32229NaGioqVmzplmwYIH5+OOPTdeuXY0kM378ePu8Bx980ERGRprc3FyH5V966SXj5+dnjh49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6qWff/65yOvy8/NTbGysvvzyS/tY//79lZGRofT0dKf5BR1RiYyM1NGjR6+6ocURtzCuRMund7tkG1KqFTovxytAafWnqe32/vLNO1/wpGG/ODyMTlpdotp2JLUv0fJX49beSYX2j945K2rvJNf7R+9+d633PXpn3X2P3rnu1KlTioiIKFJQcfnUz+uvv67HHntMy5cv14gRI1SrVi1J0pIlS9SsWTOX1lW5cmXdcccdDmN169bV0qVLC5zv7+8vf3/nQ2y+vr7y9fV16XsXRbayrz7pChxqKmyHunR+3vnCd7zLti8711aS0kqlX5dya++kq/aP3v3O1d5JRe8fvStgmWu079E76+579K501+lyUGnYsKHDXT/5Jk6cKB8f11bXvHlzfffddw5ju3fvVvXq1V0tCwAA3IBcvuvntttu07Fjx5zGz58/r9q1a7u0rkGDBmnjxo169dVX9cMPP2jhwoWaOXOm+vXr52pZAADgBuRyUPn555+Vm5vrNJ6dna1ffvmlgCUK16RJEy1btkzvvvuuoqOj9fLLL2vKlCnq3r27q2UBAIAbUJHP1Xz44Yf2f69evVphYWH2x7m5ufr0008VFRXlcgHx8fGKj493eTkAAHDjK3JQSUhIkCTZbDb16tXL4TlfX1/VqFFDkyZNcmtxAADg5lbkoJKXlydJioqKUkZGhiIiIkqtKAAAAKkYd/389NNPpVEHAACAkyIFlWnTpumpp55SQECApk2bdsW5/fv3d0thAAAARQoqr7/+urp3766AgAC9/vrrhc6z2WwEFQAA4DZFCiqXnu7h1A8AALhWXH4flUsZY+TiRwUBAAAUWbGCyuzZsxUdHa2AgAAFBAQoOjpas2bNcndtAADgJufyXT8jR47U66+/rueee05xcb99YmR6eroGDRqkn3/+WWPHjnV7kQAA4ObkclCZPn263n77bXXt2tU+9uc//1kNGjTQc889R1ABAABu4/Kpn9zcXMXGxjqNN27cWBcvXnRLUQAAAFIxgspjjz2m6dOnO43PnDmTDxMEAABuVaRTP4MHD7b/22azadasWUpNTdXdd98tSdq4caP27dunnj17lk6VAADgplSkoLJlyxaHx40bN5Yk/e9//5MkVahQQRUqVNDOnTvdXB4AALiZFSmofPbZZ6VdBwAAgJMSveEbAABAaSKoAAAAyyKoAAAAyyKoAAAAyypSUGnUqJFOnDghSRozZozOnj1bqkUBAABIRQwqu3btUlZWliQpOTlZZ86cKdWiAAAApCLenhwTE6PExETdc889MsbotddeU0hISIFzR40a5dYCAQDAzatIQWXevHkaPXq0VqxYIZvNppUrV8rHx3lRm81GUAEAAG5TpKBSp04dLVq0SJLk5eWlTz/9VBUrVizVwgAAAIoUVC6Vl5dXGnUAAAA4cTmoSL99xs+UKVO0a9cu2Ww21a1bVwMGDFDNmjXdXR8AALiJufw+KqtXr9Ydd9yhr776Sg0aNFB0dLT+85//qF69ekpLSyuNGgEAwE3K5SMqQ4cO1aBBgzRu3Din8SFDhqht27ZuKw4AANzcXD6ismvXLvXp08dp/PHHH9c333zjlqIAAACkYgSVChUqaOvWrU7jW7du5U4gAADgVi6f+nnyySf11FNP6ccff1SzZs1ks9n0+eefa/z48Xr++edLo0YAAHCTcjmojBw5UqGhoZo0aZKGDRsmSapSpYqSkpLUv39/txcIAABuXi4HFZvNpkGDBmnQoEE6ffq0JCk0NNTthQEAABTrfVTyEVAAAEBpcvliWgAAgGuFoAIAACyLoAIAACzLpaCSk5OjVq1aaffu3aVVDwAAgJ1LQcXX11c7duyQzWYrrXoAAADsXD7107NnT82ePbs0agEAAHDg8u3JFy5c0KxZs5SWlqbY2FgFBwc7PD958mS3FQcAAG5uLgeVHTt2qFGjRpLkdK0Kp4QAAIA7uRxUPvvss9KoAwAAwEmxb0/+4YcftHr1ap07d06SZIxxW1EAAABSMYLKsWPH1KZNG9WuXVt/+tOfdODAAUnSE088wacnAwAAt3I5qAwaNEi+vr7au3evgoKC7OOPPvqoVq1a5dbiAADAzc3la1RSU1O1evVqVatWzWH8D3/4g/bs2eO2wgAAAFw+opKVleVwJCXf0aNH5e/v75aiAAAApGIElRYtWmjBggX2xzabTXl5eZo4caJatWrl1uIAAMDNzeVTPxMnTlTLli21adMmXbhwQS+99JJ27typ48eP64svviiNGgEAwE3K5SMqd9xxh7Zt26a77rpLbdu2VVZWlh566CFt2bJFNWvWLI0aAQDATcrlIyqSVKlSJSUnJ7u7FgAAAAfFCionTpzQ7NmztWvXLtlsNtWtW1eJiYkKDw93d30AAOAm5vKpn3Xr1ikqKkrTpk3TiRMndPz4cU2bNk1RUVFat25dadQIAABuUi4fUenXr5/+8pe/aPr06fL29pYk5ebm6plnnlG/fv20Y8cOtxcJAABuTi4fUfnf//6n559/3h5SJMnb21uDBw/W//73P7cWBwAAbm4uB5VGjRpp165dTuO7du1STEyMO2oCAACQVMRTP9u2bbP/u3///howYIB++OEH3X333ZKkjRs36s0339S4ceNKp0oAAHBTKlJQiYmJkc1mkzHGPvbSSy85zevWrZseffRR91UHAABuakUKKj/99FNp1wEAAOCkSEGlevXqpV0HAACAk2K94duvv/6qL774QocPH1ZeXp7Dc/3793dLYQAAAC4Hlblz5+qvf/2r/Pz8VL58edlsNvtzNpuNoAIAANzG5aAyatQojRo1SsOGDZOXl8t3NwMAABSZy0nj7Nmz6tKlCyEFAACUOpfTRp8+fbR48eLSqAUAAMCBy6d+UlJSFB8fr1WrVql+/fry9fV1eH7y5MnFKiQlJUXDhw/XgAEDNGXKlGKtAwAA3FhcDiqvvvqqVq9erTp16kiS08W0xZGRkaGZM2eqQYMGxVoeAADcmFwOKpMnT9acOXPUu3dvtxRw5swZde/eXW+//bbGjh3rlnUCAIAbg8tBxd/fX82bN3dbAf369VPHjh11//33XzWoZGdnKzs72/741KlTkqScnBzl5OS4raZ8/vIv0fIONXkFFD7v/5/LucIcXbZ9/t6mkInFqK0UuLV3UqH9o3fOito7yfX+0btL5l7jfY/eWXffo3elu06bufQDfIogJSVFBw4c0LRp01wu7HKLFi3SK6+8ooyMDAUEBKhly5aKiYkp9BqVpKQkJScnO40vXLhQQUFBJa4HAACUvrNnz6pbt27KzMxUmTJlrjjX5aDy4IMPas2aNSpfvrzq1avndDHt+++/X6T17Nu3T7GxsUpNTVXDhg0l6apBpaAjKpGRkTp69OhVN7Q44hbGlWj59G7pvz9IqVbovByvAKXVn6a22/vLN+98wZOG/eLwMDppdYlq25HUvkTLX41beycV2j9656yovZNc7x+9+9213vfonXX3PXrnulOnTikiIqJIQcXlUz9ly5bVQw89VOzi8m3evFmHDx9W48aN7WO5ublav3693njjDWVnZ8vb29thGX9/f/n7Ox9i8/X1dQpM7pCt7KtPugKHmgrboS6dn3e+8B3vsu3Lzi3ehcu/r879/bqUW3snXbV/9O53rvZOKnr/6F0By1yjfY/eWXffo3elu85ivYW+O7Rp00bbt293GEtMTNTtt9+uIUOGOIUUAABw8ynWhxK6Q2hoqKKjox3GgoODVb58eadxAABwc3I5qERFRV3x/VJ+/PHHEhUEAACQz+WgMnDgQIfHOTk52rJli1atWqUXX3yxRMWsXbu2RMsDAIAbi8tBZcCAAQWOv/nmm9q0aVOJCwIAAMjnto9A7tChg5YuXequ1QEAALgvqCxZskTh4eHuWh0AAIDrp37uvPNOh4tpjTE6ePCgjhw5orfeesutxQEAgJuby0ElISHB4bGXl5cqVKigli1b6vbbb3dXXQAAAK4HldGjR5dGHQAAAE7cdo0KAACAuxX5iIqXl9cV3+hNkmw2my5evFjiogAAACQXgsqyZcsKfe7LL7/U3//+d7n4QcwAAABXVOSg8sADDziNffvttxo2bJg++ugjde/eXS+//LJbiwMAADe3Yl2jsn//fj355JNq0KCBLl68qK1bt2r+/Pm69dZb3V0fAAC4ibkUVDIzMzVkyBDVqlVLO3fu1KeffqqPPvqITzsGAAClosinfiZMmKDx48erUqVKevfddws8FQQAAOBORQ4qQ4cOVWBgoGrVqqX58+dr/vz5Bc57//333VYcAAC4uRU5qPTs2fOqtycDAAC4U5GDyrx580qxDAAAAGe8My0AALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsggoAALAsjwaVlJQUNWnSRKGhoapYsaISEhL03XffebIkAABgIR4NKuvWrVO/fv20ceNGpaWl6eLFi2rXrp2ysrI8WRYAALAIH09+81WrVjk8njt3ripWrKjNmzerRYsWHqoKAABYhUeDyuUyMzMlSeHh4QU+n52drezsbPvjU6dOSZJycnKUk5Pj9nr85V+i5R1q8goofN7/P5dzhTm6bPv8vY37aisFbu2dVGj/6J2zovZOcr1/9O6Sudd436N31t336F3prtNmjCnZFriJMUYPPPCATpw4oQ0bNhQ4JykpScnJyU7jCxcuVFBQUGmXCAAA3ODs2bPq1q2bMjMzVaZMmSvOtUxQ6devnz7++GN9/vnnqlatWoFzCjqiEhkZqaNHj151Q4sjbmFciZZP75b++4OUgrdJ+i0Zp9Wfprbb+8s373zBk4b94vAwOml1iWrbkdS+RMtfjVt7JxXaP3rnrKi9k1zvH7373bXe9+iddfc9eue6U6dOKSIiokhBxRKnfp577jl9+OGHWr9+faEhRZL8/f3l7+98iM3X11e+vr5urytb2VefdAUONRW2Q106P+984TveZduXnWsrSWml0q9LubV30lX7R+9+52rvpKL3j94VsMw12vfonXX3PXpXuuv0aFAxxui5557TsmXLtHbtWkVFRXmyHAAAYDEeDSr9+vXTwoUL9cEHHyg0NFQHDx6UJIWFhSkwMNCTpQEAAAvw6PuoTJ8+XZmZmWrZsqUqV65s/3rvvfc8WRYAALAIj5/6AQAAKAyf9QMAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACyLoAIAACzL40HlrbfeUlRUlAICAtS4cWNt2LDB0yUBAACL8GhQee+99zRw4ECNGDFCW7Zs0b333qsOHTpo7969niwLAABYhEeDyuTJk9WnTx898cQTqlu3rqZMmaLIyEhNnz7dk2UBAACL8PHUN75w4YI2b96soUOHOoy3a9dOX375ZYHLZGdnKzs72/44MzNTknT8+HHl5OS4vUafcyVrz7Fjx35/cMGv0Hk5Xn46e/asjl3wk29eXmErc6ztYpb7aisFbu2dVGj/6J2zovZOcr1/9O5313rfo3fW3ffonetOnz4tSTLGXH2y8ZBff/3VSDJffPGFw/grr7xiateuXeAyo0ePNpL44osvvvjii68b4Gvfvn1XzQseO6KSz2azOTw2xjiN5Rs2bJgGDx5sf5yXl6fjx4+rfPnyhS5zPTh16pQiIyO1b98+lSlTxtPlXFfoXcnQv+Kjd8VH74rvRumdMUanT59WlSpVrjrXY0ElIiJC3t7eOnjwoMP44cOHdcsttxS4jL+/v/z9/R3GypYtW1olXnNlypS5rnc8T6J3JUP/io/eFR+9K74boXdhYWFFmuexi2n9/PzUuHFjpaWlOYynpaWpWbNmHqoKAABYiUdP/QwePFg9evRQbGys4uLiNHPmTO3du1d//etfPVkWAACwCI8GlUcffVTHjh3TmDFjdODAAUVHR+uTTz5R9erVPVnWNefv76/Ro0c7ndbC1dG7kqF/xUfvio/eFd/N2DubMUW5NwgAAODa8/hb6AMAABSGoAIAACyLoAIAACyLoAIAACyLoAIAACyLoGIBb731lqKiohQQEKDGjRtrw4YNni7purB+/Xp16tRJVapUkc1m0/Llyz1d0nUhJSVFTZo0UWhoqCpWrKiEhAR99913ni7rujB9+nQ1aNDA/q6gcXFxWrlypafLui6lpKTIZrNp4MCBni7lupCUlCSbzebwValSJU+XdU0QVDzsvffe08CBAzVixAht2bJF9957rzp06KC9e/d6ujTLy8rKUsOGDfXGG294upTryrp169SvXz9t3LhRaWlpunjxotq1a6esrJJ9wurNoFq1aho3bpw2bdqkTZs2qXXr1nrggQe0c+dOT5d2XcnIyNDMmTPVoEEDT5dyXalXr54OHDhg/9q+fbunS7omeB8VD2vatKkaNWqk6dOn28fq1q2rhIQEpaSkeLCy64vNZtOyZcuUkJDg6VKuO0eOHFHFihW1bt06tWjRwtPlXHfCw8M1ceJE9enTx9OlXBfOnDmjRo0a6a233tLYsWMVExOjKVOmeLosy0tKStLy5cu1detWT5dyzXFExYMuXLigzZs3q127dg7j7dq105dffumhqnCzyczMlPTbCy6KLjc3V4sWLVJWVpbi4uI8Xc51o1+/furYsaPuv/9+T5dy3fn+++9VpUoVRUVFqUuXLvrxxx89XdI14dG30L/ZHT16VLm5uU6fFn3LLbc4fao0UBqMMRo8eLDuueceRUdHe7qc68L27dsVFxen8+fPKyQkRMuWLdMdd9zh6bKuC4sWLdJ///tfZWRkeLqU607Tpk21YMEC1a5dW4cOHdLYsWPVrFkz7dy5U+XLl/d0eaWKoGIBNpvN4bExxmkMKA3PPvustm3bps8//9zTpVw36tSpo61bt+rkyZNaunSpevXqpXXr1hFWrmLfvn0aMGCAUlNTFRAQ4OlyrjsdOnSw/7t+/fqKi4tTzZo1NX/+fA0ePNiDlZU+gooHRUREyNvb2+noyeHDh52OsgDu9txzz+nDDz/U+vXrVa1aNU+Xc93w8/NTrVq1JEmxsbHKyMjQ1KlT9Y9//MPDlVnb5s2bdfjwYTVu3Ng+lpubq/Xr1+uNN95Qdna2vL29PVjh9SU4OFj169fX999/7+lSSh3XqHiQn5+fGjdurLS0NIfxtLQ0NWvWzENV4UZnjNGzzz6r999/X2vWrFFUVJSnS7quGWOUnZ3t6TIsr02bNtq+fbu2bt1q/4qNjVX37t21detWQoqLsrOztWvXLlWuXNnTpZQ6jqh42ODBg9WjRw/FxsYqLi5OM2fO1N69e/XXv/7V06VZ3pkzZ/TDDz/YH//000/aunWrwsPDdeutt3qwMmvr16+fFi5cqA8++EChoaH2I3phYWEKDAz0cHXWNnz4cHXo0EGRkZE6ffq0Fi1apLVr12rVqlWeLs3yQkNDna6DCg4OVvny5bk+qgheeOEFderUSbfeeqsOHz6ssWPH6tSpU+rVq5enSyt1BBUPe/TRR3Xs2DGNGTNGBw4cUHR0tD755BNVr17d06VZ3qZNm9SqVSv74/zztL169dK8efM8VJX15d8K37JlS4fxuXPnqnfv3te+oOvIoUOH1KNHDx04cEBhYWFq0KCBVq1apbZt23q6NNzgfvnlF3Xt2lVHjx5VhQoVdPfdd2vjxo03xWsF76MCAAAsi2tUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZRFUAACAZf0fFDXXnkebfRUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "final_stats = torch.load(\"final_stats_ssa_4_exp_diff.pth\")\n",
    "centers = {15:-0.25, 16:-0, 17:0.25}\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals= []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['overlap']))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Overlap bits\")\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['total']))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Total bits\")\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "#plt.ylim(17,21)\n",
    "plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(final_stats[set_size][i]['extra']))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Extra bits\")\n",
    "#plt.ylim(15,18)\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for i in range(6):\n",
    "        vals.append(np.mean(np.array(final_stats[set_size][i]['overlap'])/np.array(final_stats[set_size][i]['total'])))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Overlap/Total fraction\")\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.mean([countSetBits(final_stats[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats[set_size][it]['ind_lens']))]))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Average computations per target\")\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "#plt.ylim(1.5,2.1)\n",
    "plt.show()\n",
    "\n",
    "for set_size in range(15,18):\n",
    "    vals = []\n",
    "    for it in range(6):\n",
    "        vals.append(np.mean([np.sum([countSetBits(final_stats[set_size][it]['ind_lens'][i][j]) for j in range(experts)]) for i in range(len(final_stats[set_size][it]['ind_lens']))]))\n",
    "    plt.bar(np.arange(6)-centers[set_size], vals, width = 0.2)\n",
    "plt.title(\"Average computations over all targets\")\n",
    "plt.grid(True)\n",
    "plt.ylabel(\"Number of bits\")\n",
    "#plt.ylim(7,9)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "e257b4a9-860a-4c33-9db4-a93db6cbe145",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.16665055 -0.87298161 -0.39695387  0.67327416]\n",
      "[ 0.167 -0.873 -0.397  0.673]\n"
     ]
    }
   ],
   "source": [
    "targets = np.random.uniform(-1,1,4)\n",
    "print(targets)\n",
    "epsilon = 0.001\n",
    "targets = (np.floor(targets/(2*epsilon))*2 + 1)*epsilon\n",
    "print(targets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88649825-71a4-43f8-8026-af05e8f3bddb",
   "metadata": {},
   "outputs": [],
   "source": [
    "final_stats = torch.load(\"final_stats_ssa_4_exp.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "24a19042-ed73-489d-abf4-87338395fee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def subsets(arr,status,curr = 0):\n",
    "    global s\n",
    "    if(curr>=len(arr)):\n",
    "        s.append(np.sum(arr*status))\n",
    "        return\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 1\n",
    "    subsets(arr,status,curr+1)\n",
    "    status[curr] = 0\n",
    "\n",
    "experts = 4\n",
    "epsilon = 0.001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "9a04129f-d1d0-4415-aa42-022d6092e673",
   "metadata": {},
   "outputs": [],
   "source": [
    "targets = np.random.uniform(-0.5,0.5,4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "1b396672-c6ae-4ea3-8714-9f67741f5812",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6811 8 [4232, 6785, 4115, 6665] 17\n",
      "(8, 1, 13, 8, [3, 5, 4, 5])\n",
      "6811 14 [4232, 6785, 4115, 6665] 4096\n",
      "(14, 1, 13, 8, [3, 5, 4, 5])\n",
      "8171 10 [5192, 7370, 1770, 1483] 1096\n",
      "(10, 3, 13, 11, [4, 7, 7, 7])\n",
      "6815 12 [4127, 6785, 4115, 6665] 4097\n",
      "(12, 2, 12, 9, [6, 5, 4, 5])\n",
      "7123 15 [192.0, 6785.0, 4115.0, 2880.0] 0\n",
      "(15, 0, 15, 9, [2, 5, 4, 4])\n",
      "7123 15 [192.0, 6785.0, 4115.0, 2880.0] 0\n",
      "(15, 0, 15, 9, [2, 5, 4, 4])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_9564\\1495535208.py:9: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  n &= int(n-1)\n"
     ]
    }
   ],
   "source": [
    "rand_vars_1 = np.random.uniform(-1,1,13)\n",
    "s = []\n",
    "subsets(rand_vars_1, np.zeros_like(rand_vars_1))\n",
    "status = []\n",
    "for i in range(experts):\n",
    "    status.append(np.argwhere(np.abs(s-targets[i])<epsilon))\n",
    "for i in range(experts):\n",
    "    if(len(status)==0):\n",
    "        print(\"Invalid combo\")\n",
    "\n",
    "a,b,c,d = find_best_subset_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_overall_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_overlap_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_extra_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_representational_bins(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_1))*rand_vars_1) - targets[i])<=epsilon)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "8a623339-30ad-4d8e-9131-0a099e86e739",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "13622 8 [8464, 13570, 8230, 13330] 17\n",
      "(8, 1, 13, 8, [3, 5, 4, 5])\n",
      "14135 13 [8464, 8707, 8230, 13330] 8192\n",
      "(13, 1, 12, 10, [3, 4, 4, 5])\n",
      "9599 9 [8254, 1383, 8230, 1143] 38\n",
      "(9, 3, 12, 10, [6, 7, 4, 7])\n",
      "13887 11 [8254, 8707, 8230, 13330] 8194\n",
      "(11, 2, 11, 10, [6, 4, 4, 5])\n",
      "14247 14 [384.0, 8707.0, 8230.0, 5760.0] 0\n",
      "(14, 0, 14, 10, [2, 4, 4, 4])\n",
      "14247 14 [384.0, 8707.0, 8230.0, 5760.0] 0\n",
      "(14, 0, 14, 10, [2, 4, 4, 4])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\RahulN\\AppData\\Local\\Temp\\ipykernel_9564\\1495535208.py:9: DeprecationWarning: Conversion of an array with ndim > 0 to a scalar is deprecated, and will error in future. Ensure you extract a single element from your array before performing this operation. (Deprecated NumPy 1.25.)\n",
      "  n &= int(n-1)\n"
     ]
    }
   ],
   "source": [
    "rand_vars_2 = np.concatenate((rand_vars_1, np.random.uniform(-1,1,1)))\n",
    "s = []\n",
    "subsets(rand_vars_2, np.zeros_like(rand_vars_2))\n",
    "status = []\n",
    "for i in range(experts):\n",
    "    status.append(np.argwhere(np.abs(s-targets[i])<epsilon))\n",
    "for i in range(experts):\n",
    "    if(len(status)==0):\n",
    "        print(\"Invalid combo\")\n",
    "\n",
    "a,b,c,d = find_best_subset_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_overall_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_overlap_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_best_extra_size(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_sparsest(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n",
    "\n",
    "a,b,c,d = find_representational_bins(status, targets, experts, epsilon)\n",
    "print(str(a)+\" \"+str(b)+\" \"+str(c)+\" \"+str(d))\n",
    "outp = find_stats(a,b,c)\n",
    "print(outp)\n",
    "for i in range(len(c)):\n",
    "# print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "    assert((np.sum(get_binary(c[i], len(rand_vars_2))*rand_vars_2) - targets[i])<=epsilon)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "4b8d2b92-e05a-4dfd-852a-b77782700d56",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-0.17713028,  0.46364824, -0.48165471, -0.15635247])"
      ]
     },
     "execution_count": 120,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "cf78f267-6538-404c-aa7c-8b1aa18dc977",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 130,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "countSetBits(3557)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "fec24b40-4baa-4da2-a384-08b71834417a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_best_subset_size(status, targets, experts, epsilon):\n",
    "    final_set = status[0].reshape(-1,1)\n",
    "    for i in range(1,experts):\n",
    "        final_set = np.bitwise_or(final_set, status[i].reshape(1,-1))\n",
    "        #print(final_set)\n",
    "        final_set = np.unique(final_set.reshape(-1)).reshape(-1,1)\n",
    "    # print(final_set)\n",
    "    final_set = final_set.reshape(-1)\n",
    "    best = 100000\n",
    "    best_id = -1\n",
    "    for i in range(len(final_set)):\n",
    "        b = countSetBits(final_set[i])\n",
    "        if(b<best):\n",
    "            best = b\n",
    "            best_id = final_set[i]\n",
    "    #print(\"Best combo is: \"+str(best_id))\n",
    "    #print(\"Binary string: \"+str(get_binary(best_id)))\n",
    "    #print()\n",
    "    #print(\"Best is: \"+str(best))\n",
    "    if(not (best <= 100)):\n",
    "        print(\"Weird1: \"+str(best))\n",
    "        best = 0\n",
    "    # count[best]+=1\n",
    "    if(best==0):\n",
    "        return None, -1, None, None    \n",
    "    tot_len = 0\n",
    "    for i in range(experts):\n",
    "        status[i] = np.reshape(status[i], (-1))\n",
    "    candidates = []\n",
    "    for i in range(experts):\n",
    "        cand_id = np.argwhere((np.bitwise_and(status[i],best_id)-status[i])==0)\n",
    "        #print(cand_id)\n",
    "        combos = [status[i][id] for id in cand_id]\n",
    "        candidates.append(combos)\n",
    "        # for combo in combos:\n",
    "        #     # print(\"Combo:\"+str(combo[0])+\" Binary:\"+str(get_binary(combo[0])))\n",
    "        #     assert((np.sum(get_binary(combo[0], 13)*rand_vars) - targets[i])<=epsilon)\n",
    "        cand_len = min([countSetBits(status[i][id]) for id in cand_id])\n",
    "        tot_len+=cand_len\n",
    "    candidates = [i[0][0] for i in candidates]\n",
    "    return best_id, best, candidates, tot_len"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "a142efc3-3de0-47ac-8e27-635237ace85a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([2580, 3146, 3303, 4706, 6310, 6518, 6727], dtype=int64),\n",
       " array([1929, 6223], dtype=int64),\n",
       " array([2159, 5928, 7474, 7949], dtype=int64),\n",
       " array([2680, 3301, 6725], dtype=int64)]"
      ]
     },
     "execution_count": 160,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "23cf0176-07b2-4f95-a0e2-bd28a4399186",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.17804448262271833"
      ]
     },
     "execution_count": 162,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(rand_vars_1*get_binary(4706,13))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "da36d6b0-6e47-41c5-8c81-3f02989a80b6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.83910321 -0.35660927  0.65856118 -0.24287832  0.735083   -0.09730102\n",
      " -0.85500564 -0.9997477  -0.70793826 -0.07167426 -0.56361288 -0.47907533\n",
      "  0.98069181]\n",
      "[0.9431918]\n",
      "[-0.83910321 -0.35660927  0.65856118 -0.24287832  0.735083   -0.09730102\n",
      " -0.85500564 -0.9997477  -0.70793826 -0.07167426 -0.56361288 -0.47907533\n",
      "  0.98069181  0.9431918 ]\n"
     ]
    }
   ],
   "source": [
    "a = np.random.uniform(-1,1,13)\n",
    "print(a)\n",
    "b = np.random.uniform(-1,1,1)\n",
    "print(b)\n",
    "c = np.concatenate((a,b))\n",
    "print(c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "5cdd1cb9-b36b-4911-bae4-a8bb616e7652",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.37676485  0.10693119 -0.40463375  0.12121309]\n",
      "[ 0.3765  0.1065 -0.4045  0.1215]\n"
     ]
    }
   ],
   "source": [
    "epsilon = 0.001\n",
    "targets = np.random.uniform(-0.5,0.5,4)\n",
    "print(targets)\n",
    "new_targets = (np.floor((targets-(-0.5))/(epsilon)) + 0.5)*epsilon + (-0.5)\n",
    "print(new_targets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "8ab19d48-dd3b-43c0-af90-85d7698218c0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.39, -0.31, -0.11, -0.07])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "f6d375d8-cd90-4a5b-86d2-a91c9a56b3b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.3930227 , -0.30534199, -0.10830319, -0.07383212])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "c299944d-59f6-4447-90b3-348d2376fa7e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.0, 0.0, 0.0, 0.0]"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "ab866565-0012-4842-8041-1d3da7502021",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([[0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0]], dtype=int64),\n",
       " array([[0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0]], dtype=int64),\n",
       " array([[0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0]], dtype=int64),\n",
       " array([[0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0],\n",
       "        [0]], dtype=int64)]"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "61fd683e-9ffb-469b-87c3-dd88ae9222bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 133,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a = 2\n",
    "b = 0\n",
    "(a-1 if a>0 else 0)+(b-1 if b>0 else 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1de32f6d-cabc-455b-b616-b4bf1a3742d5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
