{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "slideshow": {
     "slide_type": "notes"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import matplotlib.pyplot as plt\n",
    "import itertools\n",
    "from collections import Counter\n",
    "from more_itertools import set_partitions\n",
    "import copy\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "sns.set_style(\"ticks\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Dataset of $j$-th client follows $D_j\\sim (\\theta_i,\\epsilon_j^2)$.\n",
    "The following code is to simulate:\n",
    "- $\\epsilon_j^2$: the amount of noise in the sampling process \n",
    "- $\\theta_j$: the true mean of players"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0\n",
      "100.0\n"
     ]
    }
   ],
   "source": [
    "means_dist = stats.norm(loc = 0, scale = 1)\n",
    "variance_dist = stats.beta(a=8, b=2, scale = 500/4)\n",
    "print(means_dist.var())\n",
    "print(variance_dist.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def calculate_error(n_list,i,mue=means_dist.var(),var=variance_dist.mean()):\n",
    "#     n=n_list[i]\n",
    "#     N = sum(n_list)\n",
    "#     sumsquares = sum([nval**2 for nval in n_list]) - n**2 + (N-n)**2\n",
    "#     # uniform\n",
    "#     error= (mue/N + sumsquares * var/(N**2))\n",
    "#     return error"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate the error of clients in a coalition structure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Reference: [https://github.com/kpdonahue/model_sharing_games]\n",
    "#Here is the function inspired by the above reference.\n",
    "def calculate_means(var = means_dist.var(), mue = variance_dist.mean(), \n",
    "                    n_list = [10, 20, 30], w_best = False, w_list = [0.2, 0.4, 0.6], v_best = False,\n",
    "                    v_mat = [[0.1, 0.6, 0.3], [0.2, 0.8, 0.0], [0.3, 0.5, 0.2]], fair=False,err_list=None, q=0):\n",
    "    '''\n",
    "    Calculate exact error for mean estimation.  \n",
    "\n",
    "    Args:\n",
    "        var: variance of true mean distributions\n",
    "        mue: mean of true error distribution. \n",
    "        n_list: a list of length M (number of players) with the number of samples each has.\n",
    "        w_best: boolean, if true, calculates error given optimal values for w\n",
    "        w_list: if w_best is false, a list of w-weights (in [0, 1]) for coarse-grained federation.\n",
    "        v_best: boolean, if true, calculates error given optimal values for v\n",
    "        v_mat: a matrix (list of lists) of weights each player uses in fine-grained federation: the rows sum up \n",
    "               to 1.\n",
    "    Returns:\n",
    "        dataframe with average error for each player, for: local, uniform, coarse-grained, and fine-grained \n",
    "        federation.  \n",
    "    '''\n",
    "    # dataframe for storing error\n",
    "    player_error = pd.DataFrame(data = 0.0, index = ['local', 'uniform', 'coarse', 'fine','fair'], \n",
    "                                columns = range(len(n_list)))\n",
    "    N = sum(n_list)\n",
    "    \n",
    "    # for each player, calculate their true error \n",
    "    for j, n in enumerate(n_list):\n",
    "        \n",
    "        # local\n",
    "        player_error.loc['local'][j] = mue/n\n",
    "        \n",
    "        sumsquares = sum([nval**2 for nval in n_list]) - n**2 + (N-n)**2\n",
    "        \n",
    "        # uniform\n",
    "        player_error.loc['uniform'][j] = (mue/N + sumsquares * var/(N**2))\n",
    "        \n",
    "        # coarse-grained\n",
    "        if w_best: \n",
    "            if len(n_list) == 1: # division by 0 issue if length 1 list - equivalent to local\n",
    "                w_err = player_error.loc['local'][j]\n",
    "            else:\n",
    "                w_err = (mue * (N-n) + var * sumsquares)/((N-n)*N + n*var*sumsquares/mue)\n",
    "        # else:\n",
    "        #     w = w_list[j]\n",
    "        #     w_err = mue * ( w**2/n + (1-w**2)/N) + ((1-w)**2/(N**2)) * sumsquares* var\n",
    "            player_error.loc['coarse'][j] = w_err\n",
    "        \n",
    "        # fine-grained\n",
    "        if v_best: \n",
    "            # calculate optimal v weights\n",
    "            V_list = [var + mue/ni for ni in n_list]\n",
    "            sum_inv = sum([1/Vi for Vi in V_list]) - 1/V_list[j]\n",
    "            vjj = (1 + var * sum_inv)/(1 + V_list[j] * sum_inv)\n",
    "            weights = [(V_list[j]-var)/(Vk * (1 + V_list[j]*sum_inv)) for Vk in V_list]\n",
    "            weights[j] = vjj\n",
    "            v_vec = pd.DataFrame(weights)\n",
    "        # else:\n",
    "        #     v_vec = pd.DataFrame(v_mat[j])\n",
    "            \n",
    "            player_error.loc['fine'][j] = (mue * (v_vec**2).T.dot(pd.DataFrame([1/nval for nval in n_list])) + \n",
    "                                        var * ((v_vec**2).sum() - v_vec.iloc[j]**2 + (1 - v_vec.iloc[j])**2))[0][0]\n",
    "    # err_list=[player_error.loc['uniform'][j]  for j, n in enumerate(n_list)]                                \n",
    "    # for j, n in enumerate(n_list):    \n",
    "        if fair is True:\n",
    "            v_vec = pd.DataFrame([ni*pow(err_i,q)/sum([ni*pow(err_i,q) for ni,err_i in zip(n_list,err_list)]) for ni,err_i in zip(n_list,err_list)])\n",
    "            player_error.loc['fair'][j] = (mue * (v_vec**2).T.dot(pd.DataFrame([1/nval for nval in n_list])) + \n",
    "                                        var * ((v_vec**2).sum() - v_vec.iloc[j]**2 + (1 - v_vec.iloc[j])**2))[0][0]\n",
    "\n",
    "\n",
    "    return player_error"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Collect errors in all possible coalition structures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Reference: [https://github.com/kpdonahue/model_sharing_games]\n",
    "#Here is the function inspired by the above reference.\n",
    "def calc_error_groups(var = means_dist.var(), mue = variance_dist.mean(), same_size = False, \n",
    "                n = 10, M = 5, n_list = [1, 2], fair=False, err_list=None, q=0):\n",
    "    '''\n",
    "    Calculates the errors that players experience, for all possible arrangements of players into groups. \n",
    "    Assumes optimal versions of coarse and fine federation are used. \n",
    "    \n",
    "    Args:\n",
    "        var: variance of mean parameter. \n",
    "        mue: mean of errors. \n",
    "        same_size: boolean, indicates whether all players are the same size (if so, runs faster). \n",
    "        n: if players are the same size, indicates the size\n",
    "        M: if players are the same size, indicates the number of players\n",
    "        n_list: if players differ in their size, provides a list of those sizes. \n",
    "        \n",
    "    Returns: \n",
    "        tables with errors for every combination of players (uniform, coarse, and fine-grained federation), \n",
    "        as well as local learning.\n",
    "        \n",
    "    \n",
    "    '''\n",
    "    \n",
    "    if same_size:\n",
    "        # all players are interchangable\n",
    "        n_list = [n for i in range(M)]\n",
    "        comb = list(itertools.combinations_with_replacement([0,1], r=M))\n",
    "    else: \n",
    "        # for combinations, the identity of player matters (not interchangable)\n",
    "        # for example: [1, 0, 1] means a group made of 1st and 3rd players only\n",
    "        comb = list(itertools.product([0,1], repeat = len(n_list)))\n",
    "    \n",
    "    string_list = [\"\".join(map(str, val)) for val in comb] # string to name groups\n",
    "    err_uniform = pd.DataFrame(data = np.nan, \n",
    "                              index = string_list,\n",
    "                              columns = ['n_' + str(i) + '_err' for i in n_list] )\n",
    "    err_best_coarse = err_uniform.copy()\n",
    "    err_best_fine = err_uniform.copy()\n",
    "    err_fair=err_uniform.copy()\n",
    "        \n",
    "    for index, group in enumerate(comb):\n",
    "        loca = \"\".join(map(str, group)) # group index\n",
    "        if sum(group) > 0: # ignore group with no members\n",
    "            \n",
    "            # drop players not in this group\n",
    "            temp_n = [n_list[i] for i in range(len(n_list)) if list(group)[i] == 1]\n",
    "            \n",
    "            # calculate error table and rename columns\n",
    "            error_table = calculate_means(var = var, mue = mue, n_list = temp_n, w_best = False, v_best = False,fair=fair,err_list=err_list,q=q)\n",
    "            error_table.columns = [i for i in range(len(n_list)) if list(group)[i] == 1]  \n",
    "            \n",
    "            # copy errors into correct tables\n",
    "            for player in range(len(n_list)):\n",
    "                if list(group)[player] ==1: # if player is participating in group\n",
    "                    err_uniform.iloc[index, player] = error_table.loc['uniform', player]\n",
    "                    err_best_coarse.iloc[index, player] = error_table.loc['coarse', player]\n",
    "                    err_best_fine.iloc[index, player] = error_table.loc['fine', player]\n",
    "                    err_fair.iloc[index, player] = error_table.loc['fair', player]\n",
    "    \n",
    "    local_error = calculate_means(var = var, mue = mue, n_list = n_list, w_best = False, \n",
    "                                  v_best = False).loc['local']\n",
    "    \n",
    "    err_uniform.dropna(how = 'all', inplace = True)\n",
    "    err_best_coarse.dropna(how = 'all', inplace = True)\n",
    "    err_best_fine.dropna(how = 'all', inplace = True)\n",
    "    err_fair.dropna(how = 'all', inplace = True)\n",
    "    \n",
    "\n",
    "    return err_uniform, err_best_coarse, err_best_fine, err_fair,local_error"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate utility in ACFG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calc_unity_groups(err_uniform=None,  same_size = False, \n",
    "            n = 10, M = 5, n_list = [1, 2], preference=\"selfish\",friends=None,w=0.4,client_pre=None):\n",
    "    if client_pre==None:\n",
    "        client_pre=list(range(len(n_list)))\n",
    "    if same_size:\n",
    "        # all players are interchangable\n",
    "        n_list = [n for i in range(M)]\n",
    "        comb = list(itertools.combinations_with_replacement([0,1], r=M))\n",
    "    else: \n",
    "        # for combinations, the identity of player matters (not interchangable)\n",
    "        # for example: [1, 0, 1] means a group made of 1st and 3rd players only\n",
    "        comb = list(itertools.product([0,1], repeat = len(n_list)))\n",
    "    \n",
    "    string_list = [\"\".join(map(str, val)) for val in comb] # string to name groups\n",
    "    util_uniform = pd.DataFrame(data = np.nan, \n",
    "                              index = string_list,\n",
    "                              columns = ['n_' + str(i) + '_err' for i in n_list] )\n",
    "    util_uniform=copy.deepcopy(err_uniform)\n",
    "    \n",
    "    all_coalition = int('1' * len(n_list), 2)\n",
    "    for index, row_name in enumerate(util_uniform.index):\n",
    "        current_coalition= int(row_name, 2)\n",
    "        complement_coalition = all_coalition - current_coalition\n",
    "        complement_coalition = bin(complement_coalition)[2:]\n",
    "        complement_coalition = complement_coalition.zfill(len(n_list))\n",
    "        if sum([int(exist) for exist in complement_coalition])!=0:\n",
    "            complement_index = util_uniform.index.get_loc(complement_coalition)\n",
    "        else:\n",
    "            complement_index=None\n",
    "        \n",
    "        # copy errors into correct tables\n",
    "        for player in client_pre:\n",
    "        # for player in range(len(n_list)):\n",
    "            if list([exist for exist in row_name])[player]==\"1\": # if player is participating in group\n",
    "                if preference==\"mean-FR\":\n",
    "                    # if index==\"00001\":\n",
    "                    #     print()\n",
    "                    if complement_index!=None:\n",
    "                        # print(err_uniform.iloc[index,player])\n",
    "                        # print(pd.to_numeric(err_uniform.iloc[index,friends[str(player)]+[player]].replace(\"-\", np.nan), errors='coerce'))\n",
    "                        # print(pd.to_numeric(err_uniform.iloc[complement_index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce'))\n",
    "                        util_uniform.iloc[index, player] =w*err_uniform.iloc[index,player]+(1-w)*(pd.to_numeric(err_uniform.iloc[index,friends[str(player)]+[player]].replace(\"-\", np.nan), errors='coerce').sum(skipna=True)+pd.to_numeric(err_uniform.iloc[complement_index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').sum(skipna=True))/(len(friends[str(player)])+1)\n",
    "                        # print( util_uniform.iloc[index, player])\n",
    "                    else:\n",
    "                        util_uniform.iloc[index, player] =w*err_uniform.iloc[index,player]+(1-w)*pd.to_numeric(err_uniform.iloc[index,friends[str(player)]+[player]]).sum(skipna=True)/(len(friends[str(player)])+1)\n",
    "                        \n",
    "                if preference==\"min-FR\":\n",
    "                    if complement_index!=None:\n",
    "                        util_uniform.iloc[index, player] =w*err_uniform.iloc[index,player]+(1-w)*np.nanmax([pd.to_numeric(err_uniform.iloc[index,friends[str(player)]+[player]].replace(\"-\", np.nan), errors='coerce').max(skipna=True),pd.to_numeric(err_uniform.iloc[complement_index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').max(skipna=True)])\n",
    "                    else:\n",
    "                        util_uniform.iloc[index, player] =w*err_uniform.iloc[index,player]+(1-w)*pd.to_numeric(err_uniform.iloc[index,friends[str(player)]+[player]]).max(skipna=True)\n",
    "                if preference==\"mean-PA\": \n",
    "                    if complement_index!=None:\n",
    "                        util_uniform.iloc[index, player] =(pd.to_numeric(err_uniform.iloc[index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').sum(skipna=True)+pd.to_numeric(err_uniform.iloc[complement_index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').sum(skipna=True))/len(friends[str(player)])\n",
    "                    else:\n",
    "                        util_uniform.iloc[index, player] =pd.to_numeric(err_uniform.iloc[index,friends[str(player)]]).mean(skipna=True)        \n",
    "                \n",
    "                if preference==\"min-PA\":\n",
    "                    if complement_index!=None:\n",
    "                        util_uniform.iloc[index, player]=np.nanmax([pd.to_numeric(err_uniform.iloc[index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').max(skipna=True),pd.to_numeric(err_uniform.iloc[complement_index,friends[str(player)]].replace(\"-\", np.nan), errors='coerce').max(skipna=True)])\n",
    "                    else:\n",
    "                        util_uniform.iloc[index, player] =pd.to_numeric(err_uniform.iloc[index,friends[str(player)]]).max(skipna=True)\n",
    "                             \n",
    "    \n",
    "    return util_uniform"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate utility in AHG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calc_unity_groups_hedonic (err_uniform=None, var = means_dist.var(), mue = variance_dist.mean(), same_size = False, \n",
    "            n = 10, M = 5, n_list = [1, 2], preference=\"selfish\",friends=None):\n",
    "    \n",
    "    if same_size:\n",
    "        # all players are interchangable\n",
    "        n_list = [n for i in range(M)]\n",
    "        comb = list(itertools.combinations_with_replacement([0,1], r=M))\n",
    "    else: \n",
    "        # for combinations, the identity of player matters (not interchangable)\n",
    "        # for example: [1, 0, 1] means a group made of 1st and 3rd players only\n",
    "        comb = list(itertools.product([0,1], repeat = len(n_list)))\n",
    "    \n",
    "    string_list = [\"\".join(map(str, val)) for val in comb] # string to name groups\n",
    "    util_uniform = pd.DataFrame(data = np.nan, \n",
    "                              index = string_list,\n",
    "                              columns = ['n_' + str(i) + '_err' for i in n_list] )\n",
    "    util_uniform=copy.deepcopy(err_uniform)\n",
    "    \n",
    "    all_coalition = int('1' * len(n_list), 2)\n",
    "    for index, row_name in enumerate(util_uniform.index):\n",
    "        current_coalition= int(row_name, 2)\n",
    "        complement_coalition = all_coalition - current_coalition\n",
    "        complement_coalition = bin(complement_coalition)[2:]\n",
    "        complement_coalition = complement_coalition.zfill(len(n_list))\n",
    "        if sum([int(exist) for exist in complement_coalition])!=0:\n",
    "            complement_index = util_uniform.index.get_loc(complement_coalition)\n",
    "        else:\n",
    "            complement_index=None\n",
    "        \n",
    "        # copy errors into correct tables\n",
    "        # for player in [2]:\n",
    "        for player in range(len(n_list)):\n",
    "            friends_in_col=[i for i in friends[str(player)] if row_name[i]==\"1\"]\n",
    "            if list([exist for exist in row_name])[player]==\"1\": # if player is participating in group\n",
    "                \n",
    "                if preference==\"mean-FR\":\n",
    "                    util_uniform.iloc[index, player] =0.5*err_uniform.iloc[index,player]+0.5*pd.to_numeric(err_uniform.iloc[index,friends_in_col+[player]].replace(\"-\", np.nan), errors='coerce').mean(skipna=True)\n",
    "                        \n",
    "                if preference==\"min-FR\":\n",
    "                    util_uniform.iloc[index, player] =0.5*err_uniform.iloc[index,player]+0.5*pd.to_numeric(err_uniform.iloc[index,friends_in_col+[player]].replace(\"-\", np.nan), errors='coerce').max(skipna=True)\n",
    "                if preference==\"mean-PA\": \n",
    "                    util_uniform.iloc[index, player] =pd.to_numeric(err_uniform.iloc[index,friends_in_col].replace(\"-\", np.nan), errors='coerce').mean(skipna=True)        \n",
    "                \n",
    "                if preference==\"min-PA\":\n",
    "                    util_uniform.iloc[index, player] =pd.to_numeric(err_uniform.iloc[index,friends_in_col].replace(\"-\", np.nan), errors='coerce').max(skipna=True)\n",
    "                             \n",
    "    \n",
    "    return util_uniform"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Check whether the grand coalition structure is stable? "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_stable(utility_uniform, utility_fair,structure):\n",
    "    '''\n",
    "    Check whether the grand coalition structure is stable\n",
    "    \n",
    "    Args:\n",
    "        utility_uniform: Utility without considering fairness. \n",
    "        utility_fair: Utility  considering fairness. \n",
    "        structure:  all possible coalition structures\n",
    "        \n",
    "    Returns: \n",
    "        IF Stable? None/Subset\n",
    "        \n",
    "    \n",
    "    '''\n",
    "    row_ids = utility_uniform.index.tolist()\n",
    "   \n",
    "    grand_colition=row_ids[-1]\n",
    "    grand_value=utility_fair.loc[grand_colition]\n",
    "    for coalitions in structure:\n",
    "        for coaltion in coalitions:\n",
    "            not_nan_indices = utility_uniform.loc[coaltion].notna()\n",
    "\n",
    "            check_less_equal = utility_uniform.loc[coaltion][not_nan_indices].le(grand_value[not_nan_indices])\n",
    "            check_less = utility_uniform.loc[coaltion][not_nan_indices].lt(grand_value[not_nan_indices])\n",
    "\n",
    "            all_columns_less_equal = check_less_equal.all()\n",
    "            at_least_one_column_less = check_less.any()\n",
    "\n",
    "            result = all_columns_less_equal and at_least_one_column_less\n",
    "\n",
    "            if result:\n",
    "                return coaltion\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_same_position(str1, str2):\n",
    "    for i in range(len(str1)):\n",
    "        if str1[i] == '1' and str2[i] == '1':\n",
    "            return 1\n",
    "    return 0\n",
    "\n",
    "def generate_combinations(numbers):\n",
    "    target_decimal = pow(2,len(numbers[0]))-1 \n",
    "\n",
    "    def backtrack(curr, idx,total):\n",
    "        if total== target_decimal:\n",
    "            combinations.append(curr)\n",
    "            return\n",
    "            \n",
    "        exist=False\n",
    "        if len(curr)!=0:\n",
    "            for curr_i in curr:\n",
    "                if check_same_position(curr_i,numbers[idx]):\n",
    "                    exist=True\n",
    "                \n",
    "            \n",
    "        if idx<len(numbers)-1:\n",
    "            if exist==False:\n",
    "                backtrack(curr+[numbers[idx]], idx + 1, total + int(numbers[idx], 2))\n",
    "            backtrack(curr, idx + 1, total)\n",
    "    combinations = []\n",
    "    backtrack([], 0, 0)\n",
    "    return combinations\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "clients_dataset_num = [20,40,50,100]\n",
    "# clients_dataset_num = [1,5,10,15]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>n_20_err</th>\n",
       "      <th>n_40_err</th>\n",
       "      <th>n_50_err</th>\n",
       "      <th>n_100_err</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0001</th>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0010</th>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>2.0</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0011</th>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>1.555556</td>\n",
       "      <td>0.888889</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0100</th>\n",
       "      <td>-</td>\n",
       "      <td>2.5</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0101</th>\n",
       "      <td>-</td>\n",
       "      <td>1.734694</td>\n",
       "      <td>-</td>\n",
       "      <td>0.877551</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0110</th>\n",
       "      <td>-</td>\n",
       "      <td>1.728395</td>\n",
       "      <td>1.506173</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0111</th>\n",
       "      <td>-</td>\n",
       "      <td>1.495845</td>\n",
       "      <td>1.390582</td>\n",
       "      <td>0.864266</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>5.0</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1001</th>\n",
       "      <td>2.222222</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>0.888889</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1010</th>\n",
       "      <td>2.44898</td>\n",
       "      <td>-</td>\n",
       "      <td>1.591837</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1011</th>\n",
       "      <td>1.799308</td>\n",
       "      <td>-</td>\n",
       "      <td>1.446367</td>\n",
       "      <td>0.858131</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1100</th>\n",
       "      <td>2.555556</td>\n",
       "      <td>1.888889</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1101</th>\n",
       "      <td>1.84375</td>\n",
       "      <td>1.59375</td>\n",
       "      <td>-</td>\n",
       "      <td>0.84375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1110</th>\n",
       "      <td>1.917355</td>\n",
       "      <td>1.553719</td>\n",
       "      <td>1.371901</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1111</th>\n",
       "      <td>1.614512</td>\n",
       "      <td>1.424036</td>\n",
       "      <td>1.328798</td>\n",
       "      <td>0.852608</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      n_20_err  n_40_err  n_50_err n_100_err\n",
       "0001         -         -         -       1.0\n",
       "0010         -         -       2.0         -\n",
       "0011         -         -  1.555556  0.888889\n",
       "0100         -       2.5         -         -\n",
       "0101         -  1.734694         -  0.877551\n",
       "0110         -  1.728395  1.506173         -\n",
       "0111         -  1.495845  1.390582  0.864266\n",
       "1000       5.0         -         -         -\n",
       "1001  2.222222         -         -  0.888889\n",
       "1010   2.44898         -  1.591837         -\n",
       "1011  1.799308         -  1.446367  0.858131\n",
       "1100  2.555556  1.888889         -         -\n",
       "1101   1.84375   1.59375         -   0.84375\n",
       "1110  1.917355  1.553719  1.371901         -\n",
       "1111  1.614512  1.424036  1.328798  0.852608"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "err_uniform, _, _, _,_ = calc_error_groups(n_list =clients_dataset_num)\n",
    "err_uniform=err_uniform.replace([np.nan],['-'])\n",
    "err_uniform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['0001',\n",
       " '0010',\n",
       " '0011',\n",
       " '0100',\n",
       " '0101',\n",
       " '0110',\n",
       " '0111',\n",
       " '1000',\n",
       " '1001',\n",
       " '1010',\n",
       " '1011',\n",
       " '1100',\n",
       " '1101',\n",
       " '1110',\n",
       " '1111']"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "row_ids = err_uniform.index.tolist()\n",
    "row_ids"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate Optimal Egalitarian Fairness Bound $\\lambda$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_coalitions(n_list, s_list):\n",
    "    coalitions = []\n",
    "    for s in s_list:\n",
    "        indices = [i for i, x in enumerate(s) if x == '1']\n",
    "        coalitions.append(n_list[indices])\n",
    "    return coalitions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 1. **Calculated egalitarian fairness bound** in Selfish Clients v.s. **Obtained egalitarian fairness**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.614512471655329"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "for coalition in coalitions_except_grand:\n",
    "    k = np.argmin(coalition)\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)\n",
    "    lambdas_cal.append(max((N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2)),1))\n",
    "    \n",
    "    \n",
    "lambda_cal= max(lambdas_cal)\n",
    "lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "\n",
    "q_list=np.arange(0,1,0.01).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "\n",
    "for q in q_list:\n",
    "    err_uniform, _, _, err_fair,_ = calc_error_groups(n_list =clients_dataset_num,fair=True, err_list=err_list, q=q)\n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "    stable_result=check_stable(err_uniform,err_fair,coalitions)\n",
    "    stable_list.append(stable_result!=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAC9CAYAAABcfWE8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAyW0lEQVR4nO3deVxU9frA8c8AAyObOyrgrohruaaluZRlaZrmBoKidtWsrMS0VfPmrVzSRMstM8FEwZ/L1TS3ErfUq6nlgmIuLC5sbqzDcn5/HBklGWBYhu15v17zB3O+c+Y5A5xnvrtGURQFIYQQArAo6QCEEEKUHpIUhBBCGEhSEEIIYSBJQQghhIEkBSGEEAaSFIQQQhhIUhBCCGEgSUEIIYSBVUkHUBIyMzOJjo7Gzs4OjUZT0uEIIUSxUxSFxMREnJycsLAwXh+okEkhOjqa7t27l3QYQghhdiEhIdSuXdvo8QqZFOzs7AD1w7G3ty/haIQQovglJCTQvXt3w/3PmAqZFLKajOzt7SUpCCEqlLyazCtkUiiwCxdgyxZo2BBeeQV0upKOSAghipQkhfz6+2+UNm3Q6PUAKNWqoRk1CsaNA3f3Eg5OCCGKhgxJza9duwwJAUATHw8LFkDz5tC9O/z0E6SklGCAQghReFJTyK+uXVGsrbMlBoP9+2H/fpRJk9CMHKnWHpo3N3+MIlcZGRmkpaWVdBhCFAutVoulpWWhzyNJIb9at0azbx988gn8+muORTTx8fDNN+qjWzcYPx5ee036HkqYoijcvHmTO3fulHQoQhSrKlWqULt27ULNv5KkYIouXWDvXggLgxUrUH78EU1MTM5lDxyAAwfU2oP0PZSorITg5OSEra2tTFgU5Y6iKCQlJREdHQ1AnTp1CnwuTUXcjjMhIYH27dtz4sSJwg1JTU1VRyMtW2a09pDNs88+rD3Y2BT8fUW+ZWRkcPHiRZycnKhevXpJhyNEsYqLiyM6Oho3N7fHmpLye9+TjubCsLGBoUMf1h6mTUNxcjJefv9+GDECxcUFpkxRh7iKYpXVh2Bra1vCkQhR/LL+zgvTdyZJoag0aQJffYUmIgLWr4fnnjNaVBMXB19/rTYn9ewJ69aptQ5RbKTJSFQERfF3LkmhqFlbq7WHPXvg4kV4/32UGjWMl9+3Dzw8UFxdYepUuHTJbKEKIcQ/SVIoTk2bwpw5aCIj1dpAz55Gi2piY2HuXPU1zz8PwcGQ0/BXUaEkJyezePFiPD098fb2Zvjw4fj4+BAQEEBcXFxJh/eYPXv2sGfPHpNe8+GHH/LMM8/wwQcfGC3z+uuv06FDBxYtWlTYEEUeJCmYg40NDBumdkZfuABTpqDk1um5dy8MHYpSrx589BFcuWK+WEWpkZyczMiRI0lISMDf35+AgADWrVuHl5cXs2fPZu3atSUd4mMKkhS+/PJLunXrlmuZ77//nuYy98csZEiqubm5wdy5aGbNgo0b1ZFLISE5FtXcugVffony1VdoXngBJkyAfv3ASn5thZKRAfHx5n3PatXAxIlFfn5+pKWlMW3atGxtxc8//zyenp5FHaEQgCSFkmNjAx4e6iM0FJYvV+c93L79WFGNosDOnerD2Rlef1191K1bAoGXccHB8NZb8GA8t9k4OcHixTBkSL6Kp6enExQUxPjx43PsPBwzZgz37t0D4OrVq8yaNYv4+HjS0tLo2LEj06ZNw8bGhl9++YUlS5YQGhrK8uXLCQwM5MyZM7Rp04bvvvuOmJgYPv/8cyIjI9HpdNStW5cPP/yQKlWq5BiXoijMnz+fQ4cOYW9vT0ZGBkOHDmXAgAHMmTOHAwcOAODt7Y29vT1LliwhMjKSOXPmcOvWLbRaLVqtlo8//pgmTZpkO3dGRgZffPEF586d4/r163h6evL666/n+jl9//33bN26FQcHBwDeffddOnTokK/PWBihVED3799X3NzclPv375d0KNklJytKQICidO2qKJDrI9PCQlFeeUVRtm1TlPT0ko681EpOTlbOnTunJCcnq09UrpznZ1tsj8qV8x33hQsXFDc3N2XPnj25lktNTVV69eqlLFmyxPCzl5eX8umnnxrKHDlyRHFzc1MWLVqkKIqiXL16VXnvvfcURVGUYcOGKXPnzjWU/fTTT5UxY8YYfb+ff/5Zef755xW9Xq8oiqIcPnxY8fLyMhyfNm2aMm3atGyv+fXXX5VJkyYpmZmZiqIoyqZNm5QXXnhBSUtLy/a6J598Ujl16pSiKIpy6dIlpXXr1sqvv/5qKOPl5aX4+fkZfl63bp3y4osvKnfv3lUURVFOnDihtG7dWomMjMz1MyvPHvt7f0R+73vSp1Ca6HTg5aXOhj5zBt5+G6Vy5RyLajIzYetWtTmpUSOYNQtu3DBzwKK43L9/H8h7fsXWrVuJjo5m1KhRAFhbWzNq1Cg2bNhAbGxstrIDBw4EoH79+syfP58jR45w8uRJxowZYygzdOhQDh48SHh4eI7vFx0dTXJyMvEPmt86d+7M+++/n2uMHTt2ZObMmYYaz8svv8zVq1cfe4/mzZvzxBNPANC4cWOeffZZAgICjJ536dKlDBkyBEdHRwDatWtH/fr1CQ4OzjUekTtpPiqtWrYEPz80X30FQUGwdCkcPZpz2fBw+PRTlJkz0fTvr/Y9PPcc5LIPa4W1YkXJNh/lU9aNLjk5OddyYWFh1KxZk0qVKhmeq1evHhkZGVy6dIkajwyH/ucWjGFhYVhYWPDOO+8YnktPT8fFxYXo6GiuXr3KihUrDMfmz59P//792bJlC7179+a5557jlVdeoUePHrnGaGVlxQ8//MCRI0ewsLAwJIfY2FgaNWpkKOfs7JztdXXr1mX79u05njMhIYHr16+zceNG9u3bZ3g+LS2NxMTEXOMRuZOkUNrZ2oKPj/o4dUrte1izBs2Db5KP0qSnq53XGzeqtYfx42H0aKhZ09xRl15DhsCgQaW+o7lRo0Y4ODhw6dIlevXqVSQhGFtB88cffzR67Nlnn33suY0bN3LkyBE2btzIpEmT6NWrF35+fkbfd/bs2ezfv5+goCDDUiPNmjVDKYIVdsaMGcNrr71W6POIh+SrZFny5JPw3Xdorl9XRy21a2e87OXL6rIbrq7g6akusVHxlrnKmaWlmijN+TBx5JGlpSUeHh788ssvOR6fMGECs2fPpmnTpsTExGSrUYSHh2NpaflYR+4/NW3alMzMTK5evZrt+RkzZnA7hwEPAH/++Sc3btygS5cuzJ07l8WLF7Nz505D+Uc7xZOTk8nIyOD48eM89dRThoSgNzL/5sY/mj8jIiJo3LhxjmXt7e1xdnbmyj+Ga2/fvp2dO3cav2iRJ0kKZZG9vbrq6okT8L//wdixKEbanjV6PQQGqhsBtWwJCxeCkX94Ubq8/fbb6HQ65syZQ3p6OqCO/gkICCAsLIyxY8fyyiuv4OTkZGh7T0tLw9/fn8GDB2drOspJ586dadu2LUuXLiUzMxOAHTt2cPnyZapWrZrja0JCQvjpp58MP6enp1O1alUqP+j7qlatGnfv3gVg0qRJXL58mcaNG3Pq1ClD4tq1a1eO5z59+jR//vknAH///Tf79+/H29vbaPwTJkxg8+bNXL9+HYD4+HgWL15M06ZNc71ukTtZJbUwq6SWJnfvwpo1at/DmTO5FlV0OjTDhql9D089BeV4XaCUlBSuXLlCw4YN0ZXBfS1SU1NZsWIFBw8eRKvVotfradKkCW+99ZZheeSrV6/y+eefc/v2bdLS0ujQoQPTpk1Dp9Oxf/9+vv76a0JDQ+nUqRMjRoygT58+hvPHxsbyn//8hwsXLlC9enVq1KjBJ598YnRF2T///JNFixZx//59tFotmZmZTJkyhbZt2wLqzfzdd9/FwcEBV1dXw1DUTz75hCtXrtC0aVNatGjB4sWLcXd3Z+rUqWzbto39+/fz1FNPYW9vz99//20Ykvqvf/0LUGc0nzp1CkdHR1599VUmTZoEwKpVqwgODqZKlSpYWloyfvx4unbtWpy/klItt7/3/N73JCmUl6SQRVHg999h6VKUoCA0eS2098QTanIYMQIejPUuT8p6UhDCFEWRFKT5qLzRaODpp8HfX+17mD9fnUVtzOnT8MYbKM7OanI4dcpsoQohSh9JCuVZtWrw3nvqjOlff4Vhw1C02hyLahIS1M7rtm2hc2f48UdISjJvvEKIEidJoSLQaAz7NmgiIuCLL6BBA+Pljx6F0aPVzYDefRfOnzdXpEKIElYqkoJer2fevHm0aNGCyMjIXMsqisJ3331H//798fLyYtCgQaxfv95MkZYDtWrBhx/C33/Djh0wYACKkUlumjt31NFKLVpAjx6yGZAQFUCJT16LjIzE19eXBg0akJGRkWf5DRs2sHLlSrZt20adOnW4ceMG/fr1o1atWnnOrBSPsLCAPn2gTx91v4eVK9XZvlFROZcPCYGQEJSaNdGMGaMOiX1kNqoQonwo8ZpCUlISc+bMYdCgQfkqHxoaSsOGDQ3D8erUqUPDhg05ePBgcYZZvrm6wowZcPUqbN4MffqgGBmmqomJgdmzoXFjNals3gwPxtALIcq+Ek8Kbm5u1K9fP9/ln3vuOS5fvkxoaCigJomwsLA8J+qIfLCyggEDYMcONJcuqTOic1siY+dOGDhQ7Z/47DPjtQwhRJlR4knBVE8//TRffvklPj4+vPzyywwcOJA2bdrkuumIXq8nISEh20PkoVEj+OortWM6MFDtUzAmKgpmzkSpX19NEjt3woMZskKIsqXE+xRMFRISwvTp01m5ciWtWrUiIiKCbdu25ToxadmyZSw2YYVK8QgbGxg+XH2cP/9wM6A7dx4rqsnIUJuTNm9Wk8q4ceqCfE5O5o5aCFFAZa6mMH/+fHr37k2rVq0AdXndiIgIZs6cafQ148eP58SJE4ZHiJHtL0UemjeHBQvQREXBqlXqEhnGXL4MH3ygLsjn4aF2VFe8yfOFlpyczOLFi/H09MTb25vhw4fj4+NDQEAAcXFxeb5+9erV9OnTp8hWWi3MeY8ePcrGjRsL9b6JiYl4e3vTunXrPM81b948WrVqha+vb57nLa7PqSiYcs1FocwlhatXr+Li4pLtOVdXV6OLbIG68Yi9vX22hyiErOW8jxyBP/6AceNQ7OxyLKpJS1OHsvboYdgjghxqGeJxycnJjBw5koSEBPz9/QkICGDdunV4eXkxe/Zs1q5dm+c5Ro0axbhx44o8toKc99ixY2zatKlQ72tnZ0dAQAA187Ec/Pjx4/nggw/Ytm0b165dy7VscX1ORcGUay4KZS4p1KpVi5iYmGzPxcTEyLo2JaVtW1i2TF1SY8kSaNPGeNnz5+Gdd9QlNcaMgWPHpPaQCz8/P9LS0pg2bRpWVg9bep9//vlc+9CEysHBgcGDB2NhYcHFixdLOpwyo9T3Kfj6+mJhYcHcuXMBeO2111i1ahWvv/46zs7OREVFsX37dgYMGFDCkVZwjo7q2knjx6s1iKVLUdavz3FBPk1ystr8tGqVuifEhAlqE5MZa3AxiTF5FzLC3tqeStpKOR6LTYrNcfOYmnamfctLT08nKCiI8ePHZ9ujIMuYMWO4d+8eoC53vXr1arRaLcnJybRv3x5fX1+sra1zPf8333xDSEgIlStXJjk5mVdeeQUfHx+WL1/OunXrcHFxISAggPv37zNx4kSOHTuGv78/TxlpNswtjlWrVrFp0ybu3btnWA57xYoV6HQ60tPTWbBgAQcPHsTBwQFra2s++OAD3B6s2ZWYmMj06dM5efIkDRs2zLbKa34+R51Ox8WLF+ndu3e+XrN+/Xp27tzJ1atXDVuJZn3pzPrc9u3bh42NDba2tnz88ce4u7vn63P75ZdfWLJkCaGhoSxdupT169dz+fJlunXrxqeffmqIoTDXXFglnhT0ej1jx441/IFPnjyZ2rVrG3ZySk1NxeKRGbdjx45Fo9Hw5ptvotPpSEhIYPjw4UycOLFE4hf/oNFAly7QpQua+fPB319dztvYN7Ws5idfXzTe3mqCaN262MN0mlfwzu/FLy3mzU5v5nis+bfNiU2Kfex5ZYZpNaLLly+TkJBgdJOZ2rVrG7bX3LFjBxMmTKBHjx6kpaUxYcIEli9fzltvvWX0/H5+fhw+fJj169dja2vL8ePHmThxIj4+PowbN47U1FSOHTsGqN+4AwICaNasWa4x5xbH6NGjSUhI4NixY4/tu+zn58fp06cJDg7G2tqabdu2MXLkSPbs2YO9vT2zZ8/m2rVrbN++HZ1Oxw8//PDY/tPGfPPNNyQlJREWFpav8rGxsSQlJfHDDz+QmJjI8OHDWbhwIdOmTTPEeujQIdavX4+dnR3r169n9OjR7Nq1K1+fW58+fahatSojR47k0qVLLF26lLi4OHr06EHv3r3p3LkzQKGuubBKvPnI2tqagIAAtmzZwoULFwgKCsq2td/ixYuz/WxlZcW4cePYtGkTgYGBbN26lffeew8bG5uSCF/kpnr1hwvy7d0LQ4eiWOX8PURz/z58953a/NS1q7o3REqKmQMuPe4/2G7V1sjmSY/68MMP6d69OwBarZbevXtz4MABo+VTUlL48ccf8fDwMJy/Q4cOuW5okx+mxvFoLF5eXoaaTb9+/UhNTWXHjh0kJiayceNGPDw8DN/WR4wYka/VD86cOcO6devo0aNHvpNCRkaGoWnOzs6OIUOGEBgYSHp6uiFWT09P7B70oQ0ePJjMzEyCgoLydf5H9evXD4Dq1avTpEkTw9yrwlxzUSjxmoKoADQa6NULevVCc/Mm/PADLF8Oxjr/Dh2CQ4dQ3nkHzejRapNUBdtNy9HRESDbNpvGJCQk4Ovry/Xr19FqtcTExBjd8hLg2rVrpKamPjZp9O233y5UzKbG8Wgsy5cvz7ajW40aNbh37x4RERGkpaVRt25dwzEbGxuqVauW63kzMzOZPn06Xl5etGnThqlTp5KWlobWyCrBWapXr57tC2a9evVITk7m+vXrJCcnP/a5WVpa4uLiUqA+C6dHhmrb2dkZ5k8V9JqLSonXFEQFU7s2fPSRuiDfzz9Dv37GF+SLj4evv1b3g3j+ediwAdLSzBxwyWjUqBEODg5cunQp13JJSUmMGjWKatWqsXbtWgICAopkFM0/+zHy+pZa2DimTp1KQECA4bF7927Gjh2b7/j+KSAggDt37jBp0iSaNWtGWloaly9fznc8BWXK52b5yL7dGo0mx76o3M5dXKSmIEqGpSW8/DK8/DKa8HB1Mb7vv4ebN3Muv3ev+qhdG15/Hf71L6hXr8BvHz0lusCvtbc23iF+/s3zef5z54elpSUeHh788ssvOd5cJ0yYQMOGDenbty9xcXH06dPH0PeWlkfirF+/PjY2NkRERNCpUyfD8ytXrsTT05NKlSphZ2dHYmKi4ditW7dyPefly5fzjOPRm1pWX2FWLFeuXDG0pwOsWbOGZs2a0aJFC7RabbZY9Xp9rnM0bt26xcKFC5k/fz62trbUr18fa2trwsLC8uwXiY+PR6/XG5qywsPDqVSpEs7OzqSnp2NjY8O1a9cMsWRkZBAVFUXfvn0BTP7cclK3bl2Tr7koSU1BlLx69eDzzyE8XK0NPP+88bI3b8KsWSgNG0K/frBtGxSgrbWmXc0CP4yNPAKoYVsjx9cUxNtvv41Op2POnDmkP1h0UFEUAgICCAsLY+zYsbi4uKDT6fj9998B9Sa1d+/eXM+r0+nw8fEhMDDQ0Dy1f/9+du/eTaVK6rW5u7tz+fJl7t69C8C2bdtyPWd+4qhWrZrhfF9++SWHDh0yxPLTTz8Zjl29ehV/f3+aNGmCnZ0dgwYNIjAwkJQHfUxr1qzJNfHOmjWLZ5991rBqspWVFY0bN85Xv0JmZqahGSsxMZHg4GA8PDywsrLK9rklPdiAauPGjVhYWDB06NACfW45Kcg1FyXZo1kmspVOYWGwbBnKqlVqM1Ju6tVTl9QYO1atSTyirO/RnJqayooVKzh48CBarRa9Xk+TJk146623DCsF7969m3nz5uHo6IiTkxOOjo5s27aNdu3a0atXLwIDA4mKiuLJJ598bBhoSEgIVapUwd7enhkzZhjOCTBz5kwOHz5MgwYNGDp0KBMnTsTd3Z033niDW7duPXbeAwcOGI1j9erVxMXFMX78eLRaLQ4ODixevBhra2vS09NZuHAhu3fvpkaNGmi1WiZPnkzrB6PQHh2eWb9+fbp3746/vz/W1tZ4eXnh5eVliPm3335j6tSpbN++Pdtkr6lTp3L//n2WLFmS4+e8evVqAgMD0ev1eHl5sX//fsLDw/M1JPWjjz6iefPm+frcbG1t+frrrwkNDaVTp04sWrSI2bNns3v3bhwdHfH09OT111836ZofVRR7NEtSkKRQuqWkQHCwulXooUO5FlWsrNAMHKgOa+3ZEzSaMp8UhDBFUSQFaT4SpZtOB97ecPAg/PknTJyI4uCQY1FNerqaQJ57DtzdYf58uH3bzAELUbZJUhBlR+vW8O236pIay5erS2wYc/Ei+PqidO8OsbGQmChLagiRD5IURNljb6+OPjpxQl0/acwYlEo5d/5q9Ho1IVy5AufOQXS07BQnRC4kKYiyS6OBjh1h5Uq19uDnBy1aGC+fnAzh4Sh//qluPfrI0EEhhEqSgigfqlSBt9+GM2dg/37w9EQxsiCcJjNTbVI6f16tPcTEFGhYqxDlkSQFUb5oNNCtG/z0E5rISJgyBSwtMdqbkJQE166ptYfwcPVnIcqoohhMKjOaRflVsybaN96ACxdIcnCgUmoqyp075LRYgCYjQ+1viI5W+yxq1oSqVcHIEhxClEZZk+ryWuMpN5IURLlmaWlJlapVib5zB5ycsHVyUveXvn3b+DpKCQmQkIASHo6mShWoVk3dq1qIUkpRFJKSkoiOjqZKlSrZ1lUylSQFUe5l7TsQHf3IekdardqPcP++2gFtTNbaNTqdWoOwtVWbqIQohapUqWL4ey8oSQqi3NNoNNSpUwcnJ6ecF4uLilInvW3YoHZA50KpXh3Na6/B0KHg6lpMEQthOq1WW6gaQhZZ5kKWuRBZ0tJgyxZ1SY09e3Itqmg0aF58Ud3roV8/MLJ5kBClhSxzIYSptFoYPBh271ZnRE+ZglK9eo5FNYoCv/wCAwdCgwYwYwZERJg3XiGKgSQFIXLStCnMnasOa/3pJ3j2WeNlo6Lg3/9GadAA+vdXNw+SeQ+ijJKkIERudDrw9ISQEDh7FiZNQqlSJceimsxM2LpVbU5q1EjdI+L6dfPGK0QhSVIQIr9atICFC9FERcGqVfDUU8bLhofD9Oko9erBoEGwcydkZpovViEKqNBJISMjg7CwMLZv384333zDm2++WRRxCVF62dqCjw8cOQInT8KECShGOu40GRmwaRP06QNNmsBXXz0c5ipEKWTSkImIiAguXLhAWFiY4XH16lXS09PRarU0btwYNze34opViNLnySdhyRI0c+dCYCAsXQp//JFz2StX4MMPUaZPR/Pqq+rIpZ49Zda0KFXyPSR1ypQp/Pzzz2g0GnQ6HcnJyXTv3p0BAwbg5uZGgwYNimSMrDnIkFRRrI4fV7cSXbsWTV5rKTVpom4l6uOjLq0hRDEp8iGpO3fu5JNPPuHkyZMcOHCAESNGcOjQIf766y9cXFzKTEIQoth16AArVqjLeX/7LbRpY7zspUswdSqKqyt4eMC+fbIZkChR+U4KPj4+DBgwABsbG+zs7Pjkk08IDAzk6NGj9O3bl/379xdnnEKUPZUrw8SJcOoU/P47+PigGNknWqPXw7p1anNS8+bqVqJxceaNVwiKYEazoij4+/vj5+dHjx49+Pjjj6lWrVpRxVcspPlIlJjbtyEgQJ01fe5crkUVGxs0gwerzUvdusmaS6JQzDajWaPRMGrUKLZv345er+ell14q7CmFKL+qVoVJk9TNgA4cAC8vFCMrsGpSU9WJc927q8NhFyyQ2oModkU27KFWrVosWrSI2bNnF9UphSi/NBro2hUCAtR5D/PnQ7NmxsuHhsLkySguLuDlpe4uJ30PohgU+Vi4Hj16FPUphSjfqleH995Ttwfdtw88PIxvJfpo7aFlS/jmG4iPN2u4onyTAdJClBYajXqzX7tWrT18/TXkNu/n/Hl47z0UZ2fw9labo6T2IApJkoIQpVGNGjB5stps9NtvMHw4ipEtFjWpqbBmjbpoX1btQfoeRAFJUhCiNNNooEcPCAxUaw9z56oruBqTVXuQvgdRQJIUhCgrataEKVPgwgX49VcYNiz32sOjI5fmz89zVzkhQJKCEGWPRqNOclu3Tq09zJuXe+0hNBR8fdXag6enzJoWuZKkIERZVrMm+PqqtYfffst95JJery7a17OnOvx17lyIjjZzwKK0k6QgRHmQ1feQNXJp3rzcRy6FhT1cc2noUHVPatnvQSBJQYjyp0YNtfYQGqruGDdihPFZ02lpEBwMvXurTVBffgk3b5o5YFGaSFIQorzSaNRhqmvWqLWHBQvUxfaMuXwZPvoIpW5ddbe4HTtkr+kKSJKCEBVB9erw7rvqPtMHDsDIkcZXbE1PV3eLe/llda/pmTMhIsK88YoSI0lBiIoka82l1avV/R78/KBVK+Plw8Phs89QGjSAfv1gyxZITzdbuML8JCkIUVFVrQpvvw1//qnu9zB6NIqtbY5FNZmZ8PPP8OqrUK8efPyxur2oKHckKQhR0Wk00Lkz/PCDWntYsgTatjVe/sYN+OILtWmpd28ICoLUVPPFK4qVJAUhxEOVK8OECfDHH+pe0+PGoeS2EdWePerMaldXdcTT+fPmi1UUC0kKQoictW8Py5ahuXEDvv8ennrKaFFNbKy6lEaLFuoucatXQ1KSGYMVRaXQ23GWRVnb0u3cvxM7ezuTX29vbU8lbaUcj8UmxVLQj9RWa4uddc7xxCfHk5FZsOGBOisdDjYOOR67k3KHtIy0Ap3X2tKayrrKOR67m3IXfYa+QOfVWmqpoquS47H7qfdJSU8p0HktLSypVinnrWIT9YkkpRXsJqbRaKhhWyPHY8lpySToEwp0XoCadjVzfD41PZV7qfcKfN7qttWx0Dz+nVCfoeduyl3jLzx3Ftb8hBIchObu4+9fNQWsHsyBUxwd0YwYAW+8QXrL5txOvl3geCvrKmNt+fhM7Uwlk7ikgq8I62jjiI1VznM4YhJjCnze0niPSExI5MVnX8xzO84KnRQuDblEptb0WZyLX1rMm53ezPFYzbk1iU0q2MJjM7rP4LMen+V4rOV3LTkXk/uevsZM7DCRb/t+m+OxHj/2IORaSIHOO7jFYIKHBOd4bEjwEDac21Cg83av3519PvtyPPbmz2/y3fHvCnTeFjVbcHbi2RyPfbbvM2aGzCzQeWvY1iDm/ZxvIN8e+5a3drxVoPMCKDNy/vcMPhvM0A1DC3ze6CnROSacfVf30XN1zwKf98y30PIfH4ViZcW55f+hVfi0Ap/3t1G/0aNBj8eej0mMwWmeU4HPGzQ4iCEth+R4TDOz4Htil8Z7hEWaBU2CmxT/Hs1FQa/XM2/ePFq0aEFkZGSe5ePi4vjggw/w9vZmwIABDBgwgJCQgt3YhBDFS5OeTtSiZSUdhsinEk8KkZGReHt7ExMTQ0Y+Zk/q9Xp8fHzo1q0bAQEBbNmyBXd3dy5cuGCGaIUQuVqwAF58EUWT/Vv2JaucmxlF6WNV0gEkJSUxZ84cbt68yebNm/MsHxQUhJ2dHX379jU8N3nyZFJlSJwQJa93bxjxLppr12DVKggJ4b5jNa717Qs3xpZ0dCIfSk2fwtGjRxk5ciR79+7F1dXVaLmRI0fSpk0bpkyZUuD3ko7mh6SjWSUdzao8O5rzULVSVawsHv+umZ6Zzs37sey7EMPmk1EcvRJvOFalkhV92zjzalsXGtfMua1bOppVFaqjOb9JoUuXLowYMYLo6GguXryItbU1gwYN4tVXXzX6Gr1ej17/8AaVkJBA9+7d8/xwhBDFIyI+iaDjEQQdj+DWvYe1/Lb1qjC8Y136tXHGzqbEGzLKlawvw3nd98rcp37v3j2WLVvG0qVL+fe//01oaCienp7o9XqGDs15NMayZctYvHixmSMVQhhTt5otvi80453nmrI/LIb1/4tg7/loTobf4WT4HWZuPUe/NnUY1rEe7epVQaMp+EggYZoylxQsLCx44okneOaZZwBwd3enb9+++Pv7G00K48ePZ/To0Yafs2oKQoiSZWVpQS/3WvRyr0X0/RQ2/hFF0P8iuBybSNDxSIKOR9LEyZ7hHesysK0L1e1zbuoRRafERx+Zqnbt2tSqVSvbc87OzrkOZbW2tsbe3j7bQwhRujg56JjQvTF7fbsTNL4Lg9q5oNNacCk6gVk/n6fzl3t5Y80JfrsQTUZmqWj1LpfKXE2hY8eORPxjbfe4uDjq1KlTQhEJIYqSRqOhU8NqdGpYjc/6t2Tr6esE/S+C05F32XHmJjvO3KROZR2D27sytENd6lbLeWVXUTClvqbg6+vL+++/b/jZx8eHv/76i3Pn1Jl70dHRbN++nREjRpRUiEKIYuKo0zLiqfpseasrv7zbjdHPNKCKrZYbd1NY9Oslus35Dc8VR9hyKoqUNNklriiUeE1Br9czduxY7t1Th9dNnjyZ2rVr4+fnB0BqaioWFg9zl5ubG4sWLWL69OlYWVmRkZHBG2+8IUlBiHLOvbYjM15pyQcvubP73C3W/y+Cg5diOfx3HIf/jsNRZ8WAJ10Y2qEurVwcpXO6gErNkFRzyu/QLCFE6RZ5O4ng45FsOBFJ1J1kw/PN6zgytIMrrz7pQlW7x+c3VET5ve9JUpCkIESZl5mpcOjvWIKOR7LzzE30GepCl9aWFvRuWYthHeryTJMaWFpU3NpDuZ2nIIQQ/2RhoaFb05p0a1qTO0l6tpy6TtDxCM5ev8fPf97g5z9v4Pygc3pw+7rUqy6d08ZITUFqCkKUW2ei7hJ8PILNp65zN/nhci5dGlVnaEdX+rSsQyVryxKM0Hyk+SgXkhSEqFhS0jLYde4WwcfVzumsu56DjRWvPOnMkPauPFm3fM+cluYjIYR4QKe1pP8TzvR/wpmoO8lsOB7Jhj8iiIhPZu3RcNYeDaepkz1DOrgysK0rNR0q7sxpqSlITUGICikzU+HIlTiCj0ey48wNUtLUzmlLCw09m9VkSIe69HJ3QmtZ6qdz5YvUFIQQIhcWFhqeblyDpxvXYOaAlmw7fYOg4xGcirjDnvPR7DkfTXU7a15tq859aFY75+XnyxupKUhNQQjxiLBb99lwIpL/+yOK2ISHy3q3ca3MkPauvPKEM1Vsy97cB+lozoUkBSFEXtIzMgm5GEPw8Uj2ht4iLUO9VWbNfRjS3pVuTWuWmbkP0nwkhBCFYGVpwXPNa/Fc81rEJaSy5dR1gk9Ecv7Gw7kPtRxtGNTOlcHtXY3uGlfWSE1BagpCCBOcibrLhhORbD4VxZ2kh3Mf2tWrwpAOdenbpg6OOm0JRpgzaT7KhSQFIURhpaZn8Ov5aIJPRBJyMcawx4NOa0GflrUZ3L4uXRpXLzXNS9J8JIQQxcjGypKXWtfhpdZ1iL6XwuZTUQQfjyQsOoHNp66z+dR1nCvrGNjOhdfaudKojDQvSU1BagpCiCKiKAqnI+/yfyci2XIqinsp6YZj7etX5bV2rvR7omSal6T5KBeSFIQQxS0lLYM952/xfw+al7J2ELWxsuCFlrUZ3N6VrmZcuVWaj4QQogTptJb0a+NMvzbORN9LYdPJKDacUJuXtp6+ztbT16nlaMPAtq4Mbu9CE6fSMTlOagpSUxBCmImiKPz1YPTSf09fzzZ66QnXyrzW3pVX2jgXy8ZA0nyUC0kKQoiSlpqewW+h0Ww4Ecm+CzGkP2hf0lpq6OXuxGvtXOlZhGsvSfOREEKUYjZWlvRpVYc+reoQm5DKf09dZ8OJSM7duMfOs7fYefYW1eys6f+EM4Pbu9LS2Tz7TktNQWoKQohS5PyNe2z8I5JNJ69nW3upWS0HBrVz4dW2LtRy1Jl8Xmk+yoUkBSFEaZeekcmBS7H834lIdp27hT5dXdpba6nhp9c706lhNZPOJ81HQghRhllZWtCzmRM9mzlxNzmN7X/dYOMfkZy9fq9437dYzy6EEKLQKlfS4tGpHh6d6hX7e5WPLYWEEEIUCUkKQgghDCQpCCGEMKiQfQpZA64SEhJKOBIhhDCPrPtdXgNOK2RSSExMBKB79+4lHIkQQphXYmIiDg7G11mqkPMUMjMziY6Oxs7OzuQZggkJCXTv3p2QkJByPcdBrrP8qSjXKteZM0VRSExMxMnJCQsL4z0HFbKmYGFhQe3atQt1Dnt7+3L9B5dFrrP8qSjXKtf5uNxqCFmko1kIIYSBJAUhhBAGkhRMZG1tzVtvvYW1ddGvd16ayHWWPxXlWuU6C6dCdjQLIYTImdQUhBBCGEhSEEIIYSBJQQghhEGFnKeQl927d7N06VJsbGywsLBgxowZNG3atMjKlxamxL19+3Y2bNhARkYGCQkJuLi4MHXqVFxdXc0ctekK+vtZs2YNn3/+Of7+/jz11FNmiLTwTL3WiIgI5syZw507d4iPj8fOzo5PP/2U1q1bmzFq05lynXq9nnnz5nHkyBEcHR1JTU1l3Lhx9O7d28xRm06v1+Pn58cPP/zArl278vx/O378OHPmzMHa2hq9Xs/UqVPp0KGDaW+qiGxOnz6ttG3bVrly5YqiKIqyadMmpVu3bsr9+/eLpHxpYWrcLVu2VPbv368oiqJkZGQo77//vvLiiy8qqamp5gq5QAr6+7l586bSo0cPxc3NTTly5IgZIi08U681Li5O6dmzp3Ls2DFFURQlLS1N8fb2VrZt22aukAvE1OtcsGCB0rNnT+XevXuKoijK2bNnlZYtWyrnz583V8gFEhERoQwdOlSZOnWq4ubmpkRERORaPjIyUmnXrp3yv//9T1EURTl69KjSrl07JTIy0qT3leajf1i+fDk9evSgQYMGAPTv35+MjAw2bdpUJOVLC1Pj7tWrF926dQPUGeHe3t5cuXKFs2fPmivkAino72fWrFmMHz/eDBEWHVOvdcWKFbRt25aOHTsCYGVlxeeff276N0szM/U6Q0NDad26tWE2b4sWLXBwcODIkSPmCrlAkpKSmDNnDoMGDcpXeX9/f5o0aWL4/XXq1ImGDRsSEBBg0vtKUviH33//nVatWhl+trCwoGXLlhw+fLhIypcWpsbt5+eX7WcbGxtArd6WZgX5/fz6669YWVnRtWtXc4RYZEy91l27dj2WAOrXr0+tWrWKNc7CMvU6X3jhBU6cOMH169cBOHDgAPHx8VSvXt0s8RaUm5sb9evXz3f5f34uAK1btzb5XiR9Co+4ffs2CQkJj/2x1KhRg7/++qvQ5UuLooj71KlTODk50a5du+IIsUgU5DqTkpJYsGABK1euLPUJ71GmXmtSUhKRkZFkZmbi6+tLVFQUdnZ2jBw5slSvHlyQ3+mgQYNITk6mf//+1KxZk6tXr/Liiy/y0ksvmSNks4mIiKBPnz7ZnqtRowaRkZEmnUeSwiNSUlIAHpshaG1tbThWmPKlRWHj1uv1rFy5kunTp6PVaoslxqJQkOtcuHAhw4cPx8nJyeR/ppJk6rXev38fUK/X398fd3d3fv/9d8aOHcuKFSt45plnij/oAijI7zQ4OJgVK1awceNG6tWrR2hoKIcPH851pdCyKCUlpUjuReXrUykknU4HPN4kotfrDccKU760KGzc06dP56WXXir1ozdMvc6zZ89y+vRpPDw8zBJfUTL1WrNuiD179sTd3R2ALl260LlzZ/z9/Ys52oIz9ToVRWHu3LkMGzaMevXUTe/d3d0JCQlh6dKlxR+wGel0uiK5F0lN4RFVq1bFwcGBuLi4bM/HxsZSt27dQpcvLQoT97x589DpdLz77rvFGGHRMPU69+3bR2pqKqNGjQIgNTUVgC+++AJHR0dmzZplUhuvOZl6rdWqVcPa2vqx/gNnZ2dOnjxZrLEWhqnXGR8fz927d3Fxccn2vKurK7t27WLixInFGq851a1bt0juRVJT+IfOnTtnG1GjKArnzp3j6aefLpLypUVB4l6+fDk3btxg+vTpAJw5c4YzZ84Ue6yFYcp1vvnmm2zatImAgAACAgKYP38+AB999BEBAQGlNiFkMeVaLS0tadeuHTExMdmej42NpU6dOsUea2GYcp1Vq1bF2tr6seuMiYkp1bX5gujSpctjowHPnDlj8r1IksI/jBs3jn379nHt2jUA/vvf/2JhYcGrr74KgIeHBwsWLMh3+dLK1OsMDAzkv//9L97e3pw9e5a//vqL3377jYsXL5ZE+Plm6nWWZaZe67/+9S/27t1rGJVz6dIlDh06xIgRI8weuylMuU4LCwsGDhxIcHAwd+/eBdRmwsOHD5f5jmZfX1/ef/99w88jR44kLCyMEydOAOpEtsuXL+Pl5WXSeaX56B/atGnDV199xXvvvYdOp8PCwoKVK1cadjZKSUnJ1m6XV/nSypTrTEhI4N///jeZmZkMGzYs23m+/PJLs8duClN/n1n+85//cPr0aUBtPmrUqFGpTx6mXmvXrl35+OOPmThxIra2tmRkZDB79mx69uxZUpeQL6Ze54cffsiiRYvw8fFBp9ORmJiIr68vI0eOLKlLyBe9Xs/YsWO5d+8eAJMnT6Z27dqG4eGpqanZOstdXFxYtmwZs2fPRqvVotfrWbZs2WNNZ3mRpbOFEEIYSPOREEIIA0kKQgghDCQpCCGEMJCkIIQQwkCSghBCCANJCkIIIQwkKQghhDCQpCCEEMJAkoIQQggDSQpCCCEMZO0jIYrZ6tWrCQwMRK/X4+npycGDBwkPD6djx47MnDmz3K3WKco2qSkIUcxGjRrFuHHjuHnzJhqNhh9//JGtW7dy7tw5Fi5cWNLhCZGNJAUhzESj0RiWMbazs2PIkCEEBgaSnp5ewpEJ8ZAkBSHMpHr16tjY2Bh+rlevHsnJyYb9DIQoDSQpCCGEMJCkIISZxMfHZ9v8JTw8nEqVKuHs7FyCUQmRnSQFIczEwsKCtWvXApCYmEhwcDAeHh5YWckgQFF6yF+jEGZSo0YNKlWqxNixY7ly5QodO3bknXfeKemwhMhGkoIQZjRs2LDH9rkWojSR5iMhhBAGkhSEKGarV69m+fLlxMTE4O3tTUpKSkmHJIRRGkVRlJIOQgghROkgNQUhhBAGkhSEEEIYSFIQQghhIElBCCGEgSQFIYQQBpIUhBBCGEhSEEIIYSBJQQghhIEkBSGEEAb/D774Xs7SXF71AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"selfish_f.svg\")\n",
    "# plt.savefig(\"test_f.svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 2. **Calculated egalitarian fairness bound** in Purely Altruism v.s. **Obtained egalitarian fairness**"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Full-connected Friendship"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [],
   "source": [
    "friends = {}\n",
    "for i in range(len(clients_dataset_num)):\n",
    "    friends[str(i)]=[]\n",
    "    for j in range(len(clients_dataset_num)):\n",
    "        if j!=i:\n",
    "            friends[str(i)].append(j) \n",
    "w=0.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "# friends = {}\n",
    "# for i in range(len(clients_dataset_num)):\n",
    "#     friends[str(i)]=[]\n",
    "#     friends[str(i)].append((i+1)%len(clients_dataset_num)) \n",
    "#     # friends[str(i)].append((i+2)%len(clients_dataset_num)) \n",
    "#     friends[str(i)].append((i-1)%len(clients_dataset_num) )\n",
    "# friends"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "# friends ={'0': [1,1], '1': [0,3], '2': [3,3], '3': [1,2]}\n",
    "# friends ={'0': [3,3], '1': [2,3], '2': [1,1], '3': [0,1]}\n",
    "# friends ={'0': [3], '1': [2], '2': [1], '3': [0]}\n",
    "# # wfriends ={'0': [3,2], '1': [2,2], '2': [0,1], '3': [0,0]}\n",
    "# friends ={'0': [1,2,3], '1': [0,0,0], '2': [0,0,0], '3': [0,0,0]}\n",
    "# friends ={'0': [1,2,2], '1': [0,3,3], '2': [0,0,0], '3': [1,1,1]}\n",
    "# friends ={'0': [1,2], '1': [0,2], '2': [0,1], '3': [2,2]}\n",
    "# w=0.3\n",
    "# # w=0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "# clients_dataset_array = np.array(clients_dataset_num)\n",
    "# coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "# m = np.argmin(clients_dataset_array)\n",
    "# l=np.argmax(clients_dataset_array)\n",
    "# N_g=np.sum(clients_dataset_array)\n",
    "# N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "# lambdas_cal=[]\n",
    "# friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "# friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "# for i,coalition in enumerate(coalitions_except_grand):\n",
    "#     if row_ids[i]==\"10000\":\n",
    "#         print()\n",
    "#     # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "#     # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "#     # if  row_ids[i][f_opt]==\"1\":\n",
    "#     #     N_s=np.sum(coalition)\n",
    "#     #     N_s_2_sum=np.sum(coalition**2)\n",
    "#     # else:\n",
    "#     #     N_s=N_g-np.sum(coalition)\n",
    "#     #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "#     # k_list\n",
    "#     c_in_c=[]\n",
    "#     f_in_c=[]\n",
    "#     f_in_c_num=[]\n",
    "#     for j in range(len(row_ids[i])):\n",
    "#         if row_ids[i][j]==\"1\":\n",
    "#             c_in_c.append(j)\n",
    "#             f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "#             # f_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='1' else float('inf') for f in friends[str(j)]])\n",
    "#             f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "# )\n",
    "#     f_in_c=np.array(f_in_c)\n",
    "#     f_in_c_num=np.array(f_in_c_num)\n",
    "#     k = np.argmin(np.min(f_in_c_num, axis=1))\n",
    "#     # f_opt=f_in_c[k,np.argmin(f_in_c_num[k])]\n",
    "#     f_opt=friends_array[c_in_c[k],np.argmin(friends_num_array[c_in_c[k]])]\n",
    "#     N_s=np.sum(coalition)\n",
    "#     N_s_2_sum=np.sum(coalition**2)  \n",
    "    \n",
    "#     if row_ids[i][f_opt]==\"0\":\n",
    "#         N_s=N_g-N_s\n",
    "#         N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "#     if f_opt!=None:\n",
    "#         lambdas_cal.append((N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f_opt]**2+(N_s-clients_dataset_array[f_opt])**2)))\n",
    "        \n",
    "# lambda_cal= max(lambdas_cal) \n",
    "# lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.079331485680692"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "    # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "    # if  row_ids[i][f_opt]==\"1\":\n",
    "    #     N_s=np.sum(coalition)\n",
    "    #     N_s_2_sum=np.sum(coalition**2)\n",
    "    # else:\n",
    "    #     N_s=N_g-np.sum(coalition)\n",
    "    #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "    # k_list\n",
    "    c_in_c=[]\n",
    "    f_in_c=[]\n",
    "    f_in_c_num=[]\n",
    "    f_not_in_c=[]\n",
    "    f_not_in_c_num=[]\n",
    "    for j in range(len(row_ids[i])):\n",
    "        if row_ids[i][j]==\"1\":\n",
    "            c_in_c.append(j)\n",
    "            f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "            f_not_in_c.append(np.array([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ]))\n",
    "            f_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='1' else float('inf') for f in friends[str(j)]]))\n",
    "            f_not_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='0' else float('inf') for f in friends[str(j)]]))\n",
    "            # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "\n",
    "    f_in_c=np.array(f_in_c)\n",
    "    f_in_c_num=np.array(f_in_c_num)\n",
    "    f_not_in_c=np.array(f_not_in_c)\n",
    "    f_not_in_c_num=np.array(f_not_in_c_num)\n",
    "    k_1 = np.argmin(np.min(f_in_c_num, axis=1))\n",
    "    k_2 = np.argmin(np.min(f_not_in_c_num, axis=1))\n",
    "    # f_opt=f_in_c[k,np.argmin(f_in_c_num[k])]\n",
    "    f_opt_1=f_in_c[k_1,np.argmin(f_in_c_num[k_1])]\n",
    "    f_opt_2=f_not_in_c[k_2,np.argmin(f_not_in_c_num[k_2])]\n",
    "\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)  \n",
    "    Not_N_s=N_g-N_s\n",
    "    Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "\n",
    "    lambda1=lambda2=float('inf')\n",
    "    if f_opt_1!=None:\n",
    "        lambda1=(N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f_opt_1]**2+(N_s-clients_dataset_array[f_opt_1])**2))\n",
    "    if f_opt_2!=None:\n",
    "        lambda2=(Not_N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f_opt_2]**2+(Not_N_s-clients_dataset_array[f_opt_2])**2))\n",
    "\n",
    "\n",
    "    lambdas_cal.append(min(lambda1,lambda2))\n",
    "        \n",
    "lambda_cal= max(lambdas_cal) \n",
    "lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [],
   "source": [
    "# clients_dataset_array = np.array(clients_dataset_num)\n",
    "# coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "# m = np.argmin(clients_dataset_array)\n",
    "# l=np.argmax(clients_dataset_array)\n",
    "# N_g=np.sum(clients_dataset_array)\n",
    "# N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "# lambdas_cal=[]\n",
    "\n",
    "# for i,coalition in enumerate(coalitions_except_grand):\n",
    "#     # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "#     # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "#     # if  row_ids[i][f_opt]==\"1\":\n",
    "#     #     N_s=np.sum(coalition)\n",
    "#     #     N_s_2_sum=np.sum(coalition**2)\n",
    "#     # else:\n",
    "#     #     N_s=N_g-np.sum(coalition)\n",
    "#     #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "#     # k_list\n",
    "#     c_in_c=[]\n",
    "#     f_in_c=[]\n",
    "#     f_in_c_num=[]\n",
    "#     f_not_in_c=[]\n",
    "#     f_not_in_c_num=[]\n",
    "#     for j in range(len(row_ids[i])):\n",
    "#         if row_ids[i][j]==\"1\":\n",
    "#             c_in_c.append(j)\n",
    "#             f_in_c.append([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ])\n",
    "#             f_not_in_c.append([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ])\n",
    "#             f_in_c_num.append([clients_dataset_array[f] if row_ids[i][f]=='1' else float('inf') for f in friends[str(j)]])\n",
    "#             f_not_in_c_num.append([clients_dataset_array[f] if row_ids[i][f]=='0' else float('inf') for f in friends[str(j)]])\n",
    "#             # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "#     k_1 = np.argmin(np.min(f_in_c_num, axis=1))\n",
    "#     k_2 = np.argmin(np.min(f_not_in_c_num, axis=1))\n",
    "#     # f_opt=f_in_c[k,np.argmin(f_in_c_num[k])]\n",
    "#     f_opt_1=f_in_c[k_1][np.argmin(f_in_c_num[k_1])]\n",
    "#     f_opt_2=f_not_in_c[k_2,np.argmin(f_not_in_c_num[k_2])]\n",
    "\n",
    "#     N_s=np.sum(coalition)\n",
    "#     N_s_2_sum=np.sum(coalition**2)  \n",
    "#     Not_N_s=N_g-N_s\n",
    "#     Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "\n",
    "#     lambda1=lambda2=float('inf')\n",
    "#     if f_opt_1!=None:\n",
    "#         lambda1=(N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f_opt_1]**2+(N_s-clients_dataset_array[f_opt_1])**2))\n",
    "#     if f_opt_2!=None:\n",
    "#         lambda2=(Not_N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f_opt_2]**2+(Not_N_s-clients_dataset_array[f_opt_2])**2))\n",
    "\n",
    "\n",
    "#     lambdas_cal.append(min(lambda1,lambda2))\n",
    "        \n",
    "# lambda_cal= max(lambdas_cal) \n",
    "# lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.555556   0.888889\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.734694       NaN   0.877551\n",
      "0110       NaN  1.728395  1.506173        NaN\n",
      "0111       NaN  1.495845  1.390582   0.864266\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.222222       NaN       NaN   0.888889\n",
      "1010  2.448980       NaN  1.591837        NaN\n",
      "1011  1.799308       NaN  1.446367   0.858131\n",
      "1100  2.555556  1.888889       NaN        NaN\n",
      "1101  1.843750  1.593750       NaN   0.843750\n",
      "1110  1.917355  1.553719  1.371901        NaN\n",
      "1111  1.614512  1.424036  1.328798   0.852608\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.917355\n",
      "0010       NaN       NaN  1.843750        NaN\n",
      "0011       NaN       NaN  2.555556   2.555556\n",
      "0100       NaN  1.799308       NaN        NaN\n",
      "0101       NaN  2.448980       NaN   2.448980\n",
      "0110       NaN  2.222222  2.222222        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.495845       NaN       NaN        NaN\n",
      "1001  1.728395       NaN       NaN   2.222222\n",
      "1010  1.734694       NaN  2.448980        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.888889  2.555556       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.553719  1.917355  1.917355        NaN\n",
      "1111  1.424036  1.614512  1.614512   1.614512\n",
      "1.893617021276596\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.551842   0.890760\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.731038       NaN   0.879026\n",
      "0110       NaN  1.724965  1.508945        NaN\n",
      "0111       NaN  1.492025  1.389363   0.866426\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.219316       NaN       NaN   0.889477\n",
      "1010  2.445329       NaN  1.593318        NaN\n",
      "1011  1.796464       NaN  1.444549   0.859623\n",
      "1100  2.551851  1.890769       NaN        NaN\n",
      "1101  1.840622  1.591855       NaN   0.845149\n",
      "1110  1.914230  1.552729  1.373976        NaN\n",
      "1111  1.607330  1.415700  1.320944   0.861582\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.914230\n",
      "0010       NaN       NaN  1.840622        NaN\n",
      "0011       NaN       NaN  2.551851   2.551851\n",
      "0100       NaN  1.796464       NaN        NaN\n",
      "0101       NaN  2.445329       NaN   2.445329\n",
      "0110       NaN  2.219316  2.219316        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.492025       NaN       NaN        NaN\n",
      "1001  1.724965       NaN       NaN   2.219316\n",
      "1010  1.731038       NaN  2.445329        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.890769  2.551851       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.552729  1.914230  1.914230        NaN\n",
      "1111  1.415700  1.607330  1.607330   1.607330\n",
      "1.87389266638678\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.548140   0.892655\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.727391       NaN   0.880523\n",
      "0110       NaN  1.721565  1.511750        NaN\n",
      "0111       NaN  1.488215  1.388173   0.868614\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.216410       NaN       NaN   0.890081\n",
      "1010  2.441699       NaN  1.594832        NaN\n",
      "1011  1.793621       NaN  1.442750   0.861135\n",
      "1100  2.548175  1.892691       NaN        NaN\n",
      "1101  1.837496  1.589978       NaN   0.846570\n",
      "1110  1.911119  1.551775  1.376081        NaN\n",
      "1111  1.600375  1.407631  1.313392   0.870805\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.911119\n",
      "0010       NaN       NaN  1.837496        NaN\n",
      "0011       NaN       NaN  2.548175   2.548175\n",
      "0100       NaN  1.793621       NaN        NaN\n",
      "0101       NaN  2.441699       NaN   2.441699\n",
      "0110       NaN  2.216410  2.216410        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.488215       NaN       NaN        NaN\n",
      "1001  1.721565       NaN       NaN   2.216410\n",
      "1010  1.727391       NaN  2.441699        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.892691  2.548175       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.551775  1.911119  1.911119        NaN\n",
      "1111  1.407631  1.600375  1.600375   1.600375\n",
      "1.8540461249182085\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.544450   0.894574\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.723752       NaN   0.882043\n",
      "0110       NaN  1.718193  1.514588        NaN\n",
      "0111       NaN  1.484413  1.387014   0.870831\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.213505       NaN       NaN   0.890699\n",
      "1010  2.438089       NaN  1.596380        NaN\n",
      "1011  1.790781       NaN  1.440970   0.862666\n",
      "1100  2.544529  1.894653       NaN        NaN\n",
      "1101  1.834373  1.588121       NaN   0.848013\n",
      "1110  1.908024  1.550858  1.378216        NaN\n",
      "1111  1.593646  1.399830  1.306146   0.880273\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.908024\n",
      "0010       NaN       NaN  1.834373        NaN\n",
      "0011       NaN       NaN  2.544529   2.544529\n",
      "0100       NaN  1.790781       NaN        NaN\n",
      "0101       NaN  2.438089       NaN   2.438089\n",
      "0110       NaN  2.213505  2.213505        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.484413       NaN       NaN        NaN\n",
      "1001  1.718193       NaN       NaN   2.213505\n",
      "1010  1.723752       NaN  2.438089        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.894653  2.544529       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.550858  1.908024  1.908024        NaN\n",
      "1111  1.399830  1.593646  1.593646   1.593646\n",
      "1.8341050916430295\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.540772   0.896516\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.720121       NaN   0.883584\n",
      "0110       NaN  1.714851  1.517459        NaN\n",
      "0111       NaN  1.480621  1.385884   0.873075\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.210600       NaN       NaN   0.891332\n",
      "1010  2.434500       NaN  1.597963        NaN\n",
      "1011  1.787944       NaN  1.439208   0.864217\n",
      "1100  2.540913  1.896657       NaN        NaN\n",
      "1101  1.831253  1.586283       NaN   0.849479\n",
      "1110  1.904946  1.549977  1.380382        NaN\n",
      "1111  1.587147  1.392301  1.299208   0.889982\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.904946\n",
      "0010       NaN       NaN  1.831253        NaN\n",
      "0011       NaN       NaN  2.540913   2.540913\n",
      "0100       NaN  1.787944       NaN        NaN\n",
      "0101       NaN  2.434500       NaN   2.434500\n",
      "0110       NaN  2.210600  2.210600        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.480621       NaN       NaN        NaN\n",
      "1001  1.714851       NaN       NaN   2.210600\n",
      "1010  1.720121       NaN  2.434500        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.896657  2.540913       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.549977  1.904946  1.904946        NaN\n",
      "1111  1.392301  1.587147  1.587147   1.587147\n",
      "1.814096531729404\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.537107   0.898482\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.716500       NaN   0.885149\n",
      "0110       NaN  1.711537  1.520364        NaN\n",
      "0111       NaN  1.476838  1.384785   0.875348\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.207695       NaN       NaN   0.891981\n",
      "1010  2.430931       NaN  1.599580        NaN\n",
      "1011  1.785109       NaN  1.437465   0.865788\n",
      "1100  2.537328  1.898703       NaN        NaN\n",
      "1101  1.828135  1.584464       NaN   0.850968\n",
      "1110  1.901883  1.549134  1.382579        NaN\n",
      "1111  1.580876  1.385044  1.292579   0.899928\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.901883\n",
      "0010       NaN       NaN  1.828135        NaN\n",
      "0011       NaN       NaN  2.537328   2.537328\n",
      "0100       NaN  1.785109       NaN        NaN\n",
      "0101       NaN  2.430931       NaN   2.430931\n",
      "0110       NaN  2.207695  2.207695        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.476838       NaN       NaN        NaN\n",
      "1001  1.711537       NaN       NaN   2.207695\n",
      "1010  1.716500       NaN  2.430931        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.898703  2.537328       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.549134  1.901883  1.901883        NaN\n",
      "1111  1.385044  1.580876  1.580876   1.580876\n",
      "1.7940465978049416\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.533454   0.900472\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.712888       NaN   0.886736\n",
      "0110       NaN  1.708254  1.523302        NaN\n",
      "0111       NaN  1.473065  1.383717   0.877650\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.204791       NaN       NaN   0.892644\n",
      "1010  2.427384       NaN  1.601231        NaN\n",
      "1011  1.782277       NaN  1.435741   0.867380\n",
      "1100  2.533773  1.900791       NaN        NaN\n",
      "1101  1.825021  1.582666       NaN   0.852480\n",
      "1110  1.898837  1.548328  1.384807        NaN\n",
      "1111  1.574834  1.378060  1.286260   0.910107\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.898837\n",
      "0010       NaN       NaN  1.825021        NaN\n",
      "0011       NaN       NaN  2.533773   2.533773\n",
      "0100       NaN  1.782277       NaN        NaN\n",
      "0101       NaN  2.427384       NaN   2.427384\n",
      "0110       NaN  2.204791  2.204791        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.473065       NaN       NaN        NaN\n",
      "1001  1.708254       NaN       NaN   2.204791\n",
      "1010  1.712888       NaN  2.427384        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.900791  2.533773       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.548328  1.898837  1.898837        NaN\n",
      "1111  1.378060  1.574834  1.574834   1.574834\n",
      "1.7739805568600837\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.529814   0.902485\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.709285       NaN   0.888345\n",
      "0110       NaN  1.705000  1.526272        NaN\n",
      "0111       NaN  1.469303  1.382680   0.879981\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.201888       NaN       NaN   0.893324\n",
      "1010  2.423858       NaN  1.602918        NaN\n",
      "1011  1.779448       NaN  1.434037   0.868992\n",
      "1100  2.530249  1.902920       NaN        NaN\n",
      "1101  1.821911  1.580888       NaN   0.854015\n",
      "1110  1.895808  1.547561  1.387067        NaN\n",
      "1111  1.569022  1.371352  1.280253   0.920515\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.895808\n",
      "0010       NaN       NaN  1.821911        NaN\n",
      "0011       NaN       NaN  2.530249   2.530249\n",
      "0100       NaN  1.779448       NaN        NaN\n",
      "0101       NaN  2.423858       NaN   2.423858\n",
      "0110       NaN  2.201888  2.201888        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.469303       NaN       NaN        NaN\n",
      "1001  1.705000       NaN       NaN   2.201888\n",
      "1010  1.709285       NaN  2.423858        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.902920  2.530249       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.547561  1.895808  1.895808        NaN\n",
      "1111  1.371352  1.569022  1.569022   1.569022\n",
      "1.7539227269838014\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.526187   0.904523\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.705692       NaN   0.889978\n",
      "0110       NaN  1.701775  1.529277        NaN\n",
      "0111       NaN  1.465550  1.381674   0.882341\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.198986       NaN       NaN   0.894019\n",
      "1010  2.420353       NaN  1.604639        NaN\n",
      "1011  1.776622       NaN  1.432353   0.870625\n",
      "1100  2.526756  1.905092       NaN        NaN\n",
      "1101  1.818804  1.579130       NaN   0.855574\n",
      "1110  1.892796  1.546831  1.389358        NaN\n",
      "1111  1.563439  1.364919  1.274558   0.931147\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.892796\n",
      "0010       NaN       NaN  1.818804        NaN\n",
      "0011       NaN       NaN  2.526756   2.526756\n",
      "0100       NaN  1.776622       NaN        NaN\n",
      "0101       NaN  2.420353       NaN   2.420353\n",
      "0110       NaN  2.198986  2.198986        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.465550       NaN       NaN        NaN\n",
      "1001  1.701775       NaN       NaN   2.198986\n",
      "1010  1.705692       NaN  2.420353        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.905092  2.526756       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.546831  1.892796  1.892796        NaN\n",
      "1111  1.364919  1.563439  1.563439   1.563439\n",
      "1.7338964238097094\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.522572   0.906584\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.702108       NaN   0.891634\n",
      "0110       NaN  1.698581  1.532314        NaN\n",
      "0111       NaN  1.461809  1.380700   0.884730\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.196085       NaN       NaN   0.894730\n",
      "1010  2.416870       NaN  1.606396        NaN\n",
      "1011  1.773799       NaN  1.430689   0.872279\n",
      "1100  2.523295  1.907307       NaN        NaN\n",
      "1101  1.815701  1.577394       NaN   0.857157\n",
      "1110  1.889802  1.546140  1.391681        NaN\n",
      "1111  1.558084  1.358761  1.269176   0.941998\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.889802\n",
      "0010       NaN       NaN  1.815701        NaN\n",
      "0011       NaN       NaN  2.523295   2.523295\n",
      "0100       NaN  1.773799       NaN        NaN\n",
      "0101       NaN  2.416870       NaN   2.416870\n",
      "0110       NaN  2.196085  2.196085        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.461809       NaN       NaN        NaN\n",
      "1001  1.698581       NaN       NaN   2.196085\n",
      "1010  1.702108       NaN  2.416870        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.907307  2.523295       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.546140  1.889802  1.889802        NaN\n",
      "1111  1.358761  1.558084  1.558084   1.558084\n",
      "1.713923916448216\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.518971   0.908670\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.698534       NaN   0.893312\n",
      "0110       NaN  1.695416  1.535384        NaN\n",
      "0111       NaN  1.458079  1.379758   0.887149\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.193185       NaN       NaN   0.895457\n",
      "1010  2.413409       NaN  1.608188        NaN\n",
      "1011  1.770980       NaN  1.429045   0.873954\n",
      "1100  2.519865  1.909564       NaN        NaN\n",
      "1101  1.812602  1.575679       NaN   0.858764\n",
      "1110  1.886825  1.545487  1.394037        NaN\n",
      "1111  1.552957  1.352880  1.264106   0.953062\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.886825\n",
      "0010       NaN       NaN  1.812602        NaN\n",
      "0011       NaN       NaN  2.519865   2.519865\n",
      "0100       NaN  1.770980       NaN        NaN\n",
      "0101       NaN  2.413409       NaN   2.413409\n",
      "0110       NaN  2.193185  2.193185        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.458079       NaN       NaN        NaN\n",
      "1001  1.695416       NaN       NaN   2.193185\n",
      "1010  1.698534       NaN  2.413409        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.909564  2.519865       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.545487  1.886825  1.886825        NaN\n",
      "1111  1.352880  1.552957  1.552957   1.552957\n",
      "1.6940263925904362\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.515384   0.910780\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.694970       NaN   0.895014\n",
      "0110       NaN  1.692281  1.538488        NaN\n",
      "0111       NaN  1.454360  1.378847   0.889597\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.190287       NaN       NaN   0.896200\n",
      "1010  2.409971       NaN  1.610016        NaN\n",
      "1011  1.768165       NaN  1.427422   0.875650\n",
      "1100  2.516467  1.911864       NaN        NaN\n",
      "1101  1.809508  1.573985       NaN   0.860396\n",
      "1110  1.883866  1.544874  1.396425        NaN\n",
      "1111  1.548056  1.347274  1.259349   0.964335\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.883866\n",
      "0010       NaN       NaN  1.809508        NaN\n",
      "0011       NaN       NaN  2.516467   2.516467\n",
      "0100       NaN  1.768165       NaN        NaN\n",
      "0101       NaN  2.409971       NaN   2.409971\n",
      "0110       NaN  2.190287  2.190287        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.454360       NaN       NaN        NaN\n",
      "1001  1.692281       NaN       NaN   2.190287\n",
      "1010  1.694970       NaN  2.409971        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.911864  2.516467       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.544874  1.883866  1.883866        NaN\n",
      "1111  1.347274  1.548056  1.548056   1.548056\n",
      "1.6742239323925796\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.511809   0.912915\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.691416       NaN   0.896740\n",
      "0110       NaN  1.689177  1.541625        NaN\n",
      "0111       NaN  1.450652  1.377970   0.892076\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.187390       NaN       NaN   0.896960\n",
      "1010  2.406556       NaN  1.611879        NaN\n",
      "1011  1.765353       NaN  1.425819   0.877368\n",
      "1100  2.513101  1.914207       NaN        NaN\n",
      "1101  1.806419  1.572314       NaN   0.862052\n",
      "1110  1.880926  1.544301  1.398845        NaN\n",
      "1111  1.543381  1.341944  1.254903   0.975810\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.880926\n",
      "0010       NaN       NaN  1.806419        NaN\n",
      "0011       NaN       NaN  2.513101   2.513101\n",
      "0100       NaN  1.765353       NaN        NaN\n",
      "0101       NaN  2.406556       NaN   2.406556\n",
      "0110       NaN  2.187390  2.187390        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.450652       NaN       NaN        NaN\n",
      "1001  1.689177       NaN       NaN   2.187390\n",
      "1010  1.691416       NaN  2.406556        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.914207  2.513101       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.544301  1.880926  1.880926        NaN\n",
      "1111  1.341944  1.543381  1.543381   1.543381\n",
      "1.6545354906854328\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.508249   0.915074\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.687873       NaN   0.898489\n",
      "0110       NaN  1.686103  1.544794        NaN\n",
      "0111       NaN  1.446957  1.377125   0.894584\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.184495       NaN       NaN   0.897736\n",
      "1010  2.403163       NaN  1.613779        NaN\n",
      "1011  1.762546       NaN  1.424238   0.879108\n",
      "1100  2.509768  1.916593       NaN        NaN\n",
      "1101  1.803334  1.570664       NaN   0.863733\n",
      "1110  1.878004  1.543767  1.401299        NaN\n",
      "1111  1.538929  1.336888  1.250769   0.987482\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.878004\n",
      "0010       NaN       NaN  1.803334        NaN\n",
      "0011       NaN       NaN  2.509768   2.509768\n",
      "0100       NaN  1.762546       NaN        NaN\n",
      "0101       NaN  2.403163       NaN   2.403163\n",
      "0110       NaN  2.184495  2.184495        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.446957       NaN       NaN        NaN\n",
      "1001  1.686103       NaN       NaN   2.184495\n",
      "1010  1.687873       NaN  2.403163        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.916593  2.509768       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.543767  1.878004  1.878004        NaN\n",
      "1111  1.336888  1.538929  1.538929   1.538929\n",
      "1.6349788870022086\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.504702   0.917257\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.684340       NaN   0.900262\n",
      "0110       NaN  1.683059  1.547997        NaN\n",
      "0111       NaN  1.443274  1.376314   0.897124\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.181602       NaN       NaN   0.898529\n",
      "1010  2.399793       NaN  1.615715        NaN\n",
      "1011  1.759743       NaN  1.422678   0.880869\n",
      "1100  2.506468  1.919023       NaN        NaN\n",
      "1101  1.800254  1.569037       NaN   0.865440\n",
      "1110  1.875101  1.543274  1.403785        NaN\n",
      "1111  1.534699  1.332106  1.246943   0.999345\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.875101\n",
      "0010       NaN       NaN  1.800254        NaN\n",
      "0011       NaN       NaN  2.506468   2.506468\n",
      "0100       NaN  1.759743       NaN        NaN\n",
      "0101       NaN  2.399793       NaN   2.399793\n",
      "0110       NaN  2.181602  2.181602        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.443274       NaN       NaN        NaN\n",
      "1001  1.683059       NaN       NaN   2.181602\n",
      "1010  1.684340       NaN  2.399793        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.919023  2.506468       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.543274  1.875101  1.875101        NaN\n",
      "1111  1.332106  1.534699  1.534699   1.534699\n",
      "1.6155708028788476\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.501170   0.919465\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.680818       NaN   0.902058\n",
      "0110       NaN  1.680045  1.551233        NaN\n",
      "0111       NaN  1.439603  1.375535   0.899693\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.178711       NaN       NaN   0.899338\n",
      "1010  2.396447       NaN  1.617688        NaN\n",
      "1011  1.756944       NaN  1.421140   0.882653\n",
      "1100  2.503200  1.921496       NaN        NaN\n",
      "1101  1.797180  1.567433       NaN   0.867172\n",
      "1110  1.872218  1.542821  1.406305        NaN\n",
      "1111  1.530688  1.327596  1.243426   1.011392\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.872218\n",
      "0010       NaN       NaN  1.797180        NaN\n",
      "0011       NaN       NaN  2.503200   2.503200\n",
      "0100       NaN  1.756944       NaN        NaN\n",
      "0101       NaN  2.396447       NaN   2.396447\n",
      "0110       NaN  2.178711  2.178711        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.439603       NaN       NaN        NaN\n",
      "1001  1.680045       NaN       NaN   2.178711\n",
      "1010  1.680818       NaN  2.396447        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.921496  2.503200       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.542821  1.872218  1.872218        NaN\n",
      "1111  1.327596  1.530688  1.530688   1.530688\n",
      "1.5963267858532335\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.497651   0.921698\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.677306       NaN   0.903879\n",
      "0110       NaN  1.677062  1.554502        NaN\n",
      "0111       NaN  1.435945  1.374791   0.902294\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.175821       NaN       NaN   0.900165\n",
      "1010  2.393125       NaN  1.619697        NaN\n",
      "1011  1.754150       NaN  1.419624   0.884459\n",
      "1100  2.499966  1.924013       NaN        NaN\n",
      "1101  1.794112  1.565852       NaN   0.868930\n",
      "1110  1.869354  1.542409  1.408859        NaN\n",
      "1111  1.526895  1.323356  1.240215   1.023618\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.869354\n",
      "0010       NaN       NaN  1.794112        NaN\n",
      "0011       NaN       NaN  2.499966   2.499966\n",
      "0100       NaN  1.754150       NaN        NaN\n",
      "0101       NaN  2.393125       NaN   2.393125\n",
      "0110       NaN  2.175821  2.175821        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.435945       NaN       NaN        NaN\n",
      "1001  1.677062       NaN       NaN   2.175821\n",
      "1010  1.677306       NaN  2.393125        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.924013  2.499966       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.542409  1.869354  1.869354        NaN\n",
      "1111  1.323356  1.526895  1.526895   1.526895\n",
      "1.5772612595728308\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.494147   0.923956\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.673806       NaN   0.905723\n",
      "0110       NaN  1.674110  1.557805        NaN\n",
      "0111       NaN  1.432300  1.374080   0.904925\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.172935       NaN       NaN   0.901009\n",
      "1010  2.389827       NaN  1.621744        NaN\n",
      "1011  1.751362       NaN  1.418131   0.886289\n",
      "1100  2.496765  1.926573       NaN        NaN\n",
      "1101  1.791049  1.564295       NaN   0.870713\n",
      "1110  1.866510  1.542038  1.411447        NaN\n",
      "1111  1.523317  1.319385  1.237308   1.036015\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.866510\n",
      "0010       NaN       NaN  1.791049        NaN\n",
      "0011       NaN       NaN  2.496765   2.496765\n",
      "0100       NaN  1.751362       NaN        NaN\n",
      "0101       NaN  2.389827       NaN   2.389827\n",
      "0110       NaN  2.172935  2.172935        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.432300       NaN       NaN        NaN\n",
      "1001  1.674110       NaN       NaN   2.172935\n",
      "1010  1.673806       NaN  2.389827        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.926573  2.496765       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.542038  1.866510  1.866510        NaN\n",
      "1111  1.319385  1.523317  1.523317   1.523317\n",
      "1.5583875394130173\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.490658   0.926238\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.670317       NaN   0.907592\n",
      "0110       NaN  1.671188  1.561140        NaN\n",
      "0111       NaN  1.428669  1.373404   0.907587\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.170050       NaN       NaN   0.901870\n",
      "1010  2.386553       NaN  1.623828        NaN\n",
      "1011  1.748578       NaN  1.416660   0.888140\n",
      "1100  2.493598  1.929178       NaN        NaN\n",
      "1101  1.787993  1.562762       NaN   0.872524\n",
      "1110  1.863686  1.541708  1.414069        NaN\n",
      "1111  1.519952  1.315681  1.234704   1.048577\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.863686\n",
      "0010       NaN       NaN  1.787993        NaN\n",
      "0011       NaN       NaN  2.493598   2.493598\n",
      "0100       NaN  1.748578       NaN        NaN\n",
      "0101       NaN  2.386553       NaN   2.386553\n",
      "0110       NaN  2.170050  2.170050        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.428669       NaN       NaN        NaN\n",
      "1001  1.671188       NaN       NaN   2.170050\n",
      "1010  1.670317       NaN  2.386553        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.929178  2.493598       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541708  1.863686  1.863686        NaN\n",
      "1111  1.315681  1.519952  1.519952   1.519952\n",
      "1.5397178530098727\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.487183   0.928545\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.666840       NaN   0.909485\n",
      "0110       NaN  1.668297  1.564508        NaN\n",
      "0111       NaN  1.425051  1.372763   0.910281\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.167168       NaN       NaN   0.902749\n",
      "1010  2.383304       NaN  1.625949        NaN\n",
      "1011  1.745799       NaN  1.415211   0.890015\n",
      "1100  2.490465  1.931828       NaN        NaN\n",
      "1101  1.784943  1.561253       NaN   0.874360\n",
      "1110  1.860882  1.541421  1.416725        NaN\n",
      "1111  1.516795  1.312242  1.232398   1.061297\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.860882\n",
      "0010       NaN       NaN  1.784943        NaN\n",
      "0011       NaN       NaN  2.490465   2.490465\n",
      "0100       NaN  1.745799       NaN        NaN\n",
      "0101       NaN  2.383304       NaN   2.383304\n",
      "0110       NaN  2.167168  2.167168        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.425051       NaN       NaN        NaN\n",
      "1001  1.668297       NaN       NaN   2.167168\n",
      "1010  1.666840       NaN  2.383304        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.931828  2.490465       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541421  1.860882  1.860882        NaN\n",
      "1111  1.312242  1.516795  1.516795   1.516795\n",
      "1.521263365120286\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.483723   0.930878\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.663374       NaN   0.911402\n",
      "0110       NaN  1.665437  1.567909        NaN\n",
      "0111       NaN  1.421447  1.372156   0.913007\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.164290       NaN       NaN   0.903646\n",
      "1010  2.380079       NaN  1.628107        NaN\n",
      "1011  1.743027       NaN  1.413786   0.891914\n",
      "1100  2.487367  1.934521       NaN        NaN\n",
      "1101  1.781900  1.559768       NaN   0.876224\n",
      "1110  1.858100  1.541176  1.419416        NaN\n",
      "1111  1.513845  1.309064  1.230389   1.074169\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.858100\n",
      "0010       NaN       NaN  1.781900        NaN\n",
      "0011       NaN       NaN  2.487367   2.487367\n",
      "0100       NaN  1.743027       NaN        NaN\n",
      "0101       NaN  2.380079       NaN   2.380079\n",
      "0110       NaN  2.164290  2.164290        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.421447       NaN       NaN        NaN\n",
      "1001  1.665437       NaN       NaN   2.164290\n",
      "1010  1.663374       NaN  2.380079        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.934521  2.487367       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541176  1.858100  1.858100        NaN\n",
      "1111  1.309064  1.513845  1.513845   1.513845\n",
      "1.5030342062379023\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.480278   0.933235\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.659920       NaN   0.913344\n",
      "0110       NaN  1.662608  1.571343        NaN\n",
      "0111       NaN  1.417857  1.371584   0.915764\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.161413       NaN       NaN   0.904560\n",
      "1010  2.376880       NaN  1.630304        NaN\n",
      "1011  1.740260       NaN  1.412385   0.893836\n",
      "1100  2.484303  1.937260       NaN        NaN\n",
      "1101  1.778863  1.558308       NaN   0.878115\n",
      "1110  1.855338  1.540973  1.422142        NaN\n",
      "1111  1.511098  1.306146  1.228674   1.087185\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.855338\n",
      "0010       NaN       NaN  1.778863        NaN\n",
      "0011       NaN       NaN  2.484303   2.484303\n",
      "0100       NaN  1.740260       NaN        NaN\n",
      "0101       NaN  2.376880       NaN   2.376880\n",
      "0110       NaN  2.161413  2.161413        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.417857       NaN       NaN        NaN\n",
      "1001  1.662608       NaN       NaN   2.161413\n",
      "1010  1.659920       NaN  2.376880        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.937260  2.484303       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540973  1.855338  1.855338        NaN\n",
      "1111  1.306146  1.511098  1.511098   1.511098\n",
      "1.485039504414588\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.476849   0.935618\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.656478       NaN   0.915310\n",
      "0110       NaN  1.659811  1.574810        NaN\n",
      "0111       NaN  1.414282  1.371048   0.918553\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.158540       NaN       NaN   0.905493\n",
      "1010  2.373706       NaN  1.632538        NaN\n",
      "1011  1.737498       NaN  1.411007   0.895781\n",
      "1100  2.481274  1.940043       NaN        NaN\n",
      "1101  1.775834  1.556874       NaN   0.880033\n",
      "1110  1.852598  1.540813  1.424904        NaN\n",
      "1111  1.508550  1.303484  1.227249   1.100338\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.852598\n",
      "0010       NaN       NaN  1.775834        NaN\n",
      "0011       NaN       NaN  2.481274   2.481274\n",
      "0100       NaN  1.737498       NaN        NaN\n",
      "0101       NaN  2.373706       NaN   2.373706\n",
      "0110       NaN  2.158540  2.158540        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.414282       NaN       NaN        NaN\n",
      "1001  1.659811       NaN       NaN   2.158540\n",
      "1010  1.656478       NaN  2.373706        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.940043  2.481274       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540813  1.852598  1.852598        NaN\n",
      "1111  1.303484  1.508550  1.508550   1.508550\n",
      "1.4672874197627037\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.473434   0.938025\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.653048       NaN   0.917302\n",
      "0110       NaN  1.657044  1.578309        NaN\n",
      "0111       NaN  1.410722  1.370548   0.921374\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.155671       NaN       NaN   0.906443\n",
      "1010  2.370557       NaN  1.634811        NaN\n",
      "1011  1.734744       NaN  1.409653   0.897751\n",
      "1100  2.478280  1.942871       NaN        NaN\n",
      "1101  1.772813  1.555465       NaN   0.881979\n",
      "1110  1.849880  1.540697  1.427701        NaN\n",
      "1111  1.506199  1.301076  1.226110   1.113622\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.849880\n",
      "0010       NaN       NaN  1.772813        NaN\n",
      "0011       NaN       NaN  2.478280   2.478280\n",
      "0100       NaN  1.734744       NaN        NaN\n",
      "0101       NaN  2.370557       NaN   2.370557\n",
      "0110       NaN  2.155671  2.155671        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.410722       NaN       NaN        NaN\n",
      "1001  1.657044       NaN       NaN   2.155671\n",
      "1010  1.653048       NaN  2.370557        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.942871  2.478280       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540697  1.849880  1.849880        NaN\n",
      "1111  1.301076  1.506199  1.506199   1.506199\n",
      "1.44978518114261\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.470035   0.940458\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.649630       NaN   0.919318\n",
      "0110       NaN  1.654308  1.581842        NaN\n",
      "0111       NaN  1.407177  1.370084   0.924228\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.152804       NaN       NaN   0.907413\n",
      "1010  2.367435       NaN  1.637122        NaN\n",
      "1011  1.731995       NaN  1.408324   0.899745\n",
      "1100  2.475321  1.945744       NaN        NaN\n",
      "1101  1.769799  1.554082       NaN   0.883952\n",
      "1110  1.847183  1.540624  1.430533        NaN\n",
      "1111  1.504039  1.298918  1.225255   1.127029\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.847183\n",
      "0010       NaN       NaN  1.769799        NaN\n",
      "0011       NaN       NaN  2.475321   2.475321\n",
      "0100       NaN  1.731995       NaN        NaN\n",
      "0101       NaN  2.367435       NaN   2.367435\n",
      "0110       NaN  2.152804  2.152804        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.407177       NaN       NaN        NaN\n",
      "1001  1.654308       NaN       NaN   2.152804\n",
      "1010  1.649630       NaN  2.367435        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.945744  2.475321       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540624  1.847183  1.847183        NaN\n",
      "1111  1.298918  1.504039  1.504039   1.504039\n",
      "1.432539124571573\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.466652   0.942917\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.646225       NaN   0.921359\n",
      "0110       NaN  1.651604  1.585407        NaN\n",
      "0111       NaN  1.403648  1.369656   0.927114\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.149942       NaN       NaN   0.908400\n",
      "1010  2.364339       NaN  1.639472        NaN\n",
      "1011  1.729253       NaN  1.407019   0.901764\n",
      "1100  2.472398  1.948663       NaN        NaN\n",
      "1101  1.766793  1.552726       NaN   0.885955\n",
      "1110  1.844509  1.540595  1.433402        NaN\n",
      "1111  1.502069  1.297006  1.224679   1.140551\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.844509\n",
      "0010       NaN       NaN  1.766793        NaN\n",
      "0011       NaN       NaN  2.472398   2.472398\n",
      "0100       NaN  1.729253       NaN        NaN\n",
      "0101       NaN  2.364339       NaN   2.364339\n",
      "0110       NaN  2.149942  2.149942        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.403648       NaN       NaN        NaN\n",
      "1001  1.651604       NaN       NaN   2.149942\n",
      "1010  1.646225       NaN  2.364339        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.948663  2.472398       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540595  1.844509  1.844509        NaN\n",
      "1111  1.297006  1.502069  1.502069   1.502069\n",
      "1.4155547329237563\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.463285   0.945401\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.642833       NaN   0.923425\n",
      "0110       NaN  1.648931  1.589005        NaN\n",
      "0111       NaN  1.400134  1.369265   0.930033\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.147083       NaN       NaN   0.909407\n",
      "1010  2.361269       NaN  1.641861        NaN\n",
      "1011  1.726518       NaN  1.405740   0.903807\n",
      "1100  2.469511  1.951627       NaN        NaN\n",
      "1101  1.763796  1.551396       NaN   0.887985\n",
      "1110  1.841858  1.540610  1.436307        NaN\n",
      "1111  1.500282  1.295337  1.224378   1.154182\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.841858\n",
      "0010       NaN       NaN  1.763796        NaN\n",
      "0011       NaN       NaN  2.469511   2.469511\n",
      "0100       NaN  1.726518       NaN        NaN\n",
      "0101       NaN  2.361269       NaN   2.361269\n",
      "0110       NaN  2.147083  2.147083        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.400134       NaN       NaN        NaN\n",
      "1001  1.648931       NaN       NaN   2.147083\n",
      "1010  1.642833       NaN  2.361269        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.951627  2.469511       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540610  1.841858  1.841858        NaN\n",
      "1111  1.295337  1.500282  1.500282   1.500282\n",
      "1.3988366765255917\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.459933   0.947910\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.639454       NaN   0.925517\n",
      "0110       NaN  1.646290  1.592635        NaN\n",
      "0111       NaN  1.396636  1.368911   0.932985\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.144228       NaN       NaN   0.910433\n",
      "1010  2.358225       NaN  1.644288        NaN\n",
      "1011  1.723790       NaN  1.404485   0.905875\n",
      "1100  2.466659  1.954636       NaN        NaN\n",
      "1101  1.760807  1.550093       NaN   0.890045\n",
      "1110  1.839230  1.540670  1.439248        NaN\n",
      "1111  1.498676  1.293907  1.224347   1.167915\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.839230\n",
      "0010       NaN       NaN  1.760807        NaN\n",
      "0011       NaN       NaN  2.466659   2.466659\n",
      "0100       NaN  1.723790       NaN        NaN\n",
      "0101       NaN  2.358225       NaN   2.358225\n",
      "0110       NaN  2.144228  2.144228        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.396636       NaN       NaN        NaN\n",
      "1001  1.646290       NaN       NaN   2.144228\n",
      "1010  1.644288       NaN  2.358225        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.954636  2.466659       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540670  1.839230  1.839230        NaN\n",
      "1111  1.293907  1.498676  1.498676   1.498676\n",
      "1.3823888542858436\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.456598   0.950445\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.636087       NaN   0.927633\n",
      "0110       NaN  1.643680  1.596298        NaN\n",
      "0111       NaN  1.393155  1.368594   0.935970\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.141377       NaN       NaN   0.911477\n",
      "1010  2.355209       NaN  1.646755        NaN\n",
      "1011  1.721070       NaN  1.403256   0.907968\n",
      "1100  2.463844  1.957691       NaN        NaN\n",
      "1101  1.757827  1.548818       NaN   0.892133\n",
      "1110  1.836625  1.540775  1.442226        NaN\n",
      "1111  1.497245  1.292713  1.224583   1.181742\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.836625\n",
      "0010       NaN       NaN  1.757827        NaN\n",
      "0011       NaN       NaN  2.463844   2.463844\n",
      "0100       NaN  1.721070       NaN        NaN\n",
      "0101       NaN  2.355209       NaN   2.355209\n",
      "0110       NaN  2.141377  2.141377        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.393155       NaN       NaN        NaN\n",
      "1001  1.643680       NaN       NaN   2.141377\n",
      "1010  1.646755       NaN  2.355209        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.957691  2.463844       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540775  1.836625  1.836625        NaN\n",
      "1111  1.292713  1.497245  1.497245   1.497245\n",
      "1.3662144350345218\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.453279   0.953005\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.632734       NaN   0.929776\n",
      "0110       NaN  1.641102  1.599994        NaN\n",
      "0111       NaN  1.389690  1.368314   0.938988\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.138530       NaN       NaN   0.912541\n",
      "1010  2.352220       NaN  1.649262        NaN\n",
      "1011  1.718357       NaN  1.402053   0.910087\n",
      "1100  2.461066  1.960792       NaN        NaN\n",
      "1101  1.754856  1.547570       NaN   0.894252\n",
      "1110  1.834044  1.540925  1.445242        NaN\n",
      "1111  1.495987  1.291750  1.225082   1.195655\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.834044\n",
      "0010       NaN       NaN  1.754856        NaN\n",
      "0011       NaN       NaN  2.461066   2.461066\n",
      "0100       NaN  1.718357       NaN        NaN\n",
      "0101       NaN  2.352220       NaN   2.352220\n",
      "0110       NaN  2.138530  2.138530        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.389690       NaN       NaN        NaN\n",
      "1001  1.641102       NaN       NaN   2.138530\n",
      "1010  1.649262       NaN  2.352220        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.960792  2.461066       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.540925  1.834044  1.834044        NaN\n",
      "1111  1.291750  1.495987  1.495987   1.495987\n",
      "1.3503158987791033\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.449976   0.955591\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.629394       NaN   0.931943\n",
      "0110       NaN  1.638555  1.603722        NaN\n",
      "0111       NaN  1.386242  1.368072   0.942040\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.135687       NaN       NaN   0.913625\n",
      "1010  2.349259       NaN  1.651808        NaN\n",
      "1011  1.715652       NaN  1.400877   0.912231\n",
      "1100  2.458324  1.963939       NaN        NaN\n",
      "1101  1.751895  1.546350       NaN   0.896399\n",
      "1110  1.831487  1.541120  1.448294        NaN\n",
      "1111  1.494896  1.291015  1.225837   1.209649\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.831487\n",
      "0010       NaN       NaN  1.751895        NaN\n",
      "0011       NaN       NaN  2.458324   2.458324\n",
      "0100       NaN  1.715652       NaN        NaN\n",
      "0101       NaN  2.349259       NaN   2.349259\n",
      "0110       NaN  2.135687  2.135687        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.386242       NaN       NaN        NaN\n",
      "1001  1.638555       NaN       NaN   2.135687\n",
      "1010  1.651808       NaN  2.349259        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.963939  2.458324       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541120  1.831487  1.831487        NaN\n",
      "1111  1.291015  1.494896  1.494896   1.494896\n",
      "1.334695077619731\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.446690   0.958203\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.626068       NaN   0.934137\n",
      "0110       NaN  1.636041  1.607483        NaN\n",
      "0111       NaN  1.382812  1.367868   0.945125\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.132850       NaN       NaN   0.914728\n",
      "1010  2.346325       NaN  1.654393        NaN\n",
      "1011  1.712955       NaN  1.399727   0.914402\n",
      "1100  2.455619  1.967133       NaN        NaN\n",
      "1101  1.748944  1.545159       NaN   0.898577\n",
      "1110  1.828955  1.541362  1.451384        NaN\n",
      "1111  1.493968  1.290502  1.226845   1.223715\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.828955\n",
      "0010       NaN       NaN  1.748944        NaN\n",
      "0011       NaN       NaN  2.455619   2.455619\n",
      "0100       NaN  1.712955       NaN        NaN\n",
      "0101       NaN  2.346325       NaN   2.346325\n",
      "0110       NaN  2.132850  2.132850        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.382812       NaN       NaN        NaN\n",
      "1001  1.636041       NaN       NaN   2.132850\n",
      "1010  1.654393       NaN  2.346325        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.967133  2.455619       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541362  1.828955  1.828955        NaN\n",
      "1111  1.290502  1.493968  1.493968   1.493968\n",
      "1.3193531960970073\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.443421   0.960841\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.622756       NaN   0.936356\n",
      "0110       NaN  1.633558  1.611275        NaN\n",
      "0111       NaN  1.379399  1.367703   0.948244\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.130016       NaN       NaN   0.915851\n",
      "1010  2.343419       NaN  1.657019        NaN\n",
      "1011  1.710266       NaN  1.398603   0.916598\n",
      "1100  2.452952  1.970372       NaN        NaN\n",
      "1101  1.746002  1.543996       NaN   0.900785\n",
      "1110  1.826447  1.541650  1.454512        NaN\n",
      "1111  1.493199  1.290209  1.228101   1.237847\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.826447\n",
      "0010       NaN       NaN  1.746002        NaN\n",
      "0011       NaN       NaN  2.452952   2.452952\n",
      "0100       NaN  1.710266       NaN        NaN\n",
      "0101       NaN  2.343419       NaN   2.343419\n",
      "0110       NaN  2.130016  2.130016        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.379399       NaN       NaN        NaN\n",
      "1001  1.633558       NaN       NaN   2.130016\n",
      "1010  1.657019       NaN  2.343419        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.970372  2.452952       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541650  1.826447  1.826447        NaN\n",
      "1111  1.290209  1.493199  1.493199   1.493199\n",
      "1.3146412853512874\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.440169   0.963505\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.619458       NaN   0.938601\n",
      "0110       NaN  1.631106  1.615100        NaN\n",
      "0111       NaN  1.376004  1.367576   0.951397\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.127188       NaN       NaN   0.916994\n",
      "1010  2.340541       NaN  1.659685        NaN\n",
      "1011  1.707586       NaN  1.397507   0.918821\n",
      "1100  2.450322  1.973658       NaN        NaN\n",
      "1101  1.743071  1.542863       NaN   0.903024\n",
      "1110  1.823963  1.541984  1.457678        NaN\n",
      "1111  1.492583  1.290129  1.229600   1.252037\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.823963\n",
      "0010       NaN       NaN  1.743071        NaN\n",
      "0011       NaN       NaN  2.450322   2.450322\n",
      "0100       NaN  1.707586       NaN        NaN\n",
      "0101       NaN  2.340541       NaN   2.340541\n",
      "0110       NaN  2.127188  2.127188        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.376004       NaN       NaN        NaN\n",
      "1001  1.631106       NaN       NaN   2.127188\n",
      "1010  1.659685       NaN  2.340541        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.973658  2.450322       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.541984  1.823963  1.823963        NaN\n",
      "1111  1.290129  1.492583  1.492583   1.492583\n",
      "1.31303901293735\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.436933   0.966194\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.616173       NaN   0.940872\n",
      "0110       NaN  1.628687  1.618958        NaN\n",
      "0111       NaN  1.372627  1.367488   0.954584\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.124365       NaN       NaN   0.918157\n",
      "1010  2.337692       NaN  1.662391        NaN\n",
      "1011  1.704914       NaN  1.396438   0.921070\n",
      "1100  2.447730  1.976991       NaN        NaN\n",
      "1101  1.740151  1.541760       NaN   0.905294\n",
      "1110  1.821506  1.542366  1.460883        NaN\n",
      "1111  1.492117  1.290260  1.231336   1.266279\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.821506\n",
      "0010       NaN       NaN  1.740151        NaN\n",
      "0011       NaN       NaN  2.447730   2.447730\n",
      "0100       NaN  1.704914       NaN        NaN\n",
      "0101       NaN  2.337692       NaN   2.337692\n",
      "0110       NaN  2.124365  2.124365        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.372627       NaN       NaN        NaN\n",
      "1001  1.628687       NaN       NaN   2.124365\n",
      "1010  1.662391       NaN  2.337692        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.976991  2.447730       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.542366  1.821506  1.821506        NaN\n",
      "1111  1.290260  1.492117  1.492117   1.492117\n",
      "1.3111874394564829\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.433715   0.968910\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.612903       NaN   0.943170\n",
      "0110       NaN  1.626300  1.622847        NaN\n",
      "0111       NaN  1.369269  1.367440   0.957806\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.121548       NaN       NaN   0.919340\n",
      "1010  2.334872       NaN  1.665138        NaN\n",
      "1011  1.702252       NaN  1.395397   0.923347\n",
      "1100  2.445176  1.980370       NaN        NaN\n",
      "1101  1.737242  1.540686       NaN   0.907595\n",
      "1110  1.819074  1.542794  1.464126        NaN\n",
      "1111  1.491796  1.290596  1.233305   1.280566\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.819074\n",
      "0010       NaN       NaN  1.737242        NaN\n",
      "0011       NaN       NaN  2.445176   2.445176\n",
      "0100       NaN  1.702252       NaN        NaN\n",
      "0101       NaN  2.334872       NaN   2.334872\n",
      "0110       NaN  2.121548  2.121548        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.369269       NaN       NaN        NaN\n",
      "1001  1.626300       NaN       NaN   2.121548\n",
      "1010  1.665138       NaN  2.334872        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.980370  2.445176       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.542794  1.819074  1.819074        NaN\n",
      "1111  1.290596  1.491796  1.491796   1.491796\n",
      "1.3090941071114315\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.430515   0.971651\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.609648       NaN   0.945493\n",
      "0110       NaN  1.623944  1.626768        NaN\n",
      "0111       NaN  1.365929  1.367430   0.961062\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.118735       NaN       NaN   0.920544\n",
      "1010  2.332081       NaN  1.667926        NaN\n",
      "1011  1.699599       NaN  1.394385   0.925650\n",
      "1100  2.442660  1.983796       NaN        NaN\n",
      "1101  1.734344  1.539643       NaN   0.909928\n",
      "1110  1.816668  1.543271  1.467407        NaN\n",
      "1111  1.491615  1.291132  1.235502   1.294891\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.816668\n",
      "0010       NaN       NaN  1.734344        NaN\n",
      "0011       NaN       NaN  2.442660   2.442660\n",
      "0100       NaN  1.699599       NaN        NaN\n",
      "0101       NaN  2.332081       NaN   2.332081\n",
      "0110       NaN  2.118735  2.118735        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367430       NaN       NaN        NaN\n",
      "1001  1.626768       NaN       NaN   2.118735\n",
      "1010  1.667926       NaN  2.332081        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.983796  2.442660       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.543271  1.816668  1.816668        NaN\n",
      "1111  1.294891  1.491615  1.491615   1.491615\n",
      "1.3067668145827256\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.427331   0.974418\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.606407       NaN   0.947843\n",
      "0110       NaN  1.621621  1.630722        NaN\n",
      "0111       NaN  1.362609  1.367461   0.964353\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.115929       NaN       NaN   0.921769\n",
      "1010  2.329319       NaN  1.670755        NaN\n",
      "1011  1.696955       NaN  1.393400   0.927981\n",
      "1100  2.440182  1.987269       NaN        NaN\n",
      "1101  1.731457  1.538630       NaN   0.912292\n",
      "1110  1.814288  1.543795  1.470728        NaN\n",
      "1111  1.491570  1.291865  1.237920   1.309247\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.814288\n",
      "0010       NaN       NaN  1.731457        NaN\n",
      "0011       NaN       NaN  2.440182   2.440182\n",
      "0100       NaN  1.696955       NaN        NaN\n",
      "0101       NaN  2.329319       NaN   2.329319\n",
      "0110       NaN  2.115929  2.115929        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367461       NaN       NaN        NaN\n",
      "1001  1.630722       NaN       NaN   2.115929\n",
      "1010  1.670755       NaN  2.329319        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.987269  2.440182       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.543795  1.814288  1.814288        NaN\n",
      "1111  1.309247  1.491570  1.491570   1.491570\n",
      "1.3042135784055404\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.424166   0.977212\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.603181       NaN   0.950219\n",
      "0110       NaN  1.619329  1.634707        NaN\n",
      "0111       NaN  1.359308  1.367531   0.967679\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.113128       NaN       NaN   0.923015\n",
      "1010  2.326587       NaN  1.673624        NaN\n",
      "1011  1.694322       NaN  1.392445   0.930340\n",
      "1100  2.437743  1.990789       NaN        NaN\n",
      "1101  1.728583  1.537648       NaN   0.914688\n",
      "1110  1.811935  1.544368  1.474089        NaN\n",
      "1111  1.491655  1.292790  1.240556   1.323628\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.811935\n",
      "0010       NaN       NaN  1.728583        NaN\n",
      "0011       NaN       NaN  2.437743   2.437743\n",
      "0100       NaN  1.694322       NaN        NaN\n",
      "0101       NaN  2.326587       NaN   2.326587\n",
      "0110       NaN  2.113128  2.113128        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367531       NaN       NaN        NaN\n",
      "1001  1.634707       NaN       NaN   2.113128\n",
      "1010  1.673624       NaN  2.326587        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.990789  2.437743       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.544368  1.811935  1.811935        NaN\n",
      "1111  1.323628  1.491655  1.491655   1.491655\n",
      "1.3014425950713415\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.421018   0.980032\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.599971       NaN   0.952622\n",
      "0110       NaN  1.617070  1.638724        NaN\n",
      "0111       NaN  1.356027  1.367642   0.971040\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.110333       NaN       NaN   0.924282\n",
      "1010  2.323884       NaN  1.676536        NaN\n",
      "1011  1.691698       NaN  1.391518   0.932726\n",
      "1100  2.435343  1.994356       NaN        NaN\n",
      "1101  1.725721  1.536698       NaN   0.917117\n",
      "1110  1.809609  1.544989  1.477489        NaN\n",
      "1111  1.491867  1.293902  1.243404   1.338027\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.809609\n",
      "0010       NaN       NaN  1.725721        NaN\n",
      "0011       NaN       NaN  2.435343   2.435343\n",
      "0100       NaN  1.691698       NaN        NaN\n",
      "0101       NaN  2.323884       NaN   2.323884\n",
      "0110       NaN  2.110333  2.110333        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367642       NaN       NaN        NaN\n",
      "1001  1.638724       NaN       NaN   2.110333\n",
      "1010  1.676536       NaN  2.323884        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.994356  2.435343       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.544989  1.809609  1.809609        NaN\n",
      "1111  1.338027  1.491867  1.491867   1.491867\n",
      "1.2984622040919724\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.417888   0.982878\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.596775       NaN   0.955051\n",
      "0110       NaN  1.614843  1.642773        NaN\n",
      "0111       NaN  1.352765  1.367793   0.974436\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.107544       NaN       NaN   0.925570\n",
      "1010  2.321212       NaN  1.679488        NaN\n",
      "1011  1.689085       NaN  1.390621   0.935141\n",
      "1100  2.432981  1.997971       NaN        NaN\n",
      "1101  1.722871  1.535780       NaN   0.919579\n",
      "1110  1.807310  1.545659  1.480928        NaN\n",
      "1111  1.492201  1.295196  1.246457   1.352438\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.807310\n",
      "0010       NaN       NaN  1.722871        NaN\n",
      "0011       NaN       NaN  2.432981   2.432981\n",
      "0100       NaN  1.689085       NaN        NaN\n",
      "0101       NaN  2.321212       NaN   2.321212\n",
      "0110       NaN  2.107544  2.107544        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367793       NaN       NaN        NaN\n",
      "1001  1.642773       NaN       NaN   2.107544\n",
      "1010  1.679488       NaN  2.321212        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  1.997971  2.432981       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.545659  1.807310  1.807310        NaN\n",
      "1111  1.352438  1.492201  1.492201   1.492201\n",
      "1.2952808522389636\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.414776   0.985750\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.593595       NaN   0.957507\n",
      "0110       NaN  1.612648  1.646854        NaN\n",
      "0111       NaN  1.349525  1.367985   0.977868\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.104762       NaN       NaN   0.926880\n",
      "1010  2.318570       NaN  1.682482        NaN\n",
      "1011  1.686482       NaN  1.389754   0.937584\n",
      "1100  2.430659  2.001633       NaN        NaN\n",
      "1101  1.720034  1.534894       NaN   0.922074\n",
      "1110  1.805039  1.546379  1.484408        NaN\n",
      "1111  1.492652  1.296667  1.249713   1.366856\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.805039\n",
      "0010       NaN       NaN  1.720034        NaN\n",
      "0011       NaN       NaN  2.430659   2.430659\n",
      "0100       NaN  1.686482       NaN        NaN\n",
      "0101       NaN  2.318570       NaN   2.318570\n",
      "0110       NaN  2.104762  2.104762        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.367985       NaN       NaN        NaN\n",
      "1001  1.646854       NaN       NaN   2.104762\n",
      "1010  1.682482       NaN  2.318570        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.001633  2.430659       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.546379  1.805039  1.805039        NaN\n",
      "1111  1.366856  1.492652  1.492652   1.492652\n",
      "1.2919070591451984\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.411683   0.988649\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.590430       NaN   0.959990\n",
      "0110       NaN  1.610486  1.650966        NaN\n",
      "0111       NaN  1.346304  1.368219   0.981335\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.101986       NaN       NaN   0.928212\n",
      "1010  2.315958       NaN  1.685518        NaN\n",
      "1011  1.683890       NaN  1.388917   0.940055\n",
      "1100  2.428377  2.005343       NaN        NaN\n",
      "1101  1.717211  1.534040       NaN   0.924602\n",
      "1110  1.802796  1.547148  1.487928        NaN\n",
      "1111  1.493216  1.298312  1.253164   1.381273\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.802796\n",
      "0010       NaN       NaN  1.717211        NaN\n",
      "0011       NaN       NaN  2.428377   2.428377\n",
      "0100       NaN  1.683890       NaN        NaN\n",
      "0101       NaN  2.315958       NaN   2.315958\n",
      "0110       NaN  2.101986  2.101986        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.368219       NaN       NaN        NaN\n",
      "1001  1.650966       NaN       NaN   2.101986\n",
      "1010  1.685518       NaN  2.315958        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.005343  2.428377       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.547148  1.802796  1.802796        NaN\n",
      "1111  1.381273  1.493216  1.493216   1.493216\n",
      "1.2883493844301193\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.408608   0.991574\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.587281       NaN   0.962500\n",
      "0110       NaN  1.608355  1.655109        NaN\n",
      "0111       NaN  1.343105  1.368493   0.984838\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.099217       NaN       NaN   0.929565\n",
      "1010  2.313377       NaN  1.688596        NaN\n",
      "1011  1.681309       NaN  1.388110   0.942556\n",
      "1100  2.426134  2.009100       NaN        NaN\n",
      "1101  1.714401  1.533220       NaN   0.927163\n",
      "1110  1.800581  1.547967  1.491489        NaN\n",
      "1111  1.493888  1.300126  1.256805   1.395685\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.800581\n",
      "0010       NaN       NaN  1.714401        NaN\n",
      "0011       NaN       NaN  2.426134   2.426134\n",
      "0100       NaN  1.681309       NaN        NaN\n",
      "0101       NaN  2.313377       NaN   2.313377\n",
      "0110       NaN  2.099217  2.099217        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.368493       NaN       NaN        NaN\n",
      "1001  1.655109       NaN       NaN   2.099217\n",
      "1010  1.688596       NaN  2.313377        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.009100  2.426134       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.547967  1.800581  1.800581        NaN\n",
      "1111  1.395685  1.493888  1.493888   1.493888\n",
      "1.2846163964837958\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.405551   0.994525\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.584148       NaN   0.965037\n",
      "0110       NaN  1.606257  1.659284        NaN\n",
      "0111       NaN  1.339927  1.368809   0.988377\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.096454       NaN       NaN   0.930940\n",
      "1010  2.310828       NaN  1.691716        NaN\n",
      "1011  1.678739       NaN  1.387334   0.945086\n",
      "1100  2.423931  2.012905       NaN        NaN\n",
      "1101  1.711605  1.532433       NaN   0.929759\n",
      "1110  1.798395  1.548837  1.495091        NaN\n",
      "1111  1.494664  1.302103  1.260632   1.410085\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.798395\n",
      "0010       NaN       NaN  1.711605        NaN\n",
      "0011       NaN       NaN  2.423931   2.423931\n",
      "0100       NaN  1.678739       NaN        NaN\n",
      "0101       NaN  2.310828       NaN   2.310828\n",
      "0110       NaN  2.096454  2.096454        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.368809       NaN       NaN        NaN\n",
      "1001  1.659284       NaN       NaN   2.096454\n",
      "1010  1.691716       NaN  2.310828        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.012905  2.423931       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.548837  1.798395  1.798395        NaN\n",
      "1111  1.410085  1.494664  1.494664   1.494664\n",
      "1.2807166430198078\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.402513   0.997503\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.581031       NaN   0.967600\n",
      "0110       NaN  1.604191  1.663490        NaN\n",
      "0111       NaN  1.336770  1.369167   0.991951\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.093699       NaN       NaN   0.932338\n",
      "1010  2.308309       NaN  1.694879        NaN\n",
      "1011  1.676182       NaN  1.386590   0.947645\n",
      "1100  2.421769  2.016758       NaN        NaN\n",
      "1101  1.708823  1.531680       NaN   0.932389\n",
      "1110  1.796238  1.549757  1.498734        NaN\n",
      "1111  1.495539  1.304239  1.264639   1.424469\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.796238\n",
      "0010       NaN       NaN  1.708823        NaN\n",
      "0011       NaN       NaN  2.421769   2.421769\n",
      "0100       NaN  1.676182       NaN        NaN\n",
      "0101       NaN  2.308309       NaN   2.308309\n",
      "0110       NaN  2.093699  2.093699        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.369167       NaN       NaN        NaN\n",
      "1001  1.663490       NaN       NaN   2.093699\n",
      "1010  1.694879       NaN  2.308309        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.016758  2.421769       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.549757  1.796238  1.796238        NaN\n",
      "1111  1.424469  1.495539  1.495539   1.495539\n",
      "1.276658623482335\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.399494   1.000507\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.577930       NaN   0.970192\n",
      "0110       NaN  1.602158  1.667728        NaN\n",
      "0111       NaN  1.333635  1.369567   0.995562\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.090952       NaN       NaN   0.933758\n",
      "1010  2.305823       NaN  1.698084        NaN\n",
      "1011  1.673636       NaN  1.385876   0.950234\n",
      "1100  2.419646  2.020659       NaN        NaN\n",
      "1101  1.706056  1.530961       NaN   0.935054\n",
      "1110  1.794110  1.550728  1.502418        NaN\n",
      "1111  1.496510  1.306531  1.268821   1.438830\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.794110\n",
      "0010       NaN       NaN  1.706056        NaN\n",
      "0011       NaN       NaN  2.419646   2.419646\n",
      "0100       NaN  1.673636       NaN        NaN\n",
      "0101       NaN  2.305823       NaN   2.305823\n",
      "0110       NaN  2.090952  2.090952        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.369567       NaN       NaN        NaN\n",
      "1001  1.667728       NaN       NaN   2.090952\n",
      "1010  1.698084       NaN  2.305823        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.020659  2.419646       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.550728  1.794110  1.794110        NaN\n",
      "1111  1.438830  1.496510  1.496510   1.496510\n",
      "1.2724507633693667\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.396494   1.003537\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.574846       NaN   0.972810\n",
      "0110       NaN  1.600157  1.671996        NaN\n",
      "0111       NaN  1.330523  1.370009   0.999210\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.088211       NaN       NaN   0.935201\n",
      "1010  2.303368       NaN  1.701332        NaN\n",
      "1011  1.671102       NaN  1.385195   0.952852\n",
      "1100  2.417564  2.024608       NaN        NaN\n",
      "1101  1.703303  1.530276       NaN   0.937754\n",
      "1110  1.792012  1.551750  1.506144        NaN\n",
      "1111  1.497571  1.308973  1.273173   1.453164\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.792012\n",
      "0010       NaN       NaN  1.703303        NaN\n",
      "0011       NaN       NaN  2.417564   2.417564\n",
      "0100       NaN  1.671102       NaN        NaN\n",
      "0101       NaN  2.303368       NaN   2.303368\n",
      "0110       NaN  2.088211  2.088211        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.370009       NaN       NaN        NaN\n",
      "1001  1.671996       NaN       NaN   2.088211\n",
      "1010  1.701332       NaN  2.303368        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.024608  2.417564       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.551750  1.792012  1.792012        NaN\n",
      "1111  1.453164  1.497571  1.497571   1.497571\n",
      "1.2681013905118226\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.393513   1.006594\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.571778       NaN   0.975456\n",
      "0110       NaN  1.598188  1.676295        NaN\n",
      "0111       NaN  1.327432  1.370494   1.002893\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.085478       NaN       NaN   0.936667\n",
      "1010  2.300945       NaN  1.704622        NaN\n",
      "1011  1.668581       NaN  1.384545   0.955501\n",
      "1100  2.415523  2.028605       NaN        NaN\n",
      "1101  1.700566  1.529627       NaN   0.940489\n",
      "1110  1.789944  1.552824  1.509912        NaN\n",
      "1111  1.498720  1.311560  1.277690   1.467465\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.789944\n",
      "0010       NaN       NaN  1.700566        NaN\n",
      "0011       NaN       NaN  2.415523   2.415523\n",
      "0100       NaN  1.668581       NaN        NaN\n",
      "0101       NaN  2.300945       NaN   2.300945\n",
      "0110       NaN  2.085478  2.085478        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.370494       NaN       NaN        NaN\n",
      "1001  1.676295       NaN       NaN   2.085478\n",
      "1010  1.704622       NaN  2.300945        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.028605  2.415523       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.552824  1.789944  1.789944        NaN\n",
      "1111  1.467465  1.498720  1.498720   1.498720\n",
      "1.2636187133277272\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.390551   1.009678\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.568727       NaN   0.978129\n",
      "0110       NaN  1.596252  1.680626        NaN\n",
      "0111       NaN  1.324365  1.371021   1.006614\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.082754       NaN       NaN   0.938155\n",
      "1010  2.298554       NaN  1.707956        NaN\n",
      "1011  1.666073       NaN  1.383928   0.958181\n",
      "1100  2.413523  2.032650       NaN        NaN\n",
      "1101  1.697844  1.529012       NaN   0.943259\n",
      "1110  1.787906  1.553950  1.513721        NaN\n",
      "1111  1.499951  1.314290  1.282366   1.481729\n",
      "None\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.787906\n",
      "0010       NaN       NaN  1.697844        NaN\n",
      "0011       NaN       NaN  2.413523   2.413523\n",
      "0100       NaN  1.666073       NaN        NaN\n",
      "0101       NaN  2.298554       NaN   2.298554\n",
      "0110       NaN  2.082754  2.082754        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.371021       NaN       NaN        NaN\n",
      "1001  1.680626       NaN       NaN   2.082754\n",
      "1010  1.707956       NaN  2.298554        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.032650  2.413523       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.553950  1.787906  1.787906        NaN\n",
      "1111  1.481729  1.499951  1.499951   1.499951\n",
      "1.2590108010516332\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.387608   1.012788\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.565693       NaN   0.980830\n",
      "0110       NaN  1.594348  1.684987        NaN\n",
      "0111       NaN  1.321320  1.371592   1.010371\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.080037       NaN       NaN   0.939667\n",
      "1010  2.296196       NaN  1.711333        NaN\n",
      "1011  1.663577       NaN  1.383344   0.960891\n",
      "1100  2.411563  2.036744       NaN        NaN\n",
      "1101  1.695139  1.528434       NaN   0.946065\n",
      "1110  1.785899  1.555128  1.517574        NaN\n",
      "1111  1.501262  1.317157  1.287197   1.495952\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.785899\n",
      "0010       NaN       NaN  1.695139        NaN\n",
      "0011       NaN       NaN  2.411563   2.411563\n",
      "0100       NaN  1.663577       NaN        NaN\n",
      "0101       NaN  2.296196       NaN   2.296196\n",
      "0110       NaN  2.080037  2.080037        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.371592       NaN       NaN        NaN\n",
      "1001  1.684987       NaN       NaN   2.080037\n",
      "1010  1.711333       NaN  2.296196        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.036744  2.411563       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.555128  1.785899  1.785899        NaN\n",
      "1111  1.495952  1.501262  1.501262   1.501262\n",
      "1.254285565922249\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.384685   1.015925\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.562676       NaN   0.983558\n",
      "0110       NaN  1.592477  1.689378        NaN\n",
      "0111       NaN  1.318299  1.372206   1.014165\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.077328       NaN       NaN   0.941202\n",
      "1010  2.293870       NaN  1.714753        NaN\n",
      "1011  1.661095       NaN  1.382793   0.963632\n",
      "1100  2.409645  2.040886       NaN        NaN\n",
      "1101  1.692449  1.527892       NaN   0.948908\n",
      "1110  1.783923  1.556358  1.521469        NaN\n",
      "1111  1.502647  1.320157  1.292178   1.510128\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.783923\n",
      "0010       NaN       NaN  1.692449        NaN\n",
      "0011       NaN       NaN  2.409645   2.409645\n",
      "0100       NaN  1.661095       NaN        NaN\n",
      "0101       NaN  2.293870       NaN   2.293870\n",
      "0110       NaN  2.077328  2.077328        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.372206       NaN       NaN        NaN\n",
      "1001  1.689378       NaN       NaN   2.077328\n",
      "1010  1.714753       NaN  2.293870        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.040886  2.409645       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.556358  1.783923  1.783923        NaN\n",
      "1111  1.510128  1.510128  1.510128   1.502647\n",
      "1.2494507472958385\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.381781   1.019089\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.559676       NaN   0.986314\n",
      "0110       NaN  1.590637  1.693800        NaN\n",
      "0111       NaN  1.315302  1.372864   1.017996\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.074628       NaN       NaN   0.942761\n",
      "1010  2.291578       NaN  1.718216        NaN\n",
      "1011  1.658627       NaN  1.382275   0.966405\n",
      "1100  2.407769  2.045076       NaN        NaN\n",
      "1101  1.689777  1.527386       NaN   0.951787\n",
      "1110  1.781979  1.557642  1.525406        NaN\n",
      "1111  1.504103  1.323286  1.297304   1.524254\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.781979\n",
      "0010       NaN       NaN  1.689777        NaN\n",
      "0011       NaN       NaN  2.407769   2.407769\n",
      "0100       NaN  1.658627       NaN        NaN\n",
      "0101       NaN  2.291578       NaN   2.291578\n",
      "0110       NaN  2.074628  2.074628        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.372864       NaN       NaN        NaN\n",
      "1001  1.693800       NaN       NaN   2.074628\n",
      "1010  1.718216       NaN  2.291578        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.045076  2.407769       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.557642  1.781979  1.781979        NaN\n",
      "1111  1.524254  1.524254  1.524254   1.504103\n",
      "1.2445138976393677\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.378898   1.022279\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.556694       NaN   0.989098\n",
      "0110       NaN  1.588831  1.698253        NaN\n",
      "0111       NaN  1.312328  1.373565   1.021865\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.071936       NaN       NaN   0.944343\n",
      "1010  2.289319       NaN  1.721723        NaN\n",
      "1011  1.656173       NaN  1.381792   0.969209\n",
      "1100  2.405934  2.049315       NaN        NaN\n",
      "1101  1.687121  1.526918       NaN   0.954703\n",
      "1110  1.780066  1.558978  1.529387        NaN\n",
      "1111  1.505627  1.326540  1.302570   1.538325\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.780066\n",
      "0010       NaN       NaN  1.687121        NaN\n",
      "0011       NaN       NaN  2.405934   2.405934\n",
      "0100       NaN  1.656173       NaN        NaN\n",
      "0101       NaN  2.289319       NaN   2.289319\n",
      "0110       NaN  2.071936  2.071936        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.373565       NaN       NaN        NaN\n",
      "1001  1.698253       NaN       NaN   2.071936\n",
      "1010  1.721723       NaN  2.289319        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.049315  2.405934       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.558978  1.780066  1.780066        NaN\n",
      "1111  1.538325  1.538325  1.538325   1.505627\n",
      "1.2394823703456066\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.376034   1.025495\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.553729       NaN   0.991910\n",
      "0110       NaN  1.587057  1.702736        NaN\n",
      "0111       NaN  1.309379  1.374311   1.025771\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.069254       NaN       NaN   0.945950\n",
      "1010  2.287093       NaN  1.725274        NaN\n",
      "1011  1.653733       NaN  1.381343   0.972045\n",
      "1100  2.404141  2.053603       NaN        NaN\n",
      "1101  1.684482  1.526486       NaN   0.957656\n",
      "1110  1.778185  1.560369  1.533411        NaN\n",
      "1111  1.507215  1.329915  1.307972   1.552339\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.778185\n",
      "0010       NaN       NaN  1.684482        NaN\n",
      "0011       NaN       NaN  2.404141   2.404141\n",
      "0100       NaN  1.653733       NaN        NaN\n",
      "0101       NaN  2.287093       NaN   2.287093\n",
      "0110       NaN  2.069254  2.069254        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.374311       NaN       NaN        NaN\n",
      "1001  1.702736       NaN       NaN   2.069254\n",
      "1010  1.725274       NaN  2.287093        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.053603  2.404141       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.560369  1.778185  1.778185        NaN\n",
      "1111  1.552339  1.552339  1.552339   1.507215\n",
      "1.234363309302424\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.373190   1.028739\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.550782       NaN   0.994749\n",
      "0110       NaN  1.585315  1.707249        NaN\n",
      "0111       NaN  1.306454  1.375100   1.029714\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.066580       NaN       NaN   0.947581\n",
      "1010  2.284901       NaN  1.728869        NaN\n",
      "1011  1.651307       NaN  1.380928   0.974913\n",
      "1100  2.402390  2.057939       NaN        NaN\n",
      "1101  1.681861  1.526093       NaN   0.960647\n",
      "1110  1.776337  1.561813  1.537479        NaN\n",
      "1111  1.508864  1.333407  1.313505   1.566290\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.776337\n",
      "0010       NaN       NaN  1.681861        NaN\n",
      "0011       NaN       NaN  2.402390   2.402390\n",
      "0100       NaN  1.651307       NaN        NaN\n",
      "0101       NaN  2.284901       NaN   2.284901\n",
      "0110       NaN  2.066580  2.066580        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.375100       NaN       NaN        NaN\n",
      "1001  1.707249       NaN       NaN   2.066580\n",
      "1010  1.728869       NaN  2.284901        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.057939  2.402390       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.561813  1.776337  1.776337        NaN\n",
      "1111  1.566290  1.566290  1.566290   1.508864\n",
      "1.2291636401402126\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.370366   1.032009\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.547853       NaN   0.997617\n",
      "0110       NaN  1.583606  1.711792        NaN\n",
      "0111       NaN  1.303554  1.375934   1.033695\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.063916       NaN       NaN   0.949236\n",
      "1010  2.282743       NaN  1.732507        NaN\n",
      "1011  1.648896       NaN  1.380548   0.977813\n",
      "1100  2.400681  2.062324       NaN        NaN\n",
      "1101  1.679259  1.525738       NaN   0.963676\n",
      "1110  1.774521  1.563311  1.541590        NaN\n",
      "1111  1.510569  1.337013  1.319165   1.580176\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.774521\n",
      "0010       NaN       NaN  1.679259        NaN\n",
      "0011       NaN       NaN  2.400681   2.400681\n",
      "0100       NaN  1.648896       NaN        NaN\n",
      "0101       NaN  2.282743       NaN   2.282743\n",
      "0110       NaN  2.063916  2.063916        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.375934       NaN       NaN        NaN\n",
      "1001  1.711792       NaN       NaN   2.063916\n",
      "1010  1.732507       NaN  2.282743        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.062324  2.400681       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.563311  1.774521  1.774521        NaN\n",
      "1111  1.580176  1.580176  1.580176   1.510569\n",
      "1.223890063074763\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.367562   1.035306\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.544942       NaN   1.000513\n",
      "0110       NaN  1.581929  1.716365        NaN\n",
      "0111       NaN  1.300679  1.376813   1.037713\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.061261       NaN       NaN   0.950915\n",
      "1010  2.280619       NaN  1.736190        NaN\n",
      "1011  1.646501       NaN  1.380203   0.980746\n",
      "1100  2.399015  2.066758       NaN        NaN\n",
      "1101  1.676674  1.525421       NaN   0.966742\n",
      "1110  1.772739  1.564863  1.545746        NaN\n",
      "1111  1.512329  1.340728  1.324947   1.593993\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.772739\n",
      "0010       NaN       NaN  1.676674        NaN\n",
      "0011       NaN       NaN  2.399015   2.399015\n",
      "0100       NaN  1.646501       NaN        NaN\n",
      "0101       NaN  2.280619       NaN   2.280619\n",
      "0110       NaN  2.061261  2.061261        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.376813       NaN       NaN        NaN\n",
      "1001  1.716365       NaN       NaN   2.061261\n",
      "1010  1.736190       NaN  2.280619        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.066758  2.399015       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.564863  1.772739  1.772739        NaN\n",
      "1111  1.593993  1.593993  1.593993   1.512329\n",
      "1.2185490472577638\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.364779   1.038630\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.542050       NaN   1.003437\n",
      "0110       NaN  1.580284  1.720967        NaN\n",
      "0111       NaN  1.297830  1.377737   1.041770\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.058615       NaN       NaN   0.952620\n",
      "1010  2.278530       NaN  1.739918        NaN\n",
      "1011  1.644120       NaN  1.379894   0.983712\n",
      "1100  2.397391  2.071241       NaN        NaN\n",
      "1101  1.674109  1.525143       NaN   0.969848\n",
      "1110  1.770990  1.566470  1.549946        NaN\n",
      "1111  1.514139  1.344549  1.330847   1.607739\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.770990\n",
      "0010       NaN       NaN  1.674109        NaN\n",
      "0011       NaN       NaN  2.397391   2.397391\n",
      "0100       NaN  1.644120       NaN        NaN\n",
      "0101       NaN  2.278530       NaN   2.278530\n",
      "0110       NaN  2.058615  2.058615        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.377737       NaN       NaN        NaN\n",
      "1001  1.720967       NaN       NaN   2.058615\n",
      "1010  1.739918       NaN  2.278530        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.071241  2.397391       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.566470  1.770990  1.770990        NaN\n",
      "1111  1.607739  1.607739  1.607739   1.514139\n",
      "1.2131468265434253\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.362016   1.041980\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.539175       NaN   1.006390\n",
      "0110       NaN  1.578672  1.725600        NaN\n",
      "0111       NaN  1.295006  1.378706   1.045864\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.055980       NaN       NaN   0.954349\n",
      "1010  2.276475       NaN  1.743689        NaN\n",
      "1011  1.641756       NaN  1.379621   0.986711\n",
      "1100  2.395809  2.075773       NaN        NaN\n",
      "1101  1.671563  1.524905       NaN   0.972992\n",
      "1110  1.769274  1.568133  1.554190        NaN\n",
      "1111  1.515996  1.348473  1.336861   1.621410\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.769274\n",
      "0010       NaN       NaN  1.671563        NaN\n",
      "0011       NaN       NaN  2.395809   2.395809\n",
      "0100       NaN  1.641756       NaN        NaN\n",
      "0101       NaN  2.276475       NaN   2.276475\n",
      "0110       NaN  2.055980  2.055980        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.378706       NaN       NaN        NaN\n",
      "1001  1.725600       NaN       NaN   2.055980\n",
      "1010  1.743689       NaN  2.276475        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.075773  2.395809       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.568133  1.769274  1.769274        NaN\n",
      "1111  1.621410  1.621410  1.621410   1.515996\n",
      "1.2076893965773163\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.359274   1.045357\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.536320       NaN   1.009370\n",
      "0110       NaN  1.577093  1.730262        NaN\n",
      "0111       NaN  1.292208  1.379720   1.049997\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.053354       NaN       NaN   0.956104\n",
      "1010  2.274455       NaN  1.747506        NaN\n",
      "1011  1.639408       NaN  1.379385   0.989744\n",
      "1100  2.394271  2.080354       NaN        NaN\n",
      "1101  1.669036  1.524707       NaN   0.976175\n",
      "1110  1.767593  1.569850  1.558479        NaN\n",
      "1111  1.517899  1.352496  1.342984   1.635004\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.767593\n",
      "0010       NaN       NaN  1.669036        NaN\n",
      "0011       NaN       NaN  2.394271   2.394271\n",
      "0100       NaN  1.639408       NaN        NaN\n",
      "0101       NaN  2.274455       NaN   2.274455\n",
      "0110       NaN  2.053354  2.053354        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.379720       NaN       NaN        NaN\n",
      "1001  1.730262       NaN       NaN   2.053354\n",
      "1010  1.747506       NaN  2.274455        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.080354  2.394271       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.569850  1.767593  1.767593        NaN\n",
      "1111  1.635004  1.635004  1.635004   1.517899\n",
      "1.2021825131123\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.356553   1.048761\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.533483       NaN   1.012379\n",
      "0110       NaN  1.575545  1.734953        NaN\n",
      "0111       NaN  1.289436  1.380780   1.054167\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.050739       NaN       NaN   0.957883\n",
      "1010  2.272470       NaN  1.751367        NaN\n",
      "1011  1.637075       NaN  1.379185   0.992810\n",
      "1100  2.392775  2.084983       NaN        NaN\n",
      "1101  1.666529  1.524549       NaN   0.979398\n",
      "1110  1.765946  1.571624  1.562813        NaN\n",
      "1111  1.519843  1.356615  1.349214   1.648518\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.765946\n",
      "0010       NaN       NaN  1.666529        NaN\n",
      "0011       NaN       NaN  2.392775   2.392775\n",
      "0100       NaN  1.637075       NaN        NaN\n",
      "0101       NaN  2.272470       NaN   2.272470\n",
      "0110       NaN  2.050739  2.050739        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.380780       NaN       NaN        NaN\n",
      "1001  1.734953       NaN       NaN   2.050739\n",
      "1010  1.751367       NaN  2.272470        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.084983  2.392775       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.571624  1.765946  1.765946        NaN\n",
      "1111  1.648518  1.648518  1.648518   1.519843\n",
      "1.1966316914562896\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.353852   1.052192\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.530665       NaN   1.015417\n",
      "0110       NaN  1.574030  1.739674        NaN\n",
      "0111       NaN  1.286691  1.381886   1.058376\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.048134       NaN       NaN   0.959689\n",
      "1010  2.270521       NaN  1.755273        NaN\n",
      "1011  1.634760       NaN  1.379022   0.995910\n",
      "1100  2.391323  2.089662       NaN        NaN\n",
      "1101  1.664042  1.524431       NaN   0.982660\n",
      "1110  1.764334  1.573453  1.567193        NaN\n",
      "1111  1.521826  1.360826  1.355546   1.661950\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.764334\n",
      "0010       NaN       NaN  1.664042        NaN\n",
      "0011       NaN       NaN  2.391323   2.391323\n",
      "0100       NaN  1.634760       NaN        NaN\n",
      "0101       NaN  2.270521       NaN   2.270521\n",
      "0110       NaN  2.048134  2.048134        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.381886       NaN       NaN        NaN\n",
      "1001  1.739674       NaN       NaN   2.048134\n",
      "1010  1.755273       NaN  2.270521        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.089662  2.391323       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.573453  1.764334  1.764334        NaN\n",
      "1111  1.661950  1.661950  1.661950   1.521826\n",
      "1.1910422069573128\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.351173   1.055649\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.527866       NaN   1.018483\n",
      "0110       NaN  1.572548  1.744423        NaN\n",
      "0111       NaN  1.283973  1.383038   1.062624\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.045539       NaN       NaN   0.961520\n",
      "1010  2.268607       NaN  1.759224        NaN\n",
      "1011  1.632462       NaN  1.378896   0.999045\n",
      "1100  2.389914  2.094390       NaN        NaN\n",
      "1101  1.661576  1.524355       NaN   0.985963\n",
      "1110  1.762757  1.575339  1.571617        NaN\n",
      "1111  1.523846  1.365128  1.361976   1.675298\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.762757\n",
      "0010       NaN       NaN  1.661576        NaN\n",
      "0011       NaN       NaN  2.389914   2.389914\n",
      "0100       NaN  1.632462       NaN        NaN\n",
      "0101       NaN  2.268607       NaN   2.268607\n",
      "0110       NaN  2.045539  2.045539        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.383038       NaN       NaN        NaN\n",
      "1001  1.744423       NaN       NaN   2.045539\n",
      "1010  1.759224       NaN  2.268607        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.094390  2.389914       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.575339  1.762757  1.762757        NaN\n",
      "1111  1.675298  1.675298  1.675298   1.523846\n",
      "1.185419096432966\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.348515   1.059133\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.525086       NaN   1.021578\n",
      "0110       NaN  1.571098  1.749202        NaN\n",
      "0111       NaN  1.281282  1.384235   1.066910\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.042956       NaN       NaN   0.963377\n",
      "1010  2.266728       NaN  1.763220        NaN\n",
      "1011  1.630180       NaN  1.378809   1.002214\n",
      "1100  2.388549  2.099168       NaN        NaN\n",
      "1101  1.659131  1.524320       NaN   0.989306\n",
      "1110  1.761215  1.577281  1.576088        NaN\n",
      "1111  1.525900  1.369515  1.368501   1.688560\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.761215\n",
      "0010       NaN       NaN  1.659131        NaN\n",
      "0011       NaN       NaN  2.388549   2.388549\n",
      "0100       NaN  1.630180       NaN        NaN\n",
      "0101       NaN  2.266728       NaN   2.266728\n",
      "0110       NaN  2.042956  2.042956        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.384235       NaN       NaN        NaN\n",
      "1001  1.749202       NaN       NaN   2.042956\n",
      "1010  1.763220       NaN  2.266728        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.099168  2.388549       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.577281  1.761215  1.761215        NaN\n",
      "1111  1.688560  1.688560  1.688560   1.525900\n",
      "1.1797671604536095\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.345877   1.062644\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.522326       NaN   1.024701\n",
      "0110       NaN  1.569680  1.754009        NaN\n",
      "0111       NaN  1.278619  1.385480   1.071234\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.040384       NaN       NaN   0.965260\n",
      "1010  2.264886       NaN  1.767261        NaN\n",
      "1011  1.627917       NaN  1.378759   1.005418\n",
      "1100  2.387227  2.103994       NaN        NaN\n",
      "1101  1.656708  1.524327       NaN   0.992690\n",
      "1110  1.759709  1.579280  1.580604        NaN\n",
      "1111  1.527986  1.373987  1.375117   1.701733\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.759709\n",
      "0010       NaN       NaN  1.656708        NaN\n",
      "0011       NaN       NaN  2.387227   2.387227\n",
      "0100       NaN  1.627917       NaN        NaN\n",
      "0101       NaN  2.264886       NaN   2.264886\n",
      "0110       NaN  2.040384  2.040384        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.385480       NaN       NaN        NaN\n",
      "1001  1.754009       NaN       NaN   2.040384\n",
      "1010  1.767261       NaN  2.264886        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.103994  2.387227       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.580604  1.759709  1.759709        NaN\n",
      "1111  1.701733  1.701733  1.701733   1.527986\n",
      "1.175056855956745\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.343261   1.066182\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.519585       NaN   1.027853\n",
      "0110       NaN  1.568294  1.758845        NaN\n",
      "0111       NaN  1.275983  1.386770   1.075598\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.037822       NaN       NaN   0.967169\n",
      "1010  2.263080       NaN  1.771348        NaN\n",
      "1011  1.625671       NaN  1.378748   1.008657\n",
      "1100  2.385949  2.108870       NaN        NaN\n",
      "1101  1.654306  1.524377       NaN   0.996114\n",
      "1110  1.758240  1.581336  1.585166        NaN\n",
      "1111  1.530101  1.378539  1.381821   1.714817\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.758240\n",
      "0010       NaN       NaN  1.654306        NaN\n",
      "0011       NaN       NaN  2.385949   2.385949\n",
      "0100       NaN  1.625671       NaN        NaN\n",
      "0101       NaN  2.263080       NaN   2.263080\n",
      "0110       NaN  2.037822  2.037822        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.386770       NaN       NaN        NaN\n",
      "1001  1.758845       NaN       NaN   2.037822\n",
      "1010  1.771348       NaN  2.263080        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.108870  2.385949       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.585166  1.758240  1.758240        NaN\n",
      "1111  1.714817  1.714817  1.714817   1.530101\n",
      "1.1711764627570604\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.340667   1.069747\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.516864       NaN   1.031034\n",
      "0110       NaN  1.566941  1.763710        NaN\n",
      "0111       NaN  1.273374  1.388108   1.080000\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.035273       NaN       NaN   0.969105\n",
      "1010  2.261310       NaN  1.775480        NaN\n",
      "1011  1.623444       NaN  1.378776   1.011932\n",
      "1100  2.384715  2.113795       NaN        NaN\n",
      "1101  1.651926  1.524469       NaN   0.999581\n",
      "1110  1.756806  1.583449  1.589775        NaN\n",
      "1111  1.532244  1.383170  1.388609   1.727810\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.756806\n",
      "0010       NaN       NaN  1.651926        NaN\n",
      "0011       NaN       NaN  2.384715   2.384715\n",
      "0100       NaN  1.623444       NaN        NaN\n",
      "0101       NaN  2.261310       NaN   2.261310\n",
      "0110       NaN  2.035273  2.035273        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.388108       NaN       NaN        NaN\n",
      "1001  1.763710       NaN       NaN   2.035273\n",
      "1010  1.775480       NaN  2.261310        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.113795  2.384715       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.589775  1.756806  1.756806        NaN\n",
      "1111  1.727810  1.727810  1.727810   1.532244\n",
      "1.1672555698532239\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.338094   1.073338\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.514163       NaN   1.034244\n",
      "0110       NaN  1.565620  1.768603        NaN\n",
      "0111       NaN  1.270795  1.389492   1.084441\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.032735       NaN       NaN   0.971068\n",
      "1010  2.259577       NaN  1.779657        NaN\n",
      "1011  1.621235       NaN  1.378844   1.015242\n",
      "1100  2.383525  2.118769       NaN        NaN\n",
      "1101  1.649569  1.524604       NaN   1.003089\n",
      "1110  1.755410  1.585621  1.594430        NaN\n",
      "1111  1.534412  1.387876  1.395479   1.740711\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.755410\n",
      "0010       NaN       NaN  1.649569        NaN\n",
      "0011       NaN       NaN  2.383525   2.383525\n",
      "0100       NaN  1.621235       NaN        NaN\n",
      "0101       NaN  2.259577       NaN   2.259577\n",
      "0110       NaN  2.032735  2.032735        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.389492       NaN       NaN        NaN\n",
      "1001  1.768603       NaN       NaN   2.032735\n",
      "1010  1.779657       NaN  2.259577        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.118769  2.383525       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.594430  1.755410  1.755410        NaN\n",
      "1111  1.740711  1.740711  1.740711   1.534412\n",
      "1.1632974004949346\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.335543   1.076956\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.511482       NaN   1.037483\n",
      "0110       NaN  1.564331  1.773524        NaN\n",
      "0111       NaN  1.268243  1.390924   1.088921\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.030209       NaN       NaN   0.973058\n",
      "1010  2.257880       NaN  1.783881        NaN\n",
      "1011  1.619045       NaN  1.378950   1.018588\n",
      "1100  2.382379  2.123793       NaN        NaN\n",
      "1101  1.647235  1.524783       NaN   1.006639\n",
      "1110  1.754050  1.587850  1.599133        NaN\n",
      "1111  1.536603  1.392655  1.402428   1.753518\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.754050\n",
      "0010       NaN       NaN  1.647235        NaN\n",
      "0011       NaN       NaN  2.382379   2.382379\n",
      "0100       NaN  1.619045       NaN        NaN\n",
      "0101       NaN  2.257880       NaN   2.257880\n",
      "0110       NaN  2.030209  2.030209        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.390924       NaN       NaN        NaN\n",
      "1001  1.773524       NaN       NaN   2.030209\n",
      "1010  1.783881       NaN  2.257880        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.123793  2.382379       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.599133  1.754050  1.754050        NaN\n",
      "1111  1.753518  1.753518  1.753518   1.536603\n",
      "1.159305031874444\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.333013   1.080601\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.508821       NaN   1.040750\n",
      "0110       NaN  1.563074  1.778474        NaN\n",
      "0111       NaN  1.265721  1.392403   1.093440\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.027695       NaN       NaN   0.975074\n",
      "1010  2.256220       NaN  1.788150        NaN\n",
      "1011  1.616875       NaN  1.379097   1.021970\n",
      "1100  2.381277  2.128865       NaN        NaN\n",
      "1101  1.644924  1.525006       NaN   1.010232\n",
      "1110  1.752728  1.590137  1.603882        NaN\n",
      "1111  1.538816  1.397506  1.409451   1.766231\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.752728\n",
      "0010       NaN       NaN  1.644924        NaN\n",
      "0011       NaN       NaN  2.381277   2.381277\n",
      "0100       NaN  1.616875       NaN        NaN\n",
      "0101       NaN  2.256220       NaN   2.256220\n",
      "0110       NaN  2.027695  2.027695        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.392403       NaN       NaN        NaN\n",
      "1001  1.778474       NaN       NaN   2.027695\n",
      "1010  1.788150       NaN  2.256220        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.128865  2.381277       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.603882  1.752728  1.752728        NaN\n",
      "1111  1.766231  1.766231  1.766231   1.538816\n",
      "1.1552813974594018\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.330505   1.084273\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.506180       NaN   1.044047\n",
      "0110       NaN  1.561849  1.783451        NaN\n",
      "0111       NaN  1.263227  1.393930   1.097999\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.025193       NaN       NaN   0.977118\n",
      "1010  2.254598       NaN  1.792465        NaN\n",
      "1011  1.614724       NaN  1.379284   1.025389\n",
      "1100  2.380220  2.133988       NaN        NaN\n",
      "1101  1.642637  1.525274       NaN   1.013868\n",
      "1110  1.751444  1.592483  1.608678        NaN\n",
      "1111  1.541049  1.402425  1.416547   1.778848\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.751444\n",
      "0010       NaN       NaN  1.642637        NaN\n",
      "0011       NaN       NaN  2.380220   2.380220\n",
      "0100       NaN  1.614724       NaN        NaN\n",
      "0101       NaN  2.254598       NaN   2.254598\n",
      "0110       NaN  2.025193  2.025193        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.393930       NaN       NaN        NaN\n",
      "1001  1.783451       NaN       NaN   2.025193\n",
      "1010  1.792465       NaN  2.254598        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.133988  2.380220       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.608678  1.751444  1.751444        NaN\n",
      "1111  1.778848  1.778848  1.778848   1.541049\n",
      "1.1512292896702567\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.328019   1.087971\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.503560       NaN   1.047373\n",
      "0110       NaN  1.560657  1.788456        NaN\n",
      "0111       NaN  1.260763  1.395504   1.102596\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.022704       NaN       NaN   0.979190\n",
      "1010  2.253013       NaN  1.796826        NaN\n",
      "1011  1.612592       NaN  1.379512   1.028845\n",
      "1100  2.379208  2.139159       NaN        NaN\n",
      "1101  1.640375  1.525586       NaN   1.017546\n",
      "1110  1.750198  1.594888  1.613521        NaN\n",
      "1111  1.543300  1.407410  1.423713   1.791369\n",
      "1000\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.750198\n",
      "0010       NaN       NaN  1.640375        NaN\n",
      "0011       NaN       NaN  2.379208   2.379208\n",
      "0100       NaN  1.612592       NaN        NaN\n",
      "0101       NaN  2.253013       NaN   2.253013\n",
      "0110       NaN  2.022704  2.022704        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.395504       NaN       NaN        NaN\n",
      "1001  1.788456       NaN       NaN   2.022704\n",
      "1010  1.796826       NaN  2.253013        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.139159  2.379208       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.613521  1.750198  1.750198        NaN\n",
      "1111  1.791369  1.791369  1.791369   1.543300\n",
      "1.1471513628601784\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.325556   1.091696\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.500960       NaN   1.050728\n",
      "0110       NaN  1.559496  1.793489        NaN\n",
      "0111       NaN  1.258328  1.397126   1.107233\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.020227       NaN       NaN   0.981289\n",
      "1010  2.251466       NaN  1.801233        NaN\n",
      "1011  1.610481       NaN  1.379781   1.032338\n",
      "1100  2.378240  2.144380       NaN        NaN\n",
      "1101  1.638136  1.525944       NaN   1.021268\n",
      "1110  1.748990  1.597352  1.618412        NaN\n",
      "1111  1.545568  1.412460  1.430947   1.803794\n",
      "0100\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.748990\n",
      "0010       NaN       NaN  1.638136        NaN\n",
      "0011       NaN       NaN  2.378240   2.378240\n",
      "0100       NaN  1.610481       NaN        NaN\n",
      "0101       NaN  2.251466       NaN   2.251466\n",
      "0110       NaN  2.020227  2.020227        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.397126       NaN       NaN        NaN\n",
      "1001  1.793489       NaN       NaN   2.020227\n",
      "1010  1.801233       NaN  2.251466        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.144380  2.378240       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.618412  1.748990  1.748990        NaN\n",
      "1111  1.803794  1.803794  1.803794   1.545568\n",
      "1.1430501365576868\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.323114   1.095448\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.498381       NaN   1.054112\n",
      "0110       NaN  1.558367  1.798549        NaN\n",
      "0111       NaN  1.255924  1.398796   1.111910\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.017764       NaN       NaN   0.983416\n",
      "1010  2.249956       NaN  1.805687        NaN\n",
      "1011  1.608391       NaN  1.380092   1.035868\n",
      "1100  2.377317  2.149651       NaN        NaN\n",
      "1101  1.635923  1.526347       NaN   1.025034\n",
      "1110  1.747821  1.599875  1.623351        NaN\n",
      "1111  1.547851  1.417572  1.438245   1.816123\n",
      "0100\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.747821\n",
      "0010       NaN       NaN  1.635923        NaN\n",
      "0011       NaN       NaN  2.377317   2.377317\n",
      "0100       NaN  1.608391       NaN        NaN\n",
      "0101       NaN  2.249956       NaN   2.249956\n",
      "0110       NaN  2.017764  2.017764        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.398796       NaN       NaN        NaN\n",
      "1001  1.798549       NaN       NaN   2.017764\n",
      "1010  1.805687       NaN  2.249956        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.149651  2.377317       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.623351  1.747821  1.747821        NaN\n",
      "1111  1.816123  1.816123  1.816123   1.547851\n",
      "1.1389279989344363\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.320695   1.099226\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.495823       NaN   1.057525\n",
      "0110       NaN  1.557271  1.803636        NaN\n",
      "0111       NaN  1.253549  1.400514   1.116625\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.015314       NaN       NaN   0.985571\n",
      "1010  2.248485       NaN  1.810187        NaN\n",
      "1011  1.606321       NaN  1.380444   1.039436\n",
      "1100  2.376439  2.154970       NaN        NaN\n",
      "1101  1.633735  1.526796       NaN   1.028844\n",
      "1110  1.746691  1.602458  1.628338        NaN\n",
      "1111  1.550148  1.422745  1.445605   1.828354\n",
      "0100\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.746691\n",
      "0010       NaN       NaN  1.633735        NaN\n",
      "0011       NaN       NaN  2.376439   2.376439\n",
      "0100       NaN  1.606321       NaN        NaN\n",
      "0101       NaN  2.248485       NaN   2.248485\n",
      "0110       NaN  2.015314  2.015314        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.400514       NaN       NaN        NaN\n",
      "1001  1.803636       NaN       NaN   2.015314\n",
      "1010  1.810187       NaN  2.248485        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.154970  2.376439       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.628338  1.746691  1.746691        NaN\n",
      "1111  1.828354  1.828354  1.828354   1.550148\n",
      "1.134787210462918\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.318298   1.103031\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.493287       NaN   1.060968\n",
      "0110       NaN  1.556206  1.808751        NaN\n",
      "0111       NaN  1.251205  1.402280   1.121381\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.012877       NaN       NaN   0.987755\n",
      "1010  2.247051       NaN  1.814733        NaN\n",
      "1011  1.604273       NaN  1.380839   1.043041\n",
      "1100  2.375606  2.160339       NaN        NaN\n",
      "1101  1.631572  1.527292       NaN   1.032699\n",
      "1110  1.745600  1.605101  1.633374        NaN\n",
      "1111  1.552458  1.427976  1.453026   1.840488\n",
      "0100\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.745600\n",
      "0010       NaN       NaN  1.631572        NaN\n",
      "0011       NaN       NaN  2.375606   2.375606\n",
      "0100       NaN  1.604273       NaN        NaN\n",
      "0101       NaN  2.247051       NaN   2.247051\n",
      "0110       NaN  2.012877  2.012877        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.402280       NaN       NaN        NaN\n",
      "1001  1.808751       NaN       NaN   2.012877\n",
      "1010  1.814733       NaN  2.247051        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.160339  2.375606       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.633374  1.745600  1.745600        NaN\n",
      "1111  1.840488  1.840488  1.840488   1.552458\n",
      "1.1306299077311597\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.315923   1.106863\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.490771       NaN   1.064440\n",
      "0110       NaN  1.555173  1.813892        NaN\n",
      "0111       NaN  1.248891  1.404095   1.126176\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.010453       NaN       NaN   0.989966\n",
      "1010  2.245656       NaN  1.819325        NaN\n",
      "1011  1.602246       NaN  1.381276   1.046685\n",
      "1100  2.374818  2.165758       NaN        NaN\n",
      "1101  1.629436  1.527835       NaN   1.036598\n",
      "1110  1.744549  1.607804  1.638457        NaN\n",
      "1111  1.554780  1.433265  1.460504   1.852524\n",
      "0010\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.744549\n",
      "0010       NaN       NaN  1.629436        NaN\n",
      "0011       NaN       NaN  2.374818   2.374818\n",
      "0100       NaN  1.602246       NaN        NaN\n",
      "0101       NaN  2.245656       NaN   2.245656\n",
      "0110       NaN  2.010453  2.010453        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.404095       NaN       NaN        NaN\n",
      "1001  1.813892       NaN       NaN   2.010453\n",
      "1010  1.819325       NaN  2.245656        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.165758  2.374818       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.638457  1.744549  1.744549        NaN\n",
      "1111  1.852524  1.852524  1.852524   1.554780\n",
      "1.1264581073838074\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.313571   1.110721\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.488276       NaN   1.067941\n",
      "0110       NaN  1.554172  1.819060        NaN\n",
      "0111       NaN  1.246608  1.405958   1.131010\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.008044       NaN       NaN   0.992207\n",
      "1010  2.244300       NaN  1.823964        NaN\n",
      "1011  1.600242       NaN  1.381756   1.050368\n",
      "1100  2.374075  2.171225       NaN        NaN\n",
      "1101  1.627326  1.528426       NaN   1.040542\n",
      "1110  1.743538  1.610567  1.643589        NaN\n",
      "1111  1.557112  1.438608  1.468038   1.864464\n",
      "0010\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.743538\n",
      "0010       NaN       NaN  1.627326        NaN\n",
      "0011       NaN       NaN  2.374075   2.374075\n",
      "0100       NaN  1.600242       NaN        NaN\n",
      "0101       NaN  2.244300       NaN   2.244300\n",
      "0110       NaN  2.008044  2.008044        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.405958       NaN       NaN        NaN\n",
      "1001  1.819060       NaN       NaN   2.008044\n",
      "1010  1.823964       NaN  2.244300        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.171225  2.374075       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.643589  1.743538  1.743538        NaN\n",
      "1111  1.864464  1.864464  1.864464   1.557112\n",
      "1.122273710161238\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.000000\n",
      "0010       NaN       NaN  2.000000        NaN\n",
      "0011       NaN       NaN  1.311242   1.114606\n",
      "0100       NaN  2.500000       NaN        NaN\n",
      "0101       NaN  1.485803       NaN   1.071472\n",
      "0110       NaN  1.553202  1.824255        NaN\n",
      "0111       NaN  1.244356  1.407871   1.135885\n",
      "1000  5.000000       NaN       NaN        NaN\n",
      "1001  2.005648       NaN       NaN   0.994477\n",
      "1010  2.242982       NaN  1.828650        NaN\n",
      "1011  1.598259       NaN  1.382279   1.054089\n",
      "1100  2.373378  2.176742       NaN        NaN\n",
      "1101  1.625243  1.529064       NaN   1.044532\n",
      "1110  1.742567  1.613391  1.648770        NaN\n",
      "1111  1.559455  1.444006  1.475626   1.876306\n",
      "0010\n",
      "      n_20_err  n_40_err  n_50_err  n_100_err\n",
      "0001       NaN       NaN       NaN   1.742567\n",
      "0010       NaN       NaN  1.625243        NaN\n",
      "0011       NaN       NaN  2.373378   2.373378\n",
      "0100       NaN  1.598259       NaN        NaN\n",
      "0101       NaN  2.242982       NaN   2.242982\n",
      "0110       NaN  2.005648  2.005648        NaN\n",
      "0111       NaN  5.000000  5.000000   5.000000\n",
      "1000  1.407871       NaN       NaN        NaN\n",
      "1001  1.824255       NaN       NaN   2.005648\n",
      "1010  1.828650       NaN  2.242982        NaN\n",
      "1011  2.500000       NaN  2.500000   2.500000\n",
      "1100  2.176742  2.373378       NaN        NaN\n",
      "1101  2.000000  2.000000       NaN   2.000000\n",
      "1110  1.648770  1.742567  1.742567        NaN\n",
      "1111  1.876306  1.876306  1.876306   1.559455\n",
      "1.1180785050105817\n"
     ]
    }
   ],
   "source": [
    "#friends_list ={'0': [3], '1': [3], '2': [3], '3': [0,1,2]}\n",
    "q_list=np.arange(0,4,0.05).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "err_uniform, _, _, _,_ = calc_error_groups( n_list = clients_dataset_array)\n",
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "util_uniform_ACFG_min_FR=calc_unity_groups(err_uniform=err_uniform, n_list = clients_dataset_array, preference=\"min-PA\",friends =friends)\n",
    "for q in q_list:\n",
    "    _, _, _, err_fair,_ = calc_error_groups( n_list = clients_dataset_array,fair=True, err_list=err_list,q=q)\n",
    "    util_uniform_ACFG_min_FR_i=calc_unity_groups(err_uniform=err_fair, n_list = clients_dataset_array, preference=\"min-PA\",friends =friends)\n",
    "    \n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "\n",
    "    stable_result=check_stable(util_uniform_ACFG_min_FR,util_uniform_ACFG_min_FR_i,coalitions)\n",
    "    stable_list.append(stable_result!=None)\n",
    "\n",
    "    print(err_fair)\n",
    "    print(stable_result)\n",
    "    print(util_uniform_ACFG_min_FR_i)\n",
    "    print(max(err_list)/min(err_fair_last_row))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "# plt.savefig(\"pwa_f.svg\")\n",
    "plt.savefig(\"pwa_f.svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 3. **Calculated egalitarian fairness bound** in Friendly Welfare Altruism v.s. **Obtained egalitarian fairness**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "# clients_dataset_array = np.array(clients_dataset_num)\n",
    "# grand_list=list(range(clients_dataset_array.shape[0]))\n",
    "# coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "# m = np.argmin(clients_dataset_array)\n",
    "# l=np.argmax(clients_dataset_array)\n",
    "# N_g=np.sum(clients_dataset_array)\n",
    "# N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "# lambdas_cal=[]\n",
    "# lambdas_cal_ref=[]\n",
    "# friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "# friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "# for i,coalition in enumerate(coalitions_except_grand):\n",
    "#     N_s=np.sum(coalition)\n",
    "#     N_s_2_sum=np.sum(coalition**2)  \n",
    "#     Not_N_s=N_g-N_s\n",
    "#     Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "\n",
    "#     c_in_s=[]\n",
    "#     c_and_f_num=[]\n",
    "#     c_and_f_not_num=[]\n",
    "#     c_and_f_num_sum=[]\n",
    "#     c_and_f_not_num_sum=[]\n",
    "#     f_in_c=[]\n",
    "#     for j in range(len(row_ids[i])):\n",
    "#         if row_ids[i][j]==\"1\":\n",
    "#             c_in_s.append(j)\n",
    "#             c_and_f_num_sum_i=[float('inf') for c_i in range(len(clients_dataset_num))]\n",
    "\n",
    "#             c_and_f_num_sum_i[j]=clients_dataset_array[j]\n",
    "#             for f in friends[str(j)] :\n",
    "#                 if row_ids[i][f]=='1':\n",
    "#                     c_and_f_num_sum_i[f]=clients_dataset_array[f]\n",
    "#                 else:\n",
    "#                     c_and_f_num_sum_i[f]=float('inf')\n",
    "#             c_and_f_num.append(np.array(c_and_f_num_sum_i))\n",
    "\n",
    "#             if len([clients_dataset_array[f]/Not_N_s   for f in friends[str(j)] if row_ids[i][f]=='0' ])!=0:\n",
    "#                 c_and_f_not_num_sum_i=[float('inf') for c_i in range(len(clients_dataset_num))]\n",
    "#                 c_and_f_not_num_sum_i[j]=clients_dataset_array[j]\n",
    "#                 for f in friends[str(j)] :\n",
    "#                     if row_ids[i][f]=='0':\n",
    "#                         c_and_f_not_num_sum_i[f]=clients_dataset_array[f]\n",
    "#                     else:\n",
    "#                         c_and_f_not_num_sum_i[f]=float('inf')\n",
    "#                 c_and_f_not_num.append(np.array(c_and_f_not_num_sum_i))\n",
    "\n",
    "#             c_and_f_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='1' ]))\n",
    "#             # c_and_f_not_num_sum.append(w*clients_dataset_array[j]/N_s+(1-w)*min([clients_dataset_array[j]/N_s]+[clients_dataset_array[f]/Not_N_s   for f in friends[str(j)] if row_ids[i][f]=='0' ]))\n",
    "#             if len([clients_dataset_array[f]/Not_N_s   for f in friends[str(j)] if row_ids[i][f]=='0' ])!=0:\n",
    "#                 c_and_f_not_num_sum.append(w*clients_dataset_array[j]/N_s+(1-w)*min([clients_dataset_array[f]/Not_N_s   for f in friends[str(j)] if row_ids[i][f]=='0' ]))\n",
    "#                 f_in_c.append(j)\n",
    "#             # c_and_f_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='1' ]))\n",
    "#             # c_and_f_not_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='0' ]))\n",
    "\n",
    "#     # k=np.argmin(np.mean(f_in_c_num+f_not_in_c_num*(N_s)/(Not_N_s), axis=1))\n",
    "    \n",
    "#     k1=np.argmin(np.array(c_and_f_num_sum))\n",
    "#     f1=np.argmin(c_and_f_num[k1])\n",
    "#     if len(c_and_f_not_num_sum)!=0:\n",
    "#         k2=np.argmin(np.array(c_and_f_not_num_sum))\n",
    "#         f2=np.argmin(c_and_f_not_num[k2])\n",
    "#     if len(c_and_f_not_num_sum)==0:\n",
    "#         lambda1=(N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*((N_s*clients_dataset_array[l])+w*(N_s_2_sum-clients_dataset_array[c_in_s[k1]]**2+(N_s-clients_dataset_array[c_in_s[k1]])**2)+(1-w)*(N_s_2_sum-clients_dataset_array[f1]**2+(N_s-clients_dataset_array[f1])**2)))\n",
    "\n",
    "\n",
    "#         lambda2=(N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*((N_s*clients_dataset_array[l])+w*(N_s_2_sum-clients_dataset_array[c_in_s[k1]]**2+(N_s-clients_dataset_array[c_in_s[k1]])**2)+(1-w)*(N_s_2_sum-clients_dataset_array[f2]**2+(N_s-clients_dataset_array[f2])**2)))\n",
    "#     # k = np.argmin(np.mean(f_in_c_num, axis=1)+np.mean(f_not_in_c_num, axis=1))\n",
    "#     else:\n",
    "#     # Not_N_s+=clients_dataset_array[c_in_s[k2]]\n",
    "#     # Not_N_s_2_sum+=clients_dataset_array[c_in_s[k2]]**2\n",
    "#         lambda1=(N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*((N_s*clients_dataset_array[l])+w*(N_s_2_sum-clients_dataset_array[c_in_s[k1]]**2+(N_s-clients_dataset_array[c_in_s[k1]])**2)+(1-w)*(N_s_2_sum-clients_dataset_array[f1]**2+(N_s-clients_dataset_array[f1])**2)))\n",
    "\n",
    "\n",
    "#         lambda2=(N_s**2*Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*(Not_N_s**2*w*(N_s*clients_dataset_array[l]+(N_s_2_sum-clients_dataset_array[c_in_s[k2]]**2+(N_s-clients_dataset_array[c_in_s[k2]])**2))+N_s**2*(1-w)*(Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f2]**2+(Not_N_s-clients_dataset_array[f2])**2)))\n",
    "\n",
    "    \n",
    "#     lambdas_cal.append(min(lambda1,lambda2))\n",
    "    \n",
    "#     # not_coalition=[i for i in clients_dataset_array.tolist() if i not in coalition.tolist()]\n",
    "#     # f1_ref=c_in_s.index(f1)\n",
    "#     # c_not_in_s=[i for i in grand_list if i not in c_in_s]\n",
    "#     # if f2 not in c_not_in_s:\n",
    "#     #     f2_ref=c_in_s.index(f2)\n",
    "#     #     lambda1_ref= w*calculate_error(coalition.tolist(),k1)+(1-w)*calculate_error(coalition.tolist(),f1_ref)\n",
    "#     #     lambda2_ref= w*calculate_error(coalition.tolist(),k2)+(1-w)*calculate_error(coalition.tolist(),f2_ref)\n",
    "#     # else:\n",
    "#     #     f2_ref=c_not_in_s.index(f2)\n",
    "#     #     lambda1_ref= w*calculate_error(coalition.tolist(),k1)+(1-w)*calculate_error(coalition.tolist(),f1_ref)\n",
    "#     #     lambda2_ref= w*calculate_error(coalition.tolist(),k2)+(1-w)*calculate_error(not_coalition,f2_ref)\n",
    "        \n",
    "#     # all_error=calculate_error(clients_dataset_array.tolist(),m)\n",
    "#     # lambdas_cal_ref.append(min(all_error/lambda1_ref,all_error/lambda2_ref))\n",
    "# lambda_cal= max(lambdas_cal) \n",
    "# lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9831706546064156"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)  \n",
    "    Not_N_s=N_g-N_s\n",
    "    Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "\n",
    "    c_in_s=[]\n",
    "    c_and_f_num=[]\n",
    "    c_and_f_not_num=[]\n",
    "    c_and_f_num_sum=[]\n",
    "    c_and_f_not_num_sum=[]\n",
    "\n",
    "    for j in range(len(row_ids[i])):\n",
    "        if row_ids[i][j]==\"1\":\n",
    "            c_in_s.append(j)\n",
    "            c_and_f_num_sum_i=[float('inf') for c_i in range(len(clients_dataset_num))]\n",
    "\n",
    "            c_and_f_num_sum_i[j]=clients_dataset_array[j]\n",
    "            for f in friends[str(j)] :\n",
    "                if row_ids[i][f]=='1':\n",
    "                    c_and_f_num_sum_i[f]=clients_dataset_array[f]\n",
    "                else:\n",
    "                    c_and_f_num_sum_i[f]=float('inf')\n",
    "            c_and_f_num.append(np.array(c_and_f_num_sum_i))\n",
    "\n",
    "        \n",
    "            c_and_f_not_num_sum_i=[float('inf') for c_i in range(len(clients_dataset_num))]\n",
    "            c_and_f_not_num_sum_i[j]=clients_dataset_array[j]\n",
    "            for f in friends[str(j)] :\n",
    "                if row_ids[i][f]=='0':\n",
    "                    c_and_f_not_num_sum_i[f]=clients_dataset_array[f]\n",
    "                else:\n",
    "                    c_and_f_not_num_sum_i[f]=float('inf')\n",
    "            c_and_f_not_num.append(np.array(c_and_f_not_num_sum_i))\n",
    "\n",
    "            c_and_f_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='1' ]))\n",
    "            c_and_f_not_num_sum.append(w*clients_dataset_array[j]/N_s+(1-w)*min([clients_dataset_array[j]/N_s]+[clients_dataset_array[f]/Not_N_s   for f in friends[str(j)] if row_ids[i][f]=='0' ]))\n",
    "            \n",
    "            # c_and_f_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='1' ]))\n",
    "            # c_and_f_not_num_sum.append(w*clients_dataset_array[j]+(1-w)*min([clients_dataset_array[j]]+[clients_dataset_array[f]   for f in friends[str(j)] if row_ids[i][f]=='0' ]))\n",
    "\n",
    "    # k=np.argmin(np.mean(f_in_c_num+f_not_in_c_num*(N_s)/(Not_N_s), axis=1))\n",
    "    \n",
    "    k1=np.argmin(np.array(c_and_f_num_sum))\n",
    "    k2=np.argmin(np.array(c_and_f_not_num_sum))\n",
    "\n",
    "    f1=np.argmin(c_and_f_num[k1])\n",
    "    f2=np.argmin(c_and_f_not_num[k2])\n",
    "    # k = np.argmin(np.mean(f_in_c_num, axis=1)+np.mean(f_not_in_c_num, axis=1))\n",
    "    \n",
    "    lambda1=(N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*((N_s*clients_dataset_array[l])+w*(N_s_2_sum-clients_dataset_array[c_in_s[k1]]**2+(N_s-clients_dataset_array[c_in_s[k1]])**2)+(1-w)*(N_s_2_sum-clients_dataset_array[f1]**2+(N_s-clients_dataset_array[f1])**2)))\n",
    "\n",
    "\n",
    "    lambda2=(N_s**2*Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*(Not_N_s**2*w*(N_s*clients_dataset_array[l]+(N_s_2_sum-clients_dataset_array[c_in_s[k2]]**2+(N_s-clients_dataset_array[c_in_s[k2]])**2))+N_s**2*(1-w)*(Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f2]**2+(Not_N_s-clients_dataset_array[f2])**2)))\n",
    "\n",
    "    \n",
    "    lambdas_cal.append(min(lambda1,lambda2))\n",
    "        \n",
    "lambda_cal= max(lambdas_cal) \n",
    "lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "#friends_list ={'0': [3], '1': [3], '2': [3], '3': [0,1,2]}\n",
    "q_list=np.arange(0,4,0.05).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "err_uniform, _, _, _,_ = calc_error_groups( n_list = clients_dataset_array)\n",
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "util_uniform_ACFG_min_FR=calc_unity_groups(err_uniform=err_uniform, n_list = clients_dataset_array, preference=\"min-FR\",friends =friends,w=w)\n",
    "for q in q_list:\n",
    "    _, _, _, err_fair,_ = calc_error_groups( n_list = clients_dataset_array,fair=True, err_list=err_list,q=q)\n",
    "    util_uniform_ACFG_min_FR_i=calc_unity_groups(err_uniform=err_fair, n_list = clients_dataset_array, preference=\"min-FR\",friends =friends,w=w)\n",
    "    \n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "\n",
    "    stable_result=check_stable(util_uniform_ACFG_min_FR,util_uniform_ACFG_min_FR_i,coalitions)\n",
    "    stable_list.append(stable_result!=None)\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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WFiY2ePOmTOHnj174urqCkDLli3x9vZm5cqVucYjHkyad0rSvRm9L74II0bAihXZNisGA3z6KSxfrq3j06GDRcIUxeteIkt+wCiuM2fOULVqVeNsTICaNWuSkZHB2bNncXd3N77+7xJ5Z86cQafT8e677xpfS09Px8vLi5iYGC5evMh3331n3DZ16lRefPFFfvrpJzp16sRTTz1F165d6dixY64x2trasmDBAvbs2YNOpzMm/9jYWB555BHjftWqVcv2vho1arB+/XqTx0xISCA6OprVq1ezfft24+tpaWkkJibmGo94MEn6luDpqSX2/v3hrbe0Gbz3O3VKG/M/cCBMmqS1GYu8+e47GDasZK/2PTxg1qw87/7II4/g4uLC2bNn8ff3L5IQzE3LX7RokdltHUxcVKxevZo9e/awevVqhg8fjr+/PzNmzDD7uSEhIURERPDDDz8Yl8KoV68eqqoW4FtkN2DAAF555ZVCH0dkJ0nfkp57Do4fh08/RZ02TVu7537z56OuXYsybRr06SMdvXnRsyd0716qO3JtbGzo06cPv/76K4MHD86xfciQIdSqVYu6devy/fffk5ycbLzav3z5MjY2Njk6Sv+tbt26ZGZmcvHiRWrXrm18fdy4cYwYMYJKlSrleM+RI0dwd3enXbt2tGvXjhdeeIGgoCDi4uKoVKkSiqIYk3lycjL29vbs37+fRx991JjwDQaDyXiuXr2a7XlkZGS2uO7n7OxMtWrVuHDhQrbX169fj42NDc8++2yu313kTtr0Lc3JCSZPRtm/H0yMTFBiYrShnZ07w7lzFgiwDLKxgapVS+5RgMWv3nnnHfR6PZMmTSI9q/ymqqqEhYVx5swZBg4cSNeuXfHw8DC2faelpbFkyRJ69OiRrWnHlMcee4wWLVowZ84cMrOWANmwYQPnz583mfABduzYwffff298np6eTqVKlaiY1QdVuXJl7ty5A8Dw4cM5f/48tWvX5tChQ8amqo0bN5o89uHDhzly5AgA586dIyIigsDAQLPxDxkyhB9//JHorLWrbt26xaxZs6hragi0yBdFLYr7sDImISGBVq1aceDAgdJVGD0jA775BvWTT1ASEnJsVvV6lLFjtRU+Ta31Y2VSUlK4cOECtWrVQq/XWzqcfEtNTeW7777jjz/+wM7ODoPBQJ06dRg2bJhx+dyLFy8y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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"fwa_f.svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 4. **Calculated egalitarian fairness bound** in Purely Equal Altruism v.s. **Obtained egalitarian fairness**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.2913714969000893"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)  \n",
    "    Not_N_s=N_g-N_s\n",
    "    Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "    # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "    # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "    # if  row_ids[i][f_opt]==\"1\":\n",
    "    #     N_s=np.sum(coalition)\n",
    "    #     N_s_2_sum=np.sum(coalition**2)\n",
    "    # else:\n",
    "    #     N_s=N_g-np.sum(coalition)\n",
    "    #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "    # k_list\n",
    "    f_in_c=[]\n",
    "    f_num=[]\n",
    "    f_all=[]\n",
    "    f_in_c=[]\n",
    "    f_not_in_c=[]\n",
    "    f_in_c_num=[]\n",
    "    f_not_in_c_num=[]\n",
    "    f_stat=[]\n",
    "    for j in range(len(row_ids[i])):\n",
    "        if row_ids[i][j]==\"1\":\n",
    "            f_stat.append([len(friends[str(j)])])\n",
    "            f_all.append(np.array([f  for f in friends[str(j)] ]))\n",
    "            f_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]]))\n",
    "            f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "            f_not_in_c.append(np.array([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ]))\n",
    "            f_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='1' else 0  for f in friends[str(j)] ]))\n",
    "            f_not_in_c_num.append(np.array([clients_dataset_array[f]  if row_ids[i][f]=='0' else 0 for f in friends[str(j)]] ))\n",
    "            # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "    f_stat=np.array(f_stat)\n",
    "    f_all=np.array(f_all)\n",
    "    f_num=np.array(f_num)\n",
    "    f_in_c=np.array(f_in_c)\n",
    "    f_not_in_c=np.array(f_not_in_c)\n",
    "    f_in_c_num=np.array(f_in_c_num)\n",
    "    f_not_in_c_num=np.array(f_not_in_c_num)\n",
    "    # k=np.argmin(np.mean(f_in_c_num+f_not_in_c_num*(N_s)/(Not_N_s), axis=1))\n",
    "    k=np.argmin(np.sum(f_in_c_num/N_s+f_not_in_c_num/Not_N_s,axis=1).reshape(-1,1)/f_stat.reshape(-1,1))\n",
    "    \n",
    "    # k = np.argmin(np.mean(f_in_c_num, axis=1)+np.mean(f_not_in_c_num, axis=1))\n",
    "    \n",
    "   \n",
    "\n",
    "    f_k_num=len(f_all[k].tolist())\n",
    "    sum_c_in_s=sum([N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f]**2+(N_s-clients_dataset_array[f])**2 for f in f_in_c[k].tolist()  if f!=None])\n",
    "    sum_c_not_in_s=sum([Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f]**2+(Not_N_s-clients_dataset_array[f])**2 for f in f_not_in_c[k].tolist() if f!=None ])\n",
    "    \n",
    "    lambda1=f_k_num*(N_s**2)*(Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*((Not_N_s**2)*sum_c_in_s+(N_s**2)*sum_c_not_in_s))\n",
    "    \n",
    "    lambdas_cal.append(lambda1)\n",
    "        \n",
    "lambda_cal= max(lambdas_cal) \n",
    "lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "#friends_list ={'0': [3], '1': [3], '2': [3], '3': [0,1,2]}\n",
    "q_list=np.arange(0,4,0.05).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "err_uniform, _, _, _,_ = calc_error_groups( n_list = clients_dataset_array)\n",
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "util_uniform_ACFG_min_FR=calc_unity_groups(err_uniform=err_uniform, n_list = clients_dataset_array, preference=\"mean-PA\",friends=friends)\n",
    "for q in q_list:\n",
    "    _, _, _, err_fair,_ = calc_error_groups( n_list = clients_dataset_array,fair=True, err_list=err_list,q=q)\n",
    "    util_uniform_ACFG_min_FR_i=calc_unity_groups(err_uniform=err_fair, n_list = clients_dataset_array, preference=\"mean-PA\",friends=friends)\n",
    "    \n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "\n",
    "    stable_result=check_stable(util_uniform_ACFG_min_FR,util_uniform_ACFG_min_FR_i,coalitions)\n",
    "    stable_list.append(stable_result!=None)\n",
    "    \n",
    "\n",
    "    # if stable_result!=None:\n",
    "    #     print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "# fair_condition.append(len(fair_condition))\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"pea_f.svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 5. **Calculated egalitarian fairness bound** in Friendly Equal Altruism v.s. **Obtained egalitarian fairness**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.220784309141039"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)  \n",
    "    Not_N_s=N_g-N_s\n",
    "    Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "    # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "    # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "    # if  row_ids[i][f_opt]==\"1\":\n",
    "    #     N_s=np.sum(coalition)\n",
    "    #     N_s_2_sum=np.sum(coalition**2)\n",
    "    # else:\n",
    "    #     N_s=N_g-np.sum(coalition)\n",
    "    #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "    # k_list\n",
    "    c_in_s=[]\n",
    "    f_in_c=[]\n",
    "    f_num=[]\n",
    "    f_all=[]\n",
    "    f_in_c=[]\n",
    "    f_not_in_c=[]\n",
    "    f_in_c_num=[]\n",
    "    f_not_in_c_num=[]\n",
    "    f_stat=[]\n",
    "    for j in range(len(row_ids[i])):\n",
    "        \n",
    "        if row_ids[i][j]==\"1\":\n",
    "            c_in_s.append(np.array([clients_dataset_num[j]]))\n",
    "            f_all.append([f for f in friends[str(j)] ])\n",
    "            f_stat.append([len(friends[str(j)])])\n",
    "            f_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]]))\n",
    "            f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "            f_not_in_c.append(np.array([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ]))\n",
    "            f_in_c_num.append(np.array(sum([clients_dataset_array[f] if row_ids[i][f]=='1' else 0  for f in friends[str(j)] ])))\n",
    "            \n",
    "            f_not_in_c_num.append(np.array(sum([clients_dataset_array[f]  if row_ids[i][f]=='0' else 0 for f in friends[str(j)]]) ))\n",
    "\n",
    "            # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "           \n",
    "    c_in_s=np.array(c_in_s)\n",
    "    f_stat=np.array(f_stat)\n",
    "\n",
    "    f_in_c_num=np.array(f_in_c_num)\n",
    "    f_not_in_c_num=np.array(f_not_in_c_num)\n",
    "    # k=np.argmin(np.mean(f_in_c_num+f_not_in_c_num*(N_s)/(Not_N_s), axis=1))\n",
    "    # k=np.argmin(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1).reshape(-1,1))/N_s+np.sum(f_not_in_c_num,axis=1).reshape(-1,1)/Not_N_s)/(f_stat+1))\n",
    "\n",
    "    k=np.argmin(w*c_in_s/N_s+(1-w)*((c_in_s+f_in_c_num.reshape(-1,1))/N_s+f_not_in_c_num.reshape(-1,1)/Not_N_s)/(f_stat+1))\n",
    "    # print(k)\n",
    "    # k=np.argmin(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1))/N_s+np.sum(f_not_in_c_num,axis=1)/Not_N_s)/(f_stat+1))\n",
    "    # print(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1))/N_s+np.sum(f_not_in_c_num,axis=1)/Not_N_s)/(f_stat+1))\n",
    "    # k=np.argmin(np.mean(f_in_c_num/N_s+f_not_in_c_num/Not_N_s, axis=1))\n",
    "    # k = np.argmin(np.mean(f_in_c_num, axis=1)+np.mean(f_not_in_c_num, axis=1))\n",
    "    \n",
    "    f_k_num=len(f_all[k])\n",
    "    sum_c_in_s=sum([N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f]**2+(N_s-clients_dataset_array[f])**2 for f in f_in_c[k]  if f!=None])+(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2)\n",
    "    sum_c_not_in_s=sum([Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f]**2+(Not_N_s-clients_dataset_array[f])**2 for f in f_not_in_c[k] if f!=None ])\n",
    "    \n",
    "    lambda1=(f_k_num+1)*(N_s**2)*(Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*(w*(f_k_num+1)*(Not_N_s**2)*(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2)+(1-w)*(Not_N_s**2*sum_c_in_s+N_s**2*sum_c_not_in_s) ))\n",
    "    \n",
    "    lambda2=(N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2))\n",
    "    lambdas_cal.append(lambda1)\n",
    "lambda_cal= max(lambdas_cal) \n",
    "lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [],
   "source": [
    "# clients_dataset_array = np.array(clients_dataset_num)\n",
    "# coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "# m = np.argmin(clients_dataset_array)\n",
    "# l=np.argmax(clients_dataset_array)\n",
    "# N_g=np.sum(clients_dataset_array)\n",
    "# N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "# lambdas_cal=[]\n",
    "# friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "# friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "# for i,coalition in enumerate(coalitions_except_grand):\n",
    "#     if row_ids[i]==\"10001\":\n",
    "#             print()\n",
    "#     N_s=np.sum(coalition)\n",
    "#     N_s_2_sum=np.sum(coalition**2)  \n",
    "#     Not_N_s=N_g-N_s\n",
    "#     Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "#     # k=np.argmin(np.min(friends_num_array, axis=1))\n",
    "#     # f_opt=friends_array[k,np.argmin(friends_num_array[k])]  \n",
    "\n",
    "#     # if  row_ids[i][f_opt]==\"1\":\n",
    "#     #     N_s=np.sum(coalition)\n",
    "#     #     N_s_2_sum=np.sum(coalition**2)\n",
    "#     # else:\n",
    "#     #     N_s=N_g-np.sum(coalition)\n",
    "#     #     N_s_2_sum=N_g_2_sum-np.sum(coalition**2)\n",
    "#     # k_list\n",
    "#     c_in_s=[]\n",
    "#     f_in_c=[]\n",
    "#     f_num=[]\n",
    "#     f_all=[]\n",
    "#     f_in_c=[]\n",
    "#     f_not_in_c=[]\n",
    "#     f_in_c_num=[]\n",
    "#     f_not_in_c_num=[]\n",
    "#     f_stat=[]\n",
    "#     for j in range(len(row_ids[i])):\n",
    "        \n",
    "#         if row_ids[i][j]==\"1\":\n",
    "#             c_in_s.append(np.array([clients_dataset_num[j]]))\n",
    "#             f_all.append(np.array([f  for f in friends[str(j)] ]))\n",
    "#             f_stat.append([len(friends[str(j)])])\n",
    "#             f_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]]))\n",
    "#             f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "#             f_not_in_c.append(np.array([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ]))\n",
    "#             f_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='1' else 0  for f in friends[str(j)] ]))\n",
    "#             f_not_in_c_num.append(np.array([clients_dataset_array[f]  if row_ids[i][f]=='0' else 0 for f in friends[str(j)]] ))\n",
    "#             # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "#     c_in_s=np.array(c_in_s)\n",
    "#     f_stat=np.array(f_stat)\n",
    "#     f_all=np.array(f_all)\n",
    "#     f_num=np.array(f_num)\n",
    "#     f_in_c=np.array(f_in_c)\n",
    "#     f_not_in_c=np.array(f_not_in_c)\n",
    "#     f_in_c_num=np.array(f_in_c_num)\n",
    "#     f_not_in_c_num=np.array(f_not_in_c_num)\n",
    "#     t=f_not_in_c_num*(N_s)/(Not_N_s)\n",
    "#     # k=np.argmin(np.mean(f_in_c_num+f_not_in_c_num*(N_s)/(Not_N_s), axis=1))\n",
    "#     # k=np.argmin(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1).reshape(-1,1))/N_s+np.sum(f_not_in_c_num,axis=1).reshape(-1,1)/Not_N_s)/(f_stat+1))\n",
    "#     if row_ids[i]==\"11110\":\n",
    "#         ttt=w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1).reshape(-1,1))/N_s+np.sum(f_not_in_c_num,axis=1).reshape(-1,1)/Not_N_s)/(f_stat+1)\n",
    "#         k=np.argmax(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1).reshape(-1,1))/N_s+np.sum(f_not_in_c_num,axis=1).reshape(-1,1)/Not_N_s)/(f_stat+1))\n",
    "#     # k=np.argmin(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1))/N_s+np.sum(f_not_in_c_num,axis=1)/Not_N_s)/(f_stat+1))\n",
    "#     # print(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1))/N_s+np.sum(f_not_in_c_num,axis=1)/Not_N_s)/(f_stat+1))\n",
    "#     # k=np.argmin(np.mean(f_in_c_num/N_s+f_not_in_c_num/Not_N_s, axis=1))\n",
    "#     # k = np.argmin(np.mean(f_in_c_num, axis=1)+np.mean(f_not_in_c_num, axis=1))\n",
    "    \n",
    "   \n",
    "\n",
    "#         f_k_num=len(f_all[k].tolist())\n",
    "#         sum_c_in_s=sum([N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f]**2+(N_s-clients_dataset_array[f])**2 for f in f_in_c[k].tolist()  if f!=None])+(N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[k]**2+(N_s-clients_dataset_array[k])**2)\n",
    "#         sum_c_not_in_s=sum([Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f]**2+(Not_N_s-clients_dataset_array[f])**2 for f in f_not_in_c[k].tolist() if f!=None ])\n",
    "        \n",
    "#         lambda1=(f_k_num+1)*(N_s**2)*(Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*(w*(f_k_num+1)*(Not_N_s**2)*(N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[k]**2+(N_s-clients_dataset_array[k])**2)+(1-w)*(Not_N_s**2*sum_c_in_s+N_s**2*sum_c_not_in_s) ))\n",
    "        \n",
    "#         lambdas_cal.append(lambda1)\n",
    "# print(lambdas_cal)\n",
    "# lambda_cal= max(lambdas_cal) \n",
    "# lambda_cal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [],
   "source": [
    "#friends_list ={'0': [3], '1': [3], '2': [3], '3': [0,1,2]}\n",
    "\n",
    "q_list=np.arange(0,4,0.05).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "err_uniform, _, _, _,_ = calc_error_groups( n_list = clients_dataset_array)\n",
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "util_uniform_ACFG_min_FR=calc_unity_groups(err_uniform=err_uniform, n_list = clients_dataset_array, preference=\"mean-FR\",friends=friends,w=w)\n",
    "for q in q_list:\n",
    "    _, _, _, err_fair,_ = calc_error_groups( n_list = clients_dataset_array,fair=True, err_list=err_list,q=q)\n",
    "    util_uniform_ACFG_min_FR_i=calc_unity_groups(err_uniform=err_fair, n_list = clients_dataset_array, preference=\"mean-FR\",friends=friends,w=w)\n",
    "    \n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "\n",
    "    stable_result=check_stable(util_uniform_ACFG_min_FR,util_uniform_ACFG_min_FR_i,coalitions)\n",
    "    stable_list.append(stable_result!=None)\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"fea_f.svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Test 6. **Calculated egalitarian fairness bound**  v.s. **Obtained egalitarian fairness** under multi-preferences"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Case 1: 2 Selfish+3 Friendly Equal Altrusim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "C=[2,3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.614512471655329"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# selfish lambda\n",
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    coalition_group=[]\n",
    "    for j, is_exist in enumerate(row_ids[i]) :\n",
    "        index_k=0\n",
    "        if is_exist==\"1\" :\n",
    "            if   j in C:\n",
    "                coalition_group.append(coalition.tolist()[index_k])\n",
    "            index_k+=1\n",
    "    if len(coalition_group)!=0:\n",
    "        coalition_group=np.array(coalition_group)\n",
    "        k = np.argmin(coalition_group)\n",
    "        N_s=np.sum(coalition)\n",
    "        N_s_2_sum=np.sum(coalition**2)\n",
    "        lambdas_cal.append(max((N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-coalition_group[k]**2+(N_s-coalition_group[k])**2)),1))\n",
    "    \n",
    "lambda_cal_selfish= max(lambdas_cal)\n",
    "lambda_cal_selfish"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [],
   "source": [
    "C2=[item for item in list(range(len(clients_dataset_num))) if item not in C]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0105056721598076"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "clients_dataset_array = np.array(clients_dataset_num)\n",
    "coalitions_except_grand=get_coalitions(clients_dataset_array,row_ids[:-1])\n",
    "\n",
    "m = np.argmin(clients_dataset_array)\n",
    "l=np.argmax(clients_dataset_array)\n",
    "N_g=np.sum(clients_dataset_array)\n",
    "N_g_2_sum=np.sum(clients_dataset_array**2)\n",
    "lambdas_cal=[]\n",
    "friends_array=np.array([np.array(friends[str(i)]) for i in range(clients_dataset_array.shape[0])])\n",
    "friends_num_array=np.array([np.array([clients_dataset_array[f] for f in friends[str(i)]]) for i in range(clients_dataset_array.shape[0])])\n",
    "\n",
    "for i,coalition in enumerate(coalitions_except_grand):\n",
    "    N_s=np.sum(coalition)\n",
    "    N_s_2_sum=np.sum(coalition**2)  \n",
    "    Not_N_s=N_g-N_s\n",
    "    Not_N_s_2_sum=N_g_2_sum-N_s_2_sum\n",
    "    c_in_s=[]\n",
    "    c_in_s_index=[]\n",
    "    f_in_c=[]\n",
    "    f_num=[]\n",
    "    f_all=[]\n",
    "    f_in_c=[]\n",
    "    f_not_in_c=[]\n",
    "    f_in_c_num=[]\n",
    "    f_not_in_c_num=[]\n",
    "    f_stat=[]\n",
    "    for j in range(len(row_ids[i])):  \n",
    "        if row_ids[i][j]==\"1\":\n",
    "            c_in_s_index.append(j)\n",
    "            c_in_s.append(np.array([clients_dataset_num[j]]))\n",
    "            f_all.append(np.array([f  for f in friends[str(j)] ]))\n",
    "            f_stat.append([len(friends[str(j)])])\n",
    "            f_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]]))\n",
    "            f_in_c.append(np.array([f  if row_ids[i][f]==\"1\" else None for f in friends[str(j)] ]))\n",
    "            f_not_in_c.append(np.array([f  if row_ids[i][f]==\"0\" else None for f in friends[str(j)] ]))\n",
    "            f_in_c_num.append(np.array([clients_dataset_array[f] if row_ids[i][f]=='1' else 0  for f in friends[str(j)] ]))\n",
    "            f_not_in_c_num.append(np.array([clients_dataset_array[f]  if row_ids[i][f]=='0' else 0 for f in friends[str(j)]] ))\n",
    "            # f_in_c_num.append(np.array([clients_dataset_array[f]  for f in friends[str(j)]])\n",
    "    c_in_s=np.array(c_in_s)\n",
    "    f_stat=np.array(f_stat)\n",
    "    f_all=np.array(f_all)\n",
    "    f_num=np.array(f_num)\n",
    "    f_in_c=np.array(f_in_c)\n",
    "    f_not_in_c=np.array(f_not_in_c)\n",
    "    f_in_c_num=np.array(f_in_c_num)\n",
    "    f_not_in_c_num=np.array(f_not_in_c_num)\n",
    "    t=f_not_in_c_num*(N_s)/(Not_N_s)\n",
    "    \n",
    "    # k_common_index=[client for client in c_in_s_index if client in C2]\n",
    "    common_index=[client for client in range(len(c_in_s_index)) if c_in_s_index[client] in C2]\n",
    "    \n",
    "    if len(common_index)!=0:\n",
    "        k_cal=(w*c_in_s/N_s+(1-w)*((c_in_s+np.sum(f_in_c_num,axis=1).reshape(-1,1))/N_s+np.sum(f_not_in_c_num,axis=1).reshape(-1,1)/Not_N_s)/(f_stat+1))[common_index]\n",
    "\n",
    "        k=common_index[np.argmin(k_cal)]\n",
    "\n",
    "        f_k_num=len(f_all[k].tolist())\n",
    "        sum_c_in_s=sum([N_s*clients_dataset_array[l]+N_s_2_sum-clients_dataset_array[f]**2+(N_s-clients_dataset_array[f])**2 for f in f_in_c[k].tolist()  if f!=None])+(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2)\n",
    "        sum_c_not_in_s=sum([Not_N_s*clients_dataset_array[l]+Not_N_s_2_sum-clients_dataset_array[f]**2+(Not_N_s-clients_dataset_array[f])**2 for f in f_not_in_c[k].tolist() if f!=None ])\n",
    "        \n",
    "        lambda1=(f_k_num+1)*(N_s**2)*(Not_N_s**2)*(N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/((N_g**2)*(w*(f_k_num+1)*(Not_N_s**2)*(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2)+(1-w)*(Not_N_s**2*sum_c_in_s+N_s**2*sum_c_not_in_s) ))\n",
    "        \n",
    "        lambda2=(N_s**2/N_g**2)*((N_g*clients_dataset_array[l]+N_g_2_sum-clients_dataset_array[m]**2+(N_g-clients_dataset_array[m])**2)/(N_s*clients_dataset_array[l]+N_s_2_sum-coalition[k]**2+(N_s-coalition[k])**2))\n",
    "        lambdas_cal.append(lambda1)\n",
    "lambda_cal_fea= max(lambdas_cal) \n",
    "lambda_cal_fea"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "lambda_cal=max(lambda_cal_selfish,lambda_cal_fea)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [],
   "source": [
    "q_list=np.arange(0,4,0.05).tolist()\n",
    "lambda_list=[]\n",
    "stable_list=[]\n",
    "\n",
    "coalitions = generate_combinations(row_ids)\n",
    "err_uniform, _, _, _,_ = calc_error_groups( n_list = clients_dataset_array)\n",
    "err_list = err_uniform.iloc[-1].tolist()\n",
    "util_uniform_ACFG_min_FR=calc_unity_groups(err_uniform=err_uniform, n_list = clients_dataset_array, preference=\"mean-FR\",friends=friends,client_pre=C2,w=w)\n",
    "for q in q_list:\n",
    "    _, _, _, err_fair,_ = calc_error_groups( n_list = clients_dataset_array,fair=True, err_list=err_list,q=q)\n",
    "    util_uniform_ACFG_min_FR_i=calc_unity_groups(err_uniform=err_fair, n_list = clients_dataset_array, preference=\"mean-FR\",friends=friends,client_pre=C2,w=w)\n",
    "    \n",
    "    err_fair_last_row=err_fair.iloc[-1]\n",
    "    lambda_list.append(err_list[0]/err_fair_last_row[-1])\n",
    "\n",
    "    stable_result=check_stable(util_uniform_ACFG_min_FR,util_uniform_ACFG_min_FR_i,coalitions)\n",
    "    stable_list.append(stable_result!=None)\n",
    "    \n",
    "    # if stable_result!=None:\n",
    "    #     print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['font.family'] = 'serif'\n",
    "# plt.rcParams['font.family'] = 'serif'\n",
    "# plt.rcParams['font.serif'] = ['Times']\n",
    "fig, ax = plt.subplots(figsize=(4,2))\n",
    "\n",
    "ax.plot(q_list, lambda_list)\n",
    "\n",
    "fair_condition = [index for index, element in enumerate(stable_list) if element == False]\n",
    "ax.plot([q_list[i] for i in fair_condition] , [lambda_list[i] for i in fair_condition], color='red', linewidth=3, label='Core-stable')        \n",
    "ax.axhline(y=lambda_cal, linewidth=3,color='green', linestyle='--',label='Calculated $\\lambda$ bound')\n",
    "plt.xlabel('p')\n",
    "plt.ylabel('$\\lambda$')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"2_3_s_f.svg\")\n",
    "plt.show()"
   ]
  }
 ],
 "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.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
