{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Joint Shapley value calculations on the Boston housing dataset (Harrison and Rubinfeld, 1978, JEEM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "#import xgboost\n",
    "import shap\n",
    "import sklearn\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import random\n",
    "from IPython.display import display, clear_output\n",
    "\n",
    "import seaborn as sns\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import copy\n",
    "sns.set_theme(style=\"whitegrid\")\n",
    "\n",
    "EMPTY = frozenset()\n",
    "\n",
    "# from joint_shapley import * # Where most of the JS code is "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_powerset_to_k(\n",
    "    features, \n",
    "    k,\n",
    "    init=True,\n",
    "):\n",
    "    if init:\n",
    "        features = [s if type(s) == frozenset else frozenset([s]) for s in features]\n",
    "    if len(features) <= 1:\n",
    "        yield features[0]\n",
    "        yield frozenset()\n",
    "    else:\n",
    "        for item in get_powerset_to_k(features[1:], k, False):\n",
    "            if len(item) <= k - 1:\n",
    "                yield features[0].union(item)\n",
    "            yield item\n",
    "            \n",
    "def get_powerset_to_k_ex_emptyset(seq, k):\n",
    "    gen = get_powerset_to_k(seq, k)\n",
    "    for item in gen:\n",
    "        if item != frozenset():\n",
    "            yield item"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[frozenset({'c', 'd'}),\n",
       " frozenset({'b', 'd'}),\n",
       " frozenset({'a', 'd'}),\n",
       " frozenset({'d'}),\n",
       " frozenset({'b', 'c'}),\n",
       " frozenset({'a', 'c'}),\n",
       " frozenset({'c'}),\n",
       " frozenset({'a', 'b'}),\n",
       " frozenset({'b'}),\n",
       " frozenset({'a'}),\n",
       " frozenset()]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t = get_powerset_to_k([\"a\", \"b\", \"c\", \"d\"], 2)\n",
    "list(t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset has 13 features and 506 observations\n"
     ]
    }
   ],
   "source": [
    "dataset_pathname = \"boston\"\n",
    "X,y = shap.datasets.boston()\n",
    "col_rename = {l: f\"{l}\" for l in X.columns}\n",
    "X = X.rename(columns=col_rename)\n",
    "y = y\n",
    "x_labels = [f\"{l}\" for l in X.columns]\n",
    "n = len(x_labels)\n",
    "print(f\"Dataset has {n} features and {len(y)} observations\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Split train/test\n",
    "np.random.seed(0)\n",
    "test_train_split = np.random.uniform(0, 1, len(y)) <= .75\n",
    "train_X = X[test_train_split]\n",
    "train_y = y[test_train_split]\n",
    "test_X = X[~test_train_split]\n",
    "test_y = y[~test_train_split]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HY/boeAl+aJMmTIMGTKEF198kWeffZann34af39/+vTpQ0xMDAAffvgh48ePp3Xr1ly9epUXX3zRylVnd6s+fHx8ePvttxkwYACtW7fGZDLRs2dPa5d92+zteOTG3o7H3LlzSU5OZsKECZaP9H/++ed2dzxu1Ye9HI+mTZvSrFkznn32WTp06ECdOnVo27at3R0PuHUv9nJMcmKPx+N26CuDRERERAyiM14iIiIiBlHwEhERETGIgpeIiIiIQRS8RERERAyi4CUiIiJiEAUvERErGTBggOVmly1atODYsWMApKWlMWnSJFq0aEFgYCBNmjRhzJgxJCQkWLb18/Pjjz/+yLbPBg0asH379izrli9fjp+fH998802W9ceOHcPPz486depYHvXq1SMsLCxfv5Jl1apVtG/f/p73M23aNKZNmwZAVFQU4eHh97xPEaMpeImIWMHatWvx9vbGz88v29iMGTPYvn07ixcvZvfu3axYsYKTJ08ycuTIu3qtZcuW0bFjR5YsWZLj+P/93/+xa9cudu3axc8//4y7uzuDBw++q9cySnBwMJcvX2bLli3WLkXkjih4ich95dixYzRo0ID58+cTEhJCgwYNWL58OZ988gkNGzbk0UcfZc2aNZb5O3bsoEOHDgQHB9OpUyf27t1rGfvll1/o3LkzDRs2pG7dugwePJikpCQAunfvzscff0xoaCh169alW7duljNaJpOJGTNm8MILL+RYY0xMDI0aNaJ8+fKA+ca+4eHhWb78+Hb9/vvvHDlyhPDwcOLi4vj999/znO/p6ckzzzyT49m0YcOG8f7771uWr169SmBgIPHx8Vy4cIFhw4bRokULAgICaNeuneVO4ze6+exXYmIifn5+lp9NXFwc3bt3Jzg4mHbt2uX5vYL//ve/mT59+i1/BiK2RMFLRO47Fy9e5Pjx4/z8888MGzaMsWPHcv78eTZv3sygQYN49913AfP33PXr148BAwawbds2evXqRZ8+fbh48SJXr14lLCyMPn36sG3bNtavX09sbCxr1661vM66deuIiIhg06ZNmEwmZs+eDcDOnTu5evUq/v7+Odb31FNPMWfOHMLDw1m3bh2nTp2iSpUqvPXWW1nmde7cmeDg4CyPGy9HAixdupRnn32WwoULExoamutZr+vOnDnDF198QYMGDbKNhYaG8u2333L9vtvfffcdVatWpWrVqkycOBEwf+/ejh07CAoK4qOPPsrztW525coVXnrpJVq3bs22bdsYPXo0w4cP56+//spxfqNGjThw4ECu4yK2SMFLRO5LPXv2xM3NjYYNG5Kenm5ZbtKkCRcvXiQpKYm1a9fSoEEDnnjiCVxdXXnqqaeoUaMGGzZswMPDgy+//JLHH3+cy5cvc+bMGby9vbO8N+qZZ56hYsWKFClShJYtW3Lo0CHA/P6k3EIXQPv27Zk9ezbJycm8++67NG3alGeeeYZffvkly7wvvviCqKioLI9ixYpZxq9du8batWv597//DZiD2tq1a7OFs6ZNmxIcHExQUBAdOnTAy8vLEj5v9Oijj5KamsrOnTsB8+XS0NBQAIYMGcJbb72Fi4sLJ06coGjRonf8PrFNmzbh4+ND165dcXV1tfzsv/zyyxznu7q6UrNmTXbs2HFHryNiTbb1FeUiIga5HlCcnc3//1mkSBEAnJycAMjIyODEiRNs3ryZ4OBgy3ZpaWkEBQXh4uLCjz/+yMKFCwHzm92TkpK48VvYfHx8LM9dXV0tY6dOnaJUqVJ51hcSEkJISAgA8fHxfP755/Tr14/vv/+e0qVL31aP69ev5/Lly1m+1+7atWusWLGCl156ybJu06ZNeHl53XJ/Li4utGvXjvXr11O5cmV+/fVXJkyYAJjPlI0bN474+HgqV66Mt7c3d/qNdCdOnCA+Pj7Lzzs9PT3PL3UuVaoUp06duqPXEbEmBS8RuS9dD1h5KVWqFG3atOGDDz6wrDt69CjFixdn586dTJ8+neXLl1OpUiWA2/7iXicnJzIyMnIcS09Pp0GDBkydOpVGjRoBULVqVV5//XVWr17Nn3/+edvBa9myZQwfPtxyVgrMYWzRokV3/UXJoaGh9O7dm2rVqtGwYUNKlCgBwNChQ3n++eeJjIzEycmJ1atX5/g+MWdnZ1JTUy3LFy9etDwvVaoUgYGBREZGWtadOnUKDw+PXOtJS0uzhGcRe6B/rSIiuWjbti0//fQTv/zyCyaTiejoaJ555hliYmK4cuUKzs7OPPDAA6Snp7N69WqioqJIS0u75X59fX05e/ZsjmMuLi60bNmS999/n71792Iymbh06RKLFi3igQce4JFHHrmt2g8cOEBMTAzt27enVKlSlkf79u05e/Ys//vf/+7kR2FRs2ZNfHx8+OSTT7IEuitXruDp6YmTkxPx8fF8+umnWQLWdZUrV+avv/5iz549JCcnM3v2bEsIbtasGX/++Sdr164lPT2d+Ph4OnXqxPfff59rPWfPnqVs2bJ31YuINSh4iYjkolKlSkyePJmJEycSFBTEyJEjCQ8PJyQkhMaNG9O6dWvatWtHo0aNWLNmDc899xzx8fG33G9ISAi7d+/Odfytt97i8ccfZ8SIEdStW5cWLVqwfft2Fi1adFuXBMH8pvqGDRtmudwJ5kuqTzzxRJazSnfq2Wef5fLly7Ro0cKy7u2332bu3LnUrVuXsLAwnnvuOS5cuMCFCxeybBsQEED37t0ZMGAALVq0oFKlSpbLvt7e3syZM4fPP/+cBg0a0LNnT1544QU6deqUYx2pqans37/fcklWxB44me70IryIiNyzNm3a8N577xEYGAiYb6C6aNEiKlSoYN3CbNj1m6e+/PLLAPz000/MmTPnnkKkiNF0xktExAoGDRqkwHCPPvvsMwYNGmTtMkTuiIKXiIgVtG3blsuXL9/yhqaSs6ioKIoXL275AIKIvdClRhERERGD6IyXiIiIiEEUvEREREQMouAlIiIiYhAFLxERERGDKHiJiIiIGETBS0RERMQg/w9N1v0cZf5QpwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 576x468 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = sklearn.ensemble.RandomForestRegressor(\n",
    "    n_jobs=10, n_estimators=50,random_state=0\n",
    ").fit(train_X, train_y)\n",
    "\n",
    "y_predicted = model.predict(test_X)\n",
    "explainer = shap.Explainer(model)\n",
    "shap_values = explainer(test_X)\n",
    "shap.plots.bar(shap_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_features = frozenset(x_labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Define value function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "coalitions_to_k = get_powerset_to_k(n_features, k)\n",
    "\n",
    "baseline = explainer(test_X).base_values\n",
    "\n",
    "def value_function(cln_X):\n",
    "#     full_X = test_X.copy()\n",
    "#     full_X.loc[:, [col not in cln_X.columns for col in X.columns]] = \\\n",
    "#         full_X.mean(axis=0).loc[[col not in cln_X.columns for col in X.columns]].values.T\n",
    "#     full_X.loc[:, cln_X.columns] = cln_X\n",
    "    return model.predict(cln_X)# - baseline[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_coalition_arrivals(t_cln, x_labels):\n",
    "    clns_arrived = []\n",
    "    arrived_features = frozenset()\n",
    "    all_features = frozenset(x_labels)\n",
    "    clns_up_to_t, clns_up_to_incl_t = None, None\n",
    "    while(len(arrived_features) < len(all_features)):\n",
    "        to_arrive = all_features.difference(arrived_features)\n",
    "        possible_next = list(get_powerset_to_k_ex_emptyset(to_arrive, k))\n",
    "        arrives_now_cln = random.choice(possible_next)\n",
    "        if arrives_now_cln == t_cln:\n",
    "            clns_up_to_t = copy.deepcopy(clns_arrived)\n",
    "            clns_up_to_incl_t = copy.deepcopy(clns_arrived) + [arrives_now_cln]\n",
    "        clns_arrived.append(arrives_now_cln)\n",
    "        arrived_features = arrived_features.union(arrives_now_cln)\n",
    "    return clns_up_to_t, clns_up_to_incl_t, clns_arrived"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_estimate_for_coalition(\n",
    "    t_cln, \n",
    "    num_iterations: int,\n",
    "    X: pd.DataFrame,\n",
    "    value_f,\n",
    ") -> float:\n",
    "    x_labels = list(X.columns)\n",
    "    estimates = []\n",
    "    for itr in range(0, num_iterations):\n",
    "        rand_seq = random.sample(list(X.index), len(X.index))\n",
    "        Z = X.loc[rand_seq]\n",
    "        clns_up_to_t, clns_up_to_incl_t, clns_arrived = get_coalition_arrivals(t_cln, x_labels)\n",
    "\n",
    "        features_arrived = [ft for cln in clns_arrived for ft in cln]\n",
    "\n",
    "        if t_cln in clns_arrived:\n",
    "            features_up_to_t = [ft for cln in clns_up_to_t for ft in cln]\n",
    "            inv_features_up_to_t = [ft for ft in X.columns if ft not in features_up_to_t]\n",
    "            features_up_to_incl_t = [ft for cln in clns_up_to_incl_t for ft in cln]\n",
    "            inv_features_up_to_incl_t = [ft for ft in X.columns if ft not in features_up_to_incl_t]\n",
    "            X_plus_t = pd.concat([\n",
    "                X.loc[:, features_up_to_incl_t].reset_index(drop=True).astype(np.float64), \n",
    "                Z.loc[:, inv_features_up_to_incl_t].reset_index(drop=True).astype(np.float64)\n",
    "            ], axis=1).loc[:, X.columns]\n",
    "            X_minus_t = pd.concat([\n",
    "                X.loc[:, features_up_to_t].reset_index(drop=True).astype(np.float64), \n",
    "                Z.loc[:, inv_features_up_to_t].reset_index(drop=True).astype(np.float64)\n",
    "            ], axis=1).loc[:, X.columns]\n",
    "            estimates = estimates + [\n",
    "                (value_f(X_plus_t)) - \n",
    "                (value_f(X_minus_t))\n",
    "            ]\n",
    "        else:\n",
    "            estimates = estimates + [np.full(len(X), 0.0)]\n",
    "\n",
    "    combined_estimates = np.vstack(estimates)\n",
    "    return combined_estimates.mean(axis=0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 09/08/21\n",
    "def get_estimate_for_coalition_fix(\n",
    "    t_cln, \n",
    "    num_iterations: int,\n",
    "    X: pd.DataFrame,\n",
    "    value_f,\n",
    ") -> float:\n",
    "    x_labels = list(X.columns)\n",
    "    estimates = []\n",
    "    for itr in range(0, num_iterations):\n",
    "        rand_seq = random.sample(list(X.index), len(X.index))\n",
    "        Z = X.loc[rand_seq]\n",
    "        clns_up_to_t, clns_up_to_incl_t, clns_arrived = get_coalition_arrivals(t_cln, x_labels)\n",
    "\n",
    "        features_arrived = [ft for cln in clns_arrived for ft in cln]\n",
    "\n",
    "        if t_cln in clns_arrived:\n",
    "            features_up_to_t = [ft for cln in clns_up_to_t for ft in cln]\n",
    "            inv_features_up_to_t = [ft for ft in X.columns if ft not in features_up_to_t]\n",
    "            features_up_to_incl_t = [ft for cln in clns_up_to_incl_t for ft in cln]\n",
    "            inv_features_up_to_incl_t = [ft for ft in X.columns if ft not in features_up_to_incl_t]\n",
    "            X_plus_t = pd.concat([\n",
    "                X.loc[:, features_up_to_incl_t].reset_index(drop=True).astype(np.float64), \n",
    "                Z.loc[:, inv_features_up_to_incl_t].reset_index(drop=True).astype(np.float64)\n",
    "            ], axis=1).loc[:, X.columns]\n",
    "            X_minus_t = pd.concat([\n",
    "                X.loc[:, features_up_to_t].reset_index(drop=True).astype(np.float64), \n",
    "                Z.loc[:, inv_features_up_to_t].reset_index(drop=True).astype(np.float64)\n",
    "            ], axis=1).loc[:, X.columns]\n",
    "            estimates = estimates + [\n",
    "                (value_f(X_plus_t)) - \n",
    "                (value_f(X_minus_t))\n",
    "            ]\n",
    "        else:\n",
    "            estimates = estimates + [np.full(len(X), 0.0)]\n",
    "\n",
    "    combined_estimates = np.vstack(estimates)\n",
    "    return combined_estimates.mean(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Processing iter = 690'"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Test for a given t and x\n",
    "t_cln = frozenset([\"LSTAT\", \"AGE\"])\n",
    "results = {}\n",
    "for iters in range(10, 700, 10):\n",
    "    clear_output(wait=True)\n",
    "    display(f\"Processing iter = {iters}\")\n",
    "    results[iters] = get_estimate_for_coalition(\n",
    "        t_cln, iters, test_X, value_function\n",
    "    ).std(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.lineplot(x=list(results.keys()), y=list(results.values()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def reduce_to_most_meaningful(local_js, to=10):\n",
    "    global_js = local_js.abs().mean(axis=0)\n",
    "    global_js = global_js.sort_values(ascending=False)\n",
    "    most_meaningful_coalitions = global_js.iloc[:to]\n",
    "    return most_meaningful_coalitions.index"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Run calculation using new process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_using_new_process(X, y, k, value_f, num_iter = 600):\n",
    "    n_features = frozenset(list(X.columns))\n",
    "    n = len(n_features)\n",
    "    coalitions_to_k = list(get_powerset_to_k(n_features, k))\n",
    "    print(f\"Starting calculation for k = {k} with {len(coalitions_to_k)} features\")\n",
    "    num_observations = len(y)\n",
    "            \n",
    "    baseline = explainer(X).base_values\n",
    "    local_joint_shapleys = pd.DataFrame(index = X.index, columns=coalitions_to_k)\n",
    "\n",
    "    for cln_n, cln in enumerate(coalitions_to_k):\n",
    "        clear_output(wait=True)\n",
    "        display(f\"cln = {cln_n} / {len(coalitions_to_k)}\")\n",
    "        value_function = (\n",
    "            lambda cln: get_estimate_for_coalition(cln, num_iter, X, value_f)\n",
    "        )\n",
    "        local_joint_shapleys.loc[:, [cln]] = value_function(cln).reshape(-1,1)\n",
    "\n",
    "    clear_output(wait=True)\n",
    "    display(f\"Exporting data for k = {k} to csv\")\n",
    "    global_joint_shapleys = np.abs(local_joint_shapleys).mean(axis=0)\n",
    "    return local_joint_shapleys, global_joint_shapleys"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Exporting data for k = 1 to csv'"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "new_local, new_global = calculate_using_new_process(test_X, test_y, k, value_function)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "# export all local, global joint Shapleys\n",
    "new_local.to_csv(f\"local_{dataset_pathname}_all_js_k_{k}.csv\")\n",
    "new_global.to_csv(f\"global_{dataset_pathname}_all_js_k_{k}.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_mm_local_js = new_local.loc[:, reduce_to_most_meaningful(new_local)]\n",
    "new_mm_global_js = new_global.loc[reduce_to_most_meaningful(new_local)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def show_strip_plot(local_js):\n",
    "    stacked = local_js.stack().to_frame().rename(columns={0: \"Joint Shapley\"})\n",
    "    stacked.loc[:, \"Coalition\"] = [ind[1] for ind in stacked.index]\n",
    "    f, ax = plt.subplots()\n",
    "    sns.despine(bottom=True, left=True)\n",
    "    ax = sns.stripplot(\n",
    "        x=\"Joint Shapley\",\n",
    "        y=\"Coalition\",\n",
    "        data=stacked, \n",
    "        dodge=True, alpha=.5, zorder=1)\n",
    "    ax.xaxis.label.set_size(10)#set_xlabel(\"Coalition\", fontsize=6)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "show_strip_plot(new_mm_local_js)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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s4dNmzZZsxuEEEI8gGZPtJmZmezcuZOwsLDmDuWe8vPzubWb4OXLlzGZTMquObt37yYhIYHBgwfj4OCgbD4PdQkzMDCQ7du31zveunXrMBqNbNiwgS+++II///nPXLp0ieXLlyt1AgICMBqN9f698MILODg4oFarmTp1KgMHDiQvLw+AoUOHsmfPHkpLS63dHUIIIX6EZl11PGXKFCwWC76+vri4uNCxY0fUajXJycksWrSIvLw8VCoVERERaLVaUlNTlaRVWVnJuXPnOHjwIBUVFeh0OsrKylCr1SQkJODl5UVcXBzOzs4cO3aMCxcuMG3aNEaMGEFeXh56vR4AFxcXli1bRocOHTAYDKSkpGA2m+nduzfz5s0jJSWFixcvotVqSUtLIy0tjZCQEOUcKisrcXZ2BqBv37507doVgH/84x/861//4u233+bdd99Fq9XSpk0bbt68yYYNG/jTn/7E448/DtRtFP/BBx+wd+/eRvvs2WefxdXVFYC2bdvW22B+6NChpKWl8e677z6Ev44QQoiHoVlHtOvWrQPAYDBQXFyMXq9n48aNbNmyhfPnz5OVlcW2bdvYs2cPBw4cYPz48RiNRgwGAz169CA2NhY3NzfmzJnD7NmzyczMZMGCBbz33ntKGyUlJWzevJm1a9eydOlSANasWYNOpyMjIwNfX18KCws5deoUW7duJT09HaPRiKurK8nJyWi1Wjp27Mj69etp3749JpOJ/v37A1BVVcXp06dxd3cHYOHChUrS3b59O8OGDaNPnz7Y2toqe9OePn0aW1tbunfvXq8vOnTowOjRo5XnJpOp3rRxVFQUAK+88gojRowAoEuXLhQWFirvefnllzGZTA/vDySEEOInazG/o3V1daVz585A3VRtZGQkNjY2ODo6Eh4eTl5eHkOGDAFg5cqV2NnZMXnyZMrLyykoKCA+Pl45VkVFBVevXgXAz88PlUpFz549KSsrAyAwMJCYmBiCgoIIDAzEz8+PTZs2UVRUxKhRowCorq7Gy8vrjjiLioro1KkTANOnT8fHxwc3N7d6daqrq8nOzubTTz8FIDQ0lPT0dF599VUAVCqVUverr77it7/9LVA3LX3o0CGgbup48eLFDfZZWFgY27ZtIzk5mV/96lc89dRTFBUVNdLTQgghmlKLSbRqtVp5bDab65VZLBZqa+vu+LNr1y5y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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, ax = plt.subplots()\n",
    "sns.lineplot(bottom=True, left=True)\n",
    "_ = sns.barplot(x=new_mm_global_js.values, y=new_mm_global_js.index)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_mm_local_js.to_csv(f\"local_{dataset_pathname}_js_k_{k}.csv\")\n",
    "new_mm_global_js.to_csv(f\"globa_{dataset_pathname}_js_k_{k}.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
