{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import seaborn as sns\n",
    "sns.set(style=\"darkgrid\")\n",
    "from scipy.stats import poisson\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dat = '../../dat/lastfm/lastfm_processed.npz'\n",
    "array = np.load(dat)\n",
    "A = array['adj']\n",
    "Y_p = array['y_past']\n",
    "Y_heldout = array['y_heldout']\n",
    "Y = array['y']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "users_to_predict = (Y_heldout.sum(axis=1) > 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "out = '../../out/lastfm/'\n",
    "res_pif = np.load(out + 'pif_fitted_params.npz')\n",
    "res_unadj = np.load(out + 'unadjusted_fitted_params.npz')\n",
    "res_spf= np.load(out + 'spf_fitted_params.npz')\n",
    "res_net = np.load(out + 'network_pref_only_fitted_params.npz')\n",
    "res_item = np.load(out + 'item_only_fitted_params.npz') "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "beta_pif = res_pif['Beta_hat']\n",
    "beta_unadj = res_unadj['Beta_hat']\n",
    "beta_spf = res_spf['Beta_hat']\n",
    "beta_item = res_item['Beta_hat']\n",
    "beta_net = res_net['Beta_hat']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.003901340879411935,\n",
       " 0.0003244801425026929,\n",
       " 0.0005989334980591608,\n",
       " 0.000997148842906788,\n",
       " 0.0019293376731147377)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "beta_unadj.mean(), beta_spf.mean(), beta_pif.mean(), beta_item.mean(), beta_net.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def predict(params, A, Y_p, model):\n",
    "    gamma = params['Gamma_hat']\n",
    "    alpha = params['Alpha_hat']\n",
    "    z = params['Z_hat']\n",
    "    w = params['W_hat']\n",
    "    beta = params['Beta_hat']\n",
    "    \n",
    "    rate = (beta * A).dot(Y_p)\n",
    "    \n",
    "    if model == 'spf' or model == 'network_pref_only':\n",
    "        rate += z.dot(gamma.T)\n",
    "    elif model == 'item_only':\n",
    "        rate += alpha.dot(w.T)\n",
    "    elif model == 'pif':\n",
    "        rate += z.dot(gamma.T) + alpha.dot(w.T)\n",
    "    return rate + 1e-7\n",
    "\n",
    "def get_ll(predicted, truth, restrict_users=None):\n",
    "    if restrict_users is not None:\n",
    "        predicted = predicted[restrict_users,:]\n",
    "        truth = truth[restrict_users,:]\n",
    "    return poisson.logpmf(truth, predicted).sum(axis=1).mean()\n",
    "\n",
    "def get_influence_rates(params,A, Y_p):\n",
    "    beta = params['Beta_hat']\n",
    "    rate = (beta * A).dot(Y_p)\n",
    "    mean_inf_rate = rate.mean(axis=1)\n",
    "    return mean_inf_rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "heldout_pif = get_ll(predict(res_pif, A, Y_p, 'pif'), Y_heldout, restrict_users=users_to_predict)\n",
    "heldout_unadjusted = get_ll(predict(res_unadj, A, Y_p, 'unadjusted'), Y_heldout, restrict_users=users_to_predict)\n",
    "heldout_spf = get_ll(predict(res_spf, A, Y_p, 'spf'), Y_heldout, restrict_users=users_to_predict)\n",
    "heldout_net = get_ll(predict(res_net, A, Y_p, 'network_pref_only'), Y_heldout, restrict_users=users_to_predict)\n",
    "heldout_item = get_ll(predict(res_item, A, Y_p, 'item_only'), Y_heldout, restrict_users=users_to_predict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-127.66691052256706,\n",
       " -178.90860071250034,\n",
       " -153.29992744446176,\n",
       " -137.4322548290555,\n",
       " -142.25446392444064)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "heldout_pif, heldout_unadjusted, heldout_spf, heldout_net, heldout_item"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.00028107476466332373,\n",
       " 0.010492976995504827,\n",
       " 0.00012490152473026406,\n",
       " 0.0015422542104267883,\n",
       " 0.0008140058953315623)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_influence_rates(res_pif, A, Y_p).mean(), \\\n",
    "get_influence_rates(res_unadj, A, Y_p).mean(), \\\n",
    "get_influence_rates(res_spf, A, Y_p).mean(), \\\n",
    "get_influence_rates(res_net, A, Y_p).mean(), \\\n",
    "get_influence_rates(res_item, A, Y_p).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "from scipy.stats import spearmanr\n",
    "\n",
    "def convert_to_arr(centrality):\n",
    "    arr = np.array([centrality[i] for i in range(A.shape[0])])\n",
    "    return arr\n",
    "\n",
    "def calculate_corr_influence(centrality, influence):\n",
    "    arr = np.array([centrality[i] for i in range(A.shape[0])])\n",
    "    corr = spearmanr(influence, arr)\n",
    "    return corr[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "edge_list = []\n",
    "for i in range(A.shape[0]):\n",
    "    for j in range(A.shape[1]):\n",
    "        if A[i][j]:\n",
    "            edge_list.append((i,j))\n",
    "\n",
    "g = nx.Graph()\n",
    "g.add_edges_from(edge_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "degree = nx.degree_centrality(g)\n",
    "pagerank = nx.pagerank_numpy(g)\n",
    "eigen = nx.eigenvector_centrality(g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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>Degree centrality</th>\n",
       "      <th>Pagerank</th>\n",
       "      <th>Eigenvector centrality</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>PIF</th>\n",
       "      <td>-0.600394</td>\n",
       "      <td>-0.520733</td>\n",
       "      <td>-0.624198</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Unadjusted</th>\n",
       "      <td>-0.312366</td>\n",
       "      <td>-0.204206</td>\n",
       "      <td>-0.394596</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            Degree centrality  Pagerank  Eigenvector centrality\n",
       "PIF                 -0.600394 -0.520733               -0.624198\n",
       "Unadjusted          -0.312366 -0.204206               -0.394596"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pif_results = [calculate_corr_influence(degree, beta_pif), \n",
    "               calculate_corr_influence(pagerank, beta_pif), \n",
    "               calculate_corr_influence(eigen, beta_pif)]\n",
    "\n",
    "unadj_results = [calculate_corr_influence(degree, beta_unadj), \n",
    "               calculate_corr_influence(pagerank, beta_unadj), \n",
    "               calculate_corr_influence(eigen, beta_unadj)]\n",
    "\n",
    "df = pd.DataFrame([pif_results, unadj_results], columns=['Degree centrality', 'Pagerank', 'Eigenvector centrality'], index=['PIF', 'Unadjusted'])\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 38.,  13.,  25.,  92.,  68.,  22.,  72.,  28.,  47.,  38.,  62.,\n",
       "         83.,  49.,  62., 102., 117.,  28.,  25.,  30.,  14.]),\n",
       " array([14.,  3., 20., 24., 14.,  3., 21.,  1., 60.,  2., 18., 30., 13.,\n",
       "         5., 22., 16.,  9.,  7.,  4.,  3.]))"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "deg_arr = A.sum(axis=1)\n",
    "\n",
    "X = Y_p.copy()\n",
    "X[X>1] = 1\n",
    "copurchase = (X * (A.dot(Y))).sum(axis=1)\n",
    "# copurchase /= A.sum(axis=1)\n",
    "\n",
    "idx = beta_pif.argsort()[-20:]\n",
    "deg_arr[idx], copurchase[idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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gVWrVjF37tzBCveB3WsQwbuX98Q8fPjwhLnMzc2lvb0dgGg0SiAQICsrK2Fek5WZuQHYsGEDO3bsoKamhpEjRw56fL+GWbnx+/2cP3+eNWvWUFVVxenTp3nzzTdpbEz8S3FDzcz3zYgRI/B6vVgsFiZMmEB+fj4XLlwwI8z7klRFYSB2u52ioiL27NkDwK5duwYcMK+0tJTa2loAjh8/jtPpZNSoUZSUlLB79250XefSpUtcvHiRSZMmUVJSQn19Pd3d3fh8PhobG5k6dSrXrl3jlVde4b333sPr9Zoa6/261yCCDz30EE6nM97Sqra2lpKSkp/NZWlpKbt27QJi54KLioqw2+0J85qszMzN1q1bOXr0KJ999hn5+fkmR/rLmZWbCRMmcODAAWpra6mtreWRRx5h/fr1TJkyxeSI75+Z75vp06fH1798+TLXrl1jzJgxZob788y8qv2grly5IosWLZLKykp58cUX5caNGyIisn37dvnggw9ERCQYDEp1dbV4PB6ZM2eOnD59WkREDMOQd955Rzwej3g8Hjl48GD8cTdv3iwej0fKy8tl586dIiKybt06mTx5ssyePTt+2759u8kR39uXX34pXq9XysvL5aOPPhIRkSVLlsipU6dEROTMmTPyzDPPSEVFhaxcuVJCoZCIJM6l3++X5cuXi8fjkQULFsjly5dFJHFek5kZuTEMQ4qKiuTJJ5/s815paWkZmqDvk1nvm94WLVqU9K2PRMzLTUdHh6xevTr+nbRv374hiDYxNSCeoiiKEpf0p48URVEU86iioCiKosSpoqAoiqLEqaKgKIqixKmioCiKosSpoqAoiqLEqaKgKIqixKmioCiKosT9P/TSMqhyxrURAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# deg = g.degree()\n",
    "# deg_arr = convert_to_arr(deg)\n",
    "\n",
    "deg_arr = A.sum(axis=1)\n",
    "\n",
    "indices_1 = np.where(deg_arr <= 20)\n",
    "indices_2 = np.where((deg_arr > 20) & (deg_arr <=75))\n",
    "indices_3 = np.where((deg_arr > 75) & (deg_arr <=150))\n",
    "b1 = beta_pif[indices_1]\n",
    "b2 = beta_pif[indices_2]\n",
    "b3 = beta_pif[indices_3]\n",
    "# data = {'Deg <= 20':beta_pif[indices_1],\n",
    "#        'Deg > 20 and <= 50':beta_pif[indices_2],\n",
    "#        'Deg > 50 and <= 100':beta_pif[indices_3]}\n",
    "sns.distplot(b1[b1 <= 0.0005], label='Deg <= 20')\n",
    "sns.distplot(b2[b2 <= 0.0005], label='Deg > 20 and <= 50')\n",
    "sns.distplot(b3[b3 <= 0.0005], label='Deg > 50 and <= 100')\n",
    "plt.legend()\n",
    "plt.show()\n",
    "# sns.scatterplot(deg_arr[indices], beta_pif[indices])\n",
    "# sns.scatterplot(deg_arr, beta_pif)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = Y_p.copy()\n",
    "X[X>1] = 1\n",
    "copurchase = (X * (A.dot(Y))).sum(axis=1)\n",
    "copurchase /= A.sum(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7f82094389b0>"
      ]
     },
     "execution_count": 109,
     "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.distplot(copurchase)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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JR6Ph6997WvU1tbS2NiIoih4PJ7mNhUVFaSmppKUlER9fT2apmEymfB4PKSmpnYqGCFE/xbN9fhjYmL4yU9uZPTosXzzm99i5MjRLZ6f3bt3UVNTzfe//21MJhM/+tGtTJw4uTv/JK1q8/vOc889x4oVK1i+fDmLFy/moosu4v7778dms7FlyxYAli9fzsyZM7FYLEyZMoWVK1cC8MYbbzBz5szuPwIhRJ/RVj3+xMSkE+rxP/vsSxQXH+GNN14DmipUXnnlVfztb8vIzR3Es8/+pd39nXvudP7+939RWlrC66+/yl//+gLPP/939uzZ3aIe/+9+97/89a9NA06O1eP/y1+e54UX/smyZX+npqamuR7/M8+8yOWXX8muXTuorq7mz39+nN///nGee+5lzj77XJ588rEWsVx//Xd56aVXmTXrIp544lF+/OMfUFlZcVIrhRkzLuCpp57jF7+4k3vuuau5VHRPOq37uh9++GGWLFmC1+tlzJgxLFrUVFf6nnvu4c477+TJJ58kIyODP/zhDxENVgjRt0VzPX5o6t42mVRUtenn5O7uK674evP/hw8fyejRY9ix43NmzLig3WONpA4n/ry8PPLy8gAYOXIkr776aos2WVlZvPjii5GLTgjRr0RzPf5//ONvvPnm64wYMYqbb7611YvZq1a9zVlnjScrK7v5uLqz7v6pyJ27QoiIieZ6/DU1Nfzxj09yzz3/75QjmPbv38ff//43AA4fLmTfvr2MHz+xI09tREkJPyHONBY7zqHdkEws7Q9BjuZ6/Dff/JN2n58bbvgB99//a7797W+iKApLltxLTExsu+tFmtTj72FSj79nRFPMJ9dn70lSj79nRLoev3T1CCFElJHEL4TodVKPv2dJ4hfiDNDHemxFN4nU31kSvxD9nKqamodEijNbKBQ8YZjr6ZLEL0Q/53A4qa+vaTFGXpw5DMMgGAxQU+PB6ex6vaPeHzIihOgSpzOe6moPZWVFQM92+aiq2lyDp7/orzEriorLlYjD0fXhn5L4hejnFEUhKal3CiJG07DZ3hTpmKWrRwghoowkfiGEiDKS+IUQIspI4hdCiCgjiV8IIaKMJH4hhIgykviFECLKSOIXQogoI4lfCCGijCR+IYSIMpL4hRAiykjiF0KIKCOJXwghoowkfiGEiDKS+IUQIspI4hdCiCgjiV8I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N7+J5G6EEEKcpogXPdV1/YSuEsMwpOtECCH6kIgn/vT0dDweT/PvHo+H1NTUSO9GCCHEaYp44p8+fTrr16+nqqoKn8/He++9x8yZMyO9GyGEEKcp4hd309LSuO2221i0aBGhUIirrrqKcePGRXo3QgghTlPEL+4KIYTo22RGSyGEiDKS+IUQIspI4hdCiCgjiV8IIaJMn0z8R48e5brrrmPevHn86Ec/oqGhoUWbYDDI7bffzqWXXsqVV17JgQMHgKYbxh588EHmzZvH/Pnz2bJlCwCapnHPPfdw2WWXsWDBAp5//vmIxPrWW28xf/585syZw0svvdTi8fz8fPLy8pg7dy5333034XC4zWOsq6vjpptu4tJLL+W666474Z6ISIl0zAcOHOC6667ja1/7GldffTX5+fl9PuZjSktLOfvssykqKurzMXu9Xn7+859zxRVXcMUVV7Br164+H3NtbS033ngjl19+OVdddVWfem0c87//+7889thjzb9393sw0vGe1vvP6INuuukmY8WKFYZhGMbjjz9uPPTQQy3aPP3008avfvUrwzAMY+PGjcY3vvENwzAM45133jFuvPFGQ9M04+DBg8bs2bONUChkLFu2zFi8eLGhaZrR0NBgXHrppcbOnTu7FGdpaalx4YUXGtXV1UZDQ4OxcOFCY9++fSe0WbBggbF161bDMAzjl7/8pfHSSy+1eYz33nuv8dRTTxmGYRivv/668dOf/rRLMfZEzNdcc43x4YcfGoZhGOvWrTMWLlzY52M2DMPQNM343ve+Z0yYMME4cuRIn4/5rrvuMn73u98ZhmEYq1evNq666qo+H/MjjzzS/P/333/fuOaaa/pMzHV1dcYvf/lLY9y4ccajjz7a3L4734PdEe/pvP/63Bl/KBRi06ZNzJ07F4C8vDxWrVrVot1HH33E5ZdfDsDUqVOpqqri6NGjrF69mvnz56OqKoMGDSIjI4OtW7cybNgwbrnlFlRVJSYmhpycHEpKSroU6/EF6WJiYpoL0h1TXFyM3+9nwoQJJxxLW8f40UcfsXDhQgAuu+wyPv74Y0KhEJHSHTF/4xvfYMaMGQCMGDGiy89rT8QM8PTTTzN9+nQSExMjGm93xGwYBu+99x433XQTADNnzuS3v/1tn44Zmkq4HDv79/l82O32PhEzwPvvv8/AgQO54YYbTthmd74HuyPe03n/9bnEX11djdPpxGxuurfM7XZTVlbWol15eTlut7v5d7fbTWlpKeXl5SeUiDi2fMKECQwfPhyAzz77jO3btzN16tQuxXpyDKmpqSfE2lqMZWVlbR7j8euYzWacTidVVVVdirO7Y87Ly8NkMgHw6KOPcskll0Qs3u6KeefOnWzYsKHFm6ivxlxZWYnVauXll1/m6quvZtGiRWia1qdjBvje977H+vXrOf/881myZAmLFy/uEzEDXHHFFdx0003Nr93W1on0e7A74j2d91+vzsD1zjvvcP/995+wLDc3t0VRt9aKvBknFX8zDANVVVstEqeqX32+bdq0idtuu42HH36Y+Pj4LsXfXkG6Uz1+crtTHWNr8XdVd8VsGAYPPfQQ27Zt44UXXohYvN0Rs8/n49577+WPf/xjRJ/b7oxZ0zQqKipwuVz885//ZO3atdxyyy28S+zt0AAAAyVJREFU//77fTZmgN/85jdcd911LFq0iK1bt3Lbbbfx9tv/v737B2kdjKIAfgZrkYeDClF00kkHB6EoWGxxUGkiVungoouI1UkQcXbUQRDHDhkcnBulHaQ4KG4dSh3ctIKLoUHBPyhUj8PDgqL1qckzkPuDDG2Xk9B7CV8+blL484+jwZ3K/BV21qBTeb9af796xx+JRLC/v//q0HUd19fX5buZj4a8NTY2wjTN8udisQhFUdDU1PTu9wCwu7uL+fl5rK2tIRgM/jj/ZwPp3v7+kqW+vv7Dc1QUBcViEQBQKpVwe3tbfreBHZzIXCqVsLi4iKOjI2xubqK2tta2vE5kzmazsCwLc3NziEajME0TMzMzODk5cW3muro6VFVVYXh4GAAQDAZxd3cHy7Jcmxn4uzwRi8UAAF1dXWhoaChvxPjNzJU4WYNO5P1O/bluqcfn8yEQCCCdTgMAksnku0PewuEwDMMAAGSzWfj9fjQ3NyMUCmFnZwePj484OztDoVBAZ2cn8vk8lpeXoes6enp6bMn62UC6lpYW+P3+8s4iwzAQCoUqnmM4HEYymQQApNNpBAIB+Hz2vQjaicyrq6u4ubmBruu2N30nMvf19WFvbw+GYcAwDCiKgkQigba2Ntdmrq6uRm9vL1KpFAAgl8uhpqbG1ucTTvw32tvbkclkAACFQgGmaaK1tfXXM1fiZA06kfdb9feVJ9L/y/n5OScmJhiJRDg1NcWrqyuS5NbWFtfX10mS9/f3XFpaoqqqHB0dLe/QeXp64srKClVVpaqqPDg4IEnOzs6yu7ubIyMj5SOTyfw46/b2NjVN4+DgIBOJBElyenqa+XyeJHl8fMxYLMahoSEuLCzw4eGh4jleXl4yHo9TVVWOj4/bvtvE7syWZbGjo4MDAwOvrq2bM7/V39/v+utMkhcXF4zH49Q0jdFolLlczvWZT09POTk5SU3TODY2xsPDQ9dkfrGxsfFql4zTNWhn3u/WnwxpE0IIj3HdUo8QQghnSeMXQgiPkcYvhBAeI41fCCE8Rhq/EEJ4jDR+IYTwGGn8QgjhMdL4hRDCY54BafhO3QCkfK8AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "indices_1 = np.where(copurchase <= 5)\n",
    "indices_2 = np.where(copurchase > 5)\n",
    "b1 = beta_unadj[indices_1]\n",
    "b2 = beta_unadj[indices_2]\n",
    "# b3 = beta_unadj[indices_3]\n",
    "\n",
    "sns.distplot(b1[b1 <= 0.01], label='Copurchase <= 5', kde=True)\n",
    "sns.distplot(b2[b2 <= 0.01], label='Copurchase > 5', kde=True)\n",
    "# sns.distplot(b3[b3 <= 0.01], label='Copurchase > 400', kde=True)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(SpearmanrResult(correlation=0.057361062439635145, pvalue=0.00022581593981799405),\n",
       " SpearmanrResult(correlation=-0.6488501479289093, pvalue=0.0))"
      ]
     },
     "execution_count": 117,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "spearmanr(copurchase, beta_unadj), spearmanr(copurchase, beta_pif)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "indices_1 = np.where(copurchase <= 50)\n",
    "indices_2 = np.where((copurchase > 100) & (copurchase <=400))\n",
    "indices_3 = np.where((copurchase > 400))\n",
    "b1 = beta_pif[indices_1]\n",
    "b2 = beta_pif[indices_2]\n",
    "b3 = beta_pif[indices_3]\n",
    "\n",
    "sns.distplot(b1[b1 <= 0.001], label='Copurchase <= 50', kde=True)\n",
    "sns.distplot(b2[b2 <= 0.001], label='Copurchase > 100 and <= 400', kde=True)\n",
    "sns.distplot(b3[b3 <= 0.001], label='Copurchase > 400', kde=True)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "overlap = []\n",
    "per_item_overlap = np.zeros(Y.shape[1])\n",
    "row_idx, col_idx = np.nonzero(A)\n",
    "for (i,j) in zip(row_idx, col_idx):\n",
    "    i1 = np.nonzero(Y[i,:])[0]\n",
    "    i2 = np.nonzero(Y_p[j,:])[0]\n",
    "    intersect = np.intersect1d(i1, i2)\n",
    "    overlap.append(intersect.shape[0])\n",
    "    for k in intersect:\n",
    "        per_item_overlap[k] += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2.9364837135834545, 0.5189749854223101)"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "overlap = np.array(overlap)\n",
    "overlap.mean(), (overlap > 0).sum()/overlap.shape[0]\n",
    "\n",
    "# import matplotlib.pyplot as plt\n",
    "# plt.hist(overlap)\n",
    "# plt.xlim(0, 200)\n",
    "# np.histogram(overlap)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "items = (per_item_overlap > 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_overlap = []\n",
    "\n",
    "for (i,j) in zip(row_idx, col_idx):\n",
    "    i1 = np.nonzero(Y[i,items])[0]\n",
    "    i2 = np.nonzero(Y_p[j,items])[0]\n",
    "    intersect = np.intersect1d(i1, i2)\n",
    "    selected_overlap.append(intersect.shape[0])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2.779295620788155, 0.506659605405924)"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selected_overlap = np.array(selected_overlap)\n",
    "selected_overlap.mean(), (selected_overlap > 0).sum()/selected_overlap.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = A.shape[0]\n",
    "betas = np.hstack([beta_unadj, beta_net, beta_item, beta_spf, beta_pif])\n",
    "method_names = ['unadjusted']*n + ['network only']*n + ['item only']*n + ['spf']*n + ['pif']*n\n",
    "df = pd.DataFrame(np.array([betas, method_names]).T, columns=['beta', 'method'])\n",
    "df = df.astype({'beta': 'float'})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7ff5d0332828>"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAbIAAAEJCAYAAADxfqKqAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nO3deVhWdf7/8ee9cQOCgASiaOYOqO2J2rgnmEsuVNOUDk1p06JYmmlpTmONqZVmOVM/m2ls0VbLJVvAJc1MLLU0BVtcRgUFN5RduM/vD4L0Kxki3LeH+/W4Li/lnPuc+/0+qC8+n3PucyyGYRiIiIiYlNXTBYiIiFwIBZmIiJiagkxERExNQSYiIqamIBMREVNTkImIiKkpyERExNTsni7AWx07lofLVXMf4QsNDeDIkdwa25+ZeHPv4N39e3Pv4F39W60WQkLqVbpOQeYhLpdRo0FWvk9v5c29g3f37829g/oHTS2KiIjJKchERMTUFGQiImJqCjIRETE1BZmIiJiagkxERExNQSYiIqamIBMREVNTkImIiKkpyERExNQUZCIiYmoKMhERMTUFmYiImJqCTERETE1BJiIiplangiw1NZXhw4cDMGnSJLZt23be+3j33Xf56KOPzmubXr16sX///vN+r5qWk3OcTZu+5sMP3yM5+RO+/XYzmZkHKC0t9XRpIiK1ps4+WPMf//hHtbbbvHkzHTt2rOFqak9+fj5r165izdpVHDp4sNLX2O0Omja9lMsua0GTJk1o2LARERGNCA4OwWqtUz/LiIgX8liQpaamMnfuXN544w0AJk6cSMeOHXn99ddp3bo1aWlphIaGMmfOHIKDg3nzzTdZsmQJBQUFOBwOnnvuOVq0aMG6det4+umncTqdNG/evGL/w4cPZ9SoUQCVvk9cXBxjx47l8OHDADzwwAP4+fmxatUqNmzYQFhYGNHR0UyZMoWDBw9isVgYN24cXbp04fjx44wfP56DBw/SsmVLioqK3HrsCgry2bXrZ7Zu/Za1a1dTVFSIzS8Me0ATXCUFYLECBrhKcZUWUeIqZveePezevats+WlsdjsOuwMfHx/CwxvSunVbAgIC8PPzx8/PD19fP3x8fPDxceJ0+uBw+ODjc/rvDiwWi1v7FxE53UU3IktPT2fatGnExMQwevRoli1bxpAhQ1ixYgVvvPEGvr6+zJkzhwULFjBhwgQmTpzIa6+9RsuWLZk0aVKV3yclJYXIyEjmzZtHWloaS5cuZcKECfTq1YuOHTvStWtXHnroIRISEujduzdZWVncfvvtLF68mBdeeIGYmBheeeUVvv76az755JNaPCK/yso6xNNP/52cnONlCywW7IGX4hMYyKmcPRgF2Wdt4+vrS1xcP5KTkyksLDxrfWlJCaUlJRQWFnDiRA4//fRDbbchIl7K39+f8eMn06zZZTW634suyEJDQ4mJiQGgdevW5OTkEBAQwHPPPcfy5cvZs2cPX3zxBdHR0ezcuZPw8HBatmwJwJAhQ5gzZ06V3ueqq65i1qxZHDp0iB49evDAAw+c9Zr169eza9cuXnjhBQBKSkrYt28fGzdu5LnnngPguuuuo2nTpjXR+u/Ky8v9NcQAq90Pm18DsNjAdarSbeLi4hg5ciSGYbBs2bIqvIsFLBYwXDVUtYhImfz8fI4dO1p3gsxisWAYv05znTpV9h+x0+k86zWZmZkMHz6cYcOG0a1bNy655BLS0tLO2ofNZqvy+1x22WV88sknfPHFF6xevZpXX32Vjz/++IxtXS4Xr732GsHBwQBkZWURGhpapfetDc2bt+Sll15lz57d/PjjTr777lt+/nkLVpsPFmcIRv6hs7ZJTk7GMAxSUlKq9B4REY1o0qQp/v7++Pn543Q6cTqd+Pg4f5liLJtOLJ9uLJ9itNvtFb9sNhtWqw2r1YrNZsVqtWGxWGrtfFxYWCDZ2SdrZd9m4M39e3PvoP7LeSzIQkJC2LdvH0VFRRQUFLBp0yauv/76Sl+7bds2mjVrxp133klhYSEvvPACERERtG3blsOHD5Oenk5UVBTLly+v8vu8+eab7Nu3j0cffZRu3brRs2dPcnNzsdlsFVf5derUiYULF3L//ffz008/cccdd7By5Uo6d+7MkiVLiIqKYuvWrfzvf/+r1WN1OqfTl7Zto2nbNpoBAwaza9dPfPrZcr75OvXXF1lsgAGGi8LCwoqRmNPp+0solYeQoyJ8fHx8uPLKq+nR4wad8xIRU/FYkLVu3Zru3bvTv39/IiMjueaaa37ztddffz1vvfUW/fr1wzAMrrvuOn788UccDgezZs1i/Pjx2O32iinJqrzP4MGDGTt2LAMHDsRmszF+/Hjq169Ply5dmDVrFoGBgUyePJkpU6YwcOBAAGbOnElAQABJSUlMnDiR/v3706JFC7dNLVamRYtW3H/fGJwPGqSmbuHnn39k797dBAQEEB4eQXh4Q5o0uZTGjSOx2y+6mWQRkQtmMU6fI6tDBg8ezJNPPkmHDh08XUqljhzJxeWquUPvzVMM3tw7eHf/3tw7eFf/VquF0NCAyte5uRa3uPnmm/H19aVt27aeLkVERGpZnZxrev/99z1dgoiIuEmdHJGJiIj3UJCJiIipKchERMTUFGQiImJqCjIRETE1BZmIiJiagkxERExNQSYiIqamIBMREVNTkImIiKkpyERExNQUZCIiYmoKMhERMTUFmYiImJqCTERETE1BJiIipqYgExERU1OQiYiIqSnIRETE1BRkIiJiagoyERExNQWZiIiYmoJMRERMTUEmIiKmpiATERFTU5CJiIipKchERMTUFGQiImJqCjIRETE1BZmIiJiagqwOyMo6xNKlS8nMzPB0KSIibmf3dAFyYTIzM5g5Yyo5J04AENEwgoE3DaVz5z94uDIREfe4aEZkjz76KAcOHKjRfbZt27ZG95eamsrw4cNrdJ8XIjPzADNmTKW0MI/EDiH0axmINe8Ir7zyL1as+MzT5YmIuMVFE2SpqakYhuHpMkxj166fmDF9Kq7CPBI7BNM82IeOjf2564oQokKdLFz4GsuXL9ExFZE6r1aCLDU1lbvuuov777+f+Ph4kpKSKC4uBmDx4sUMGTKEQYMG8dhjj1FUVMS8efPIysrinnvu4dVXX+WZZ54BYN26dVx99dWUlJQAcOONN3L48GG+/fZbbrnlFm666SYSExPZu3cvAMOHD2fUqFHEx8eTlpZWUc/mzZuJi4ureF25goICxo0bx4ABAxg4cCCLFy8G4IMPPuChhx7irrvuok+fPjzxxBNnbLd371569OiBy+Wq6HfEiBE1fyB/w4YN65kxfSrWUwX8uX0Qmw8W8MLXh3l582He+P4YBadc1HNYWLToHcaOfYC1a1dXHH8Rkbqm1s6RbdmyhU8++YTw8HBuvfVW1q1bR9OmTXn33Xd5++23cTqdPPfcc/znP//h/vvv5+2332bevHkUFRUxfvx4ADZs2ICvry87duwgJCSEwMBA6tevz9ixY3n++ee5/PLL+eSTTxg7diyLFi0CyqYT586dW1FHeno6kyZN4uWXX6ZZs2Zn1Pjiiy8SEhLCRx99xNGjR7nllluIioqqqP+jjz7CZrPRt29f/vSnP1Vs16xZM5o0aUJqaiqdO3dm8eLFDB06tLYO5Rk+/3wlr7/+H5oF+XBrVBBf7s9jyxEXcXH9SU5OpjCv8IzX5+QcZ/78V5g//xVsNht2ux2bzUZYWEMaN47E4XDgcDiw2cqWW61WbDYbNpsdu73s9Xa745dlv663Wq1YLJbfqNICnD0SLB8c/uZmFdtSyfaV7bNsWf36fpw4UVCFfV7MKuutKq/jtP5rts9zf5/OX01MDvzfmn7/e28O1Tk2zZu3ICwssOaLMaFaC7LWrVsTEREBQMuWLcnJySEjI4O9e/dy6623AnDq1CliYmLO2K5ly5bk5uaSk5PDN998w+23387GjRvx8/Oje/fu7Nmzh/r163P55ZcDZaO0KVOmcPLkSYCK5eXuvvtu+vbtS4sWLc6qccOGDUybNg2ABg0a0Lt3bzZu3EhAQABXXXUVAQEBADRt2pScnJwztk1ISGDp0qVceeWVbNiw4axRW2359tvNBPvaGN4+GLvVws/Hi4mL68fIkSMxDINly5adtY3TZsFlGJwqLaW0tBSAvXt3s3fvbrfULCI1LyAggIULF3q6jItCrQWZ0+ms+LPFYsEwDEpLS7nxxhuZPHkyAHl5eRX/sZ6ua9eupKSkYLFY6NWrF3PmzMFisZCUlFQxnXe68n0D+Pr6nrHu2Wef5ZFHHjljtHX6dr+1n8rqP13fvn2ZPXs2n332Gd26dTvj9bWpadOmbN26hU9+Pkm/loG0DPYhOTkZwzBISUmpdJviUqPi53i7zYa/vz9Opy9OpxOHwwf7L6Myq9WGzWbFarVV9Px/fy8bEZSNhCyWspnp8vXlfy53+rLTj+Hp+6xsfWXbn2uZr6+DoqKSKu2zTHkPNaGyfVVv/5X19nuvs1gsOJ12CgtPnff7nVttnVu9kON+dk0+PnaKi0suYJ8Xk/M7Nr17x51jVsS7uPXy+9jYWF599VXuu+8+GjRowBNPPMGll17K6NGjsdlsFSHSvXt3nnzySeLj44mOjubnn3/GZrMRExNDcXExx48fZ+vWrVx++eV8/PHHNG7cmODg4Erfs3PnzowbN47Jkyfz7rvvYrX+elqwU6dOvP/++0yePJmjR4+ycuVKXnzxRXbu3Pm7vfj5+dGtWzdmzZrFiy++WDMHqAqGDLkVw4CPP17KkYJSbomqD+TzZcrHBNvAGeQAIKewlONFLux2O92796Zz5+u55JJwAgMD69xf/rCwQLKzT3q6DI/x5v69uXf5lVuDLCoqilGjRpGYmIjL5SI6Opp77rkHgB49enDPPffw73//m9jYWLKzs+nYsSMWi4Xo6GhCQkIA8PHxYfbs2Tz55JMUFBQQFBTE7Nmzz/m+gwcP5oMPPuCNN94gMTGxYvkDDzzAE088wcCBAyktLeXee++lXbt2VQoygP79+7N582auuOKKah6R82e1Wrn55tuIjGzCf/87jze25/Dn9sHEtSibKzcMg1V78/giJ4/Y2M4MH343/v7+bqtPRMTdLIauz66W0tJSZs+eTWhoKH/5y1/Oe/sjR3JxuS7s0H///Xe88MJzXOJrYVi7IA4XlLL5YAFbswrp1q0nf/7z3WeMQOsqb/+p3Jv79+bewbv6t1othIYGVL7OzbXUGQkJCWzfvv2MqxndrX37K0hKepgjhQbPpR5m/tZj7DhyihtvHEhi4givCDEREY3IPKQmRmTl0tN3sGVLKq1aRdO+/RX4+fnVyH7Nwpt+Kq2MN/fvzb2Dd/V/rhGZ7rVYB0RFxdC1a6zX/IUWETmd5p5ERMTUFGQiImJqCjIRETE1BZmIiJiagkxERExNQSYiIqamIBMREVNTkImIiKkpyERExNQUZCIiYmoKMhERMTUFmYiImJqCTERETE1BJiIipqYgExERU1OQiYiIqSnIRETE1BRkIiJiavZzrczIyDjnxo0bN67RYkRERM7XOYOsf//+WCwWDMOgsLAQf39/7HY7J06cIDQ0lHXr1rmrThERkUqdM8i2bNkCwJQpU4iNjaV///4ArFy5khUrVtR+dSIiIr+jSufIvv/++4oQA+jduzfp6em1VpSIiEhVVSnIXC4XqampFV+vXbsWi8VSa0WJiIhU1TmnFstNnjyZBx98EIfDgcvlAuCf//xnrRYmIiJSFVUKsmuvvZbVq1fzww8/YLFYaNOmDXZ7lTYVERGpVVVKo/z8fGbOnMnatWspKSnh+uuvZ9KkSQQEBNR2fSIiIudUpXNkTz/9NMXFxfzzn//kX//6FxaLhSeffLK2axMREfldVRqRfffddyxdurTi66eeeuqMqxjl4lBSUgKgaV8R8SpVGpGVlpZWXOQBZVcx2my2WitKzo/L5eKzzz5j3MOjeObZf2AYhqdLEhFxmyr96N65c2cefPBB/vSnPwHw1ltvERsbW6uFSdVkZBzgXy/NIePAfmz1HPz4w042bfqaa6/t6OnSRETcokojsokTJ9KqVStmzZrFM888Q/PmzXnkkUdquzb5HYZhMH/+Kxw8nElAbDhBfZpgr+/kvfcWVkwziojUdVUakdntdpKSkkhKSqrteuQ8bNv2LT/99AP1rrwEZ2TZFaR+7UPIXn+QNWtW0rt3vIcrFBGpfVUakaWkpNCnTx+uueYarr766opftW3btm1MmjQJgHfffZePPvqo1t/z97Rt29bTJQBl58Xee/8t7AE+OC8LrFjuaOiHI8yPxUsWkZ+f78EKRUTco0ojsmeeeYYJEyYQFRXl1ltTdejQgQ4dOgCwefNmOnbUeZ9yqanrObB/PwHXhWOx/vo9sVgs+LdvQM7qA8yY+SR3Jo6kefMWHqxURKR2VSnIAgICuOGGG2q7lrOkpqYyd+5c7rvvPlatWsWGDRsICwsjOjqaKVOmcPDgQSwWC+PGjaNLly68+OKLZGRksGfPHo4ePcp9993HV199xXfffUdUVBSzZ88+K4hffvllli5dis1m4/rrr2f8+PFkZmYyatQoWrduTVpaGqGhocyZM4fg4GCgbDR0ww038J///IfmzZuTn5/PjTfeSHJyMk6ns9aPS0lJCR988C72YCeOSH/yth6m+GA+FpsVq68Nn0b1qNcxjIytB3jqqcfp3r0XUVExhIU1pEGDUPz9/XA4fGq9ThERd6hSkHXo0IEVK1Z4JMwAunTpQq9evejYsSNdu3bloYceIiEhgd69e5OVlcXtt9/O4sWLAfjhhx9455132Lx5M4mJiSxbtozLLruMfv36sXPnTqKioir2u2bNGlatWsWiRYtwOByMHj2at99+m+7du5Oens60adOIiYlh9OjRLFu2jOHDhwNgtVoZPHgwS5cuZcyYMSQnJ9OjRw+3hBhARsZ+jhw5TMC1YRRsPwb7ixkQ14/k5GQKcwo4dagAaz07vlHBuE4U8/malXz++Uq31CYiF6/x4ycRHd3O02XUuHMG2VVXXYXFYqG0tJR33nkHHx8f7HY7hmFgsVjYvHmzu+o8w/r169m1axcvvPACUDZC2bdvHwDXX389drudxo0bExYWRqtWrQBo2LAhOTk5Z+xnw4YN9O/fHz8/PwASEhJYvHgx3bt3JzQ0lJiYGABat2591rZDhw7lL3/5C2PGjOHDDz9k7Nixtdrz6So+J2azcCqrgP5xfRk5ciSGYbBs2bKy15S4sNjAGujA6mPDVVTqtvpE5OJ0/PgxT5dQK84ZZOe6uMKTH7p1uVy89tprFVN9WVlZhIaGsmLFChwOR8Xrfu8OF6d/yLtc+WXrp4+uyp+SfbomTZrQuHFjkpOTOXLkCFdccUW1+zlfDRs2ol69ehTtPokj3I/k5GQMwyAlJaXiNc5m9SnalUvJsULatIkiOrod4eFlU4t+fn74+vrhdPricNix2x3YbDasVqspH88TFhZIdvZJT5fhMd7cvzf3Duq/3DmvWoyMjCQyMpK//e1vFX8u/+XOEQiAzWajtLRsVNGpUycWLlwIwE8//cTAgQMpKCg473126tSJ5cuXU1hYSElJCYsWLaJTp05V3j4hIYGnnnqKm2666bzf+0L4+voycOBQTmUV4Aj3g6ZOlq/+hFNOF46GfvhFh1D4Uw5+JQ7++tdRTJjwOIMGJdC58x9o2zaaSy+9jPDwhgQFBeHvXw8fHx9sNpspQ0xE5JxDlqSkJHbv3s2+ffsYOHBgxfKSkhJ8fNx7sUCXLl2YNWsWgYGBTJ48mSlTplTUNHPmzGrdib9nz56kpaWRkJBASUkJf/jDHxg2bBgHDx6s0vZxcXE8/vjjDBo06Lzf+0L17Nmbz5KXk7vjOIE9GlGvQ2jFupMbD2G32fnb36bRoEHoOfYiImJ+FuMcc4T79+/nwIEDPP744zz11FMVy202G61atSIoKMgtRV6MDMNg7dq1vPXWW7z88svnvf2RI7m4XBc2Pbtu3RpeffX/ERAbXvGB6JKjheR8nsGAAYMZOvTWC9q/WXj79Io39+/NvYN39W+1WggNrXzAcs4RWZMmTWjSpAmffvopxcXF7N27lzZt2lBYWFhxgYS3mjZtGqtXr+aVV17xWA1dunTl40+Wkf19NrZ6DmxBPuR/f4x6AQHceOPA39+BiEgdUKU7e2zbto0bbriBv/71rxw6dIgePXp47IrFi8WkSZNYsWIFzZs391gNVquVxD/fjdNwkLPqACe/PMipwwUMGXyL1/+gISLeo0pBNmPGDObPn09wcDARERHMnDmTf/zjH7Vdm1RB27bRzJjxPIMHD6b0SDHhDSPo1q2np8sSEXGbKn0gurCwsOLzWADdu3dn9uzZtVaUnJ969QK4++676dr1BqxWmx6sKSJepcp3v8/Jyam4PHvXrl21WpRUT0hIA0+XICLidlUKsnvvvZdhw4aRnZ3N2LFj+fLLL5k6dWpt1yYiIvK7qhRkvXr1IjAwkPT0dKxWK/feey9Wa5VOr4mIiNSqKgXZ008/zYIFC8740LHFYuGrr76qtcJERESqokpBlpKSwhdffEFISEht1yMiInJeqjQ/eNlll1G/fv3arkVEROS8VWlENnz4cIYNG0ZsbOwZl3aPGjWq1goTERGpiioF2bx58wgICODkSe+4p5eIiJhHlYKsoKCAt956q7ZrEREROW9VOkfWvHlz0tPTa7sWERGR81alEVlmZiY333wzkZGRZzyHbNmyZbVWmIiISFVUKcjc/TRoERGRqqpSkHXs2LG26xAREakW3WdKRERMTUEmIiKmpiATERFTU5DVAcXFxSxatIiSkhJPlyIi4nYKsjpg27ZvmT9/Pt9/v9XTpYiIuJ2CrA7IyjoEQGbmAQ9XIiLifgqyOiA7OwuAzMwMD1ciIuJ+CrI6IOtQ2Ygs48B+D1ciIuJ+CrI6IOtQJgAZGQcwDMPD1YiIuJeCzORKSko4euwYvhYLhUWFHD9+3NMliYi4lYLM5I4ePYLLcHGpo+xmzhkZml4UEe+iIDO58isWm/0SZLrgQ0S8jYLM5LKzy4Iswm7HabXqEnwR8ToKMpPLzs7CZrFQz2Il2GrTlYsi4nUUZCaXlZVFfZsNi8VCiNWqc2Qi4nUUZCaXdSiT+hYLACE2Gydzc8nNPenhqkRE3EdBZmKGYZCdnUV9qw2AEFvZc1IzMnSeTES8h4LsAm3fvp0ePXpwxx13uP29T548QVFxcUWQhdns2CwWvvxyrdtrERHxFAXZBVq9ejU33XQTCxYscPt7l196H2QrCzJ/q5V2Pk7WrVvDAV30ISJewu7pAi5GBw8e5OGHHyY/Px+r1crkyZMZO3Ysffv2Zf369QBMmzaN7Oxs3nrrLQB8fHwYNWqUW+s8fPgwAEUuF5sL8mnscHC1rz/pp4pZtOgdkpLGubUeERFPUJBV4v3336dHjx6MGDGCtWvXsmnTJgD8/f1ZvHgxq1atYsKECSxbtozbbrsNwO0hBlBaWvYgza9cJdwQF8dnycnEO5xc6ePLxm838dpr/6Zhwwj8/Pyx/XJloydZLJZK7wX5f5eX11nV1wYG+nLiREEtVGwO9ev7eW3/F9p7SEgDoqPbefzfhlwYBVklOnfuzOjRo0lLS6N79+4MGzaMBQsWcOuttwLQq1cvJk6cyNGjRz1caZk+cXGMGDkSC5CRvIL2vr5sLMxnzZpVni5N5KKXlPQwV155tafLkAugIKvENddcw/Lly/n888/5+OOP+fDDDwGw2389XC6XC9sv56Y8bUVyCgArU1Lo4/Dhp+IiAKKj2xEUFITFUv1ToeUjoN8aTV0MnE47RUUlni7DY3x9HRQWnvJ0GR5xob03bXop7dp1qMGKxBMUZJWYOXMmDRs2JDExkdjYWIYMGUK9evVYvnw5w4cPJyUlhZYtWxIUFOTROq3WsoDqbLVxMHkFfRw+hNrsfJafS+tWbXj44ce8YsokLCyQ7Gzv/eycN/fvzb3LrxRklRg+fDjjxo3jgw8+wGazMWPGDKZOncrmzZt5//338fPzY/r06Z4ukwYNQgHwtVpp7fQFYFNBPvmlpdxy6+1eEWIiIgqySjRq1IiFCxeesWzq1KmMGzeOJk2anLF89OjR7iztDOHhDQHIcZXSlLKrF78tLuSqq66hVas2HqtLRMSd9DkyEwsKCsZht3Oi1AVAdmkJxS4XvXrFebgyERH30YisilatuviuALRarVxySRgnjhwB4FhpKQBNmjT1ZFkiIm6lEZnJhTeM4MQvVxMeLS3Fz9eP+vU9exGKiIg7KchMLiysISdcpRiGwXFXKY0jI3WRh4h4FQWZyYWHN+SUy0WBYXDMcNG4cZPf30hEpA5RkJlceHg4AFklpygoLaVRo0gPVyQi4l4KMpMLCysLsr2nyu5u0LixgkxEvIuCzOQuuSQcC7D3VDGgIBMR76MgMzmHw0FwcAh5hgsfh6Pibh8iIt5CQVYHlN/hIyKiccX9F0VEvIX+16sDwsIjAGgcqSsWRcT7KMjqgPIrF3V+TES8kYKsDiifWtSl9yLijRRkdUC7dh2Ij48nJqadp0sREXE7BVkdUK9eAKNGjcLPz9/TpYiIuJ2CTERETE1BJiIipqYgExERU1OQiYiIqSnIRETE1BRkIiJiagoyERExNQWZiIiYmoJMRERMTUEmIiKmpiATERFTU5CJiIipKchERMTUFGR1wMmTJ3jzzTcZPz6JtLTtni5HRMSt7J4uQC5Mbm4ujz32MHl5uVgsFlJT1xMdreeSiYj30IjM5Hbu3EFeXi5Rl/UmOLAJ27d/7+mSRETcSkFmcunpadisdoICGhEU0IgjR7LJzs7ydFkiIm6jIDO59LTtBPiHYbXaCApoBKDzZCLiVRRkJnby5AkOZOynfkAEAH7OIHwc/uzYoelFEfEeCjIT++GHdACC6pUFmcVioX69CHbs+B7DMDxZmoiI2yjIquHQoUOMHDkSgIyMDOLj4xk0aBC5ublurWPnzrLzY/X8QiuWBQVEkJt7kgMH9rm1FhERT1GQVUPDhg155ZVXANi4cU/+ROUAAAqiSURBVCPt27dnyZIlBAQEuLWOtLQdFefHygUFNsZisTJ//r/Jz893az0iIp6gIPsdqampJCYmcvfddxMfH8/48ePZtWsXvXr1Ii0tjeeff54vvviCKVOmuLWu/Px8DhzYR6B/OHsyvmZL+ods+2k5x07so1XTruzevYuZM59i8+avycw8QF5eLi6Xy601ioi4gz4QXQVbtmxh8eLFNG/enDFjxrBmzRoAoqOjSUpKYuPGjUydOtWtNRUVFQFwMi+LotJjxPWNIzk5md0HUmke2Ym2zXryw//WMHfubLfWJeJpAwYMZujQWz1dhriRRmRVcN1119GiRQssFguDBg1iw4YNni6pQkFRDnFxcYwcOZI+ffoAZeFmtzuxWCwerk7E/Y4dO+rpEsTNNCKrApvt13NQhmGc8bWnOBwOAJw+ASQnJ2MYBikpKWXr7L6k704hJCSY+Ph+REQ0JigoCH//ejidTpxOX2w2W50JurCwQLKzT3q6DI/x5v69uXf5lYKsCjZt2sShQ4cICwtj8eLFdOvWjfT0dI/WFBAQQMOGERTl2Qjwb0HKZ2uw2wO4NKId+7O+JSwsjEcemUxISAOP1ikiUts0tVgF4eHhPPLII/Tr14+GDRvSpUsXT5cEQHR0O3ILsmnW6BquihpCh1b9cTr8cblKGTHifoWYiHgFjciq4JJLLuG11147Y9mqVasAGDp0KEOHDvVEWbRpE83nn68kr+AYAf5lnyXLyT2In58/zZu38EhNIiLuphGZibVtGw3AibyDQNn5uxN5mURFxWC16lsrIt5BI7LfERsbS2xsrKfLqFRISAjh4RGcyD1I47B2FBWfpLA4l5gYPY9MRLyHfmw3uejoGE7mZ2EYLnJyD/6yrL2HqxIRcR8Fmcm1bRtDSWkxufmHycnNJCgomEaNGnu6LBERt9HUoslFR7fDx8dJ2u4UDCA2tlOd+XyYiEhVaERmckFBQTzxxDR69uqBxWJw7bUdPV2SiIhbWQw9uMojjhzJxeWquUMfFhZIVtYJrxyNefvdHby5f2/uHbyrf6vVQmho5U8Y0YisDvHGEBMRUZCJiIipKchERMTUFGQiImJqCjIRETE1BZmIiJiagkxERExNQSYiIqamW1R5iNVa85/5qo19moU39w7e3b839w7e0/+5+tSdPURExNQ0tSgiIqamIBMREVNTkImIiKkpyERExNQUZCIiYmoKMhERMTUFmYiImJqCTERETE1BJiIipqYgM4Fly5bRr18/4uLiWLBgwVnr09LSGDp0KPHx8UyaNImSkhIAMjIyuOOOO+jbty/33XcfeXl57i79glW3902bNnHzzTczaNAgEhMTOXDggLtLrxHV7b/cjh07aN++vbvKrVHV7T0rK4t77rmHwYMHc9ttt7F//353l37Bqtv7/v37ueOOOxg0aBDDhw837d/782bIRe3gwYNGz549jWPHjhl5eXnGwIEDjR9//PGM1/Tv39/YsmWLYRiG8eijjxoLFiwwDMMw7rnnHuOjjz4yDMMw5s6da8ycOdO9xV+gC+m9Z8+eRlpammEYhvHee+8Z9957r3uLrwEX0r9hGEZ+fr5x2223GW3atHFr3TXhQnpPTEw0Fi5caBiGYSxcuNAYM2aMe4u/QBfS+8MPP1zx59dff90YN26ce4v3EI3ILnLr16+nU6dOBAcH4+/vT3x8PJ9++mnF+gMHDlBYWMiVV14JwNChQ/n00085deoUX3/9NfHx8WcsN5Pq9l5cXMyYMWOIiooCoG3btmRmZnqkhwtR3f7LTZ8+ncTERLfXXROq2/vRo0dJT0/ntttuAyAhIYEHH3zQIz1U14V8310uF7m5uQAUFBTg6+vr/gY8QEF2kcvKyiIsLKzi6/DwcA4dOvSb68PCwjh06BDHjh0jICAAu91+xnIzqW7vPj4+DBo0CCj7hz137lxuuOEG9xVeQ6rbP8DKlSspLCykb9++7iu4BlW393379tG4cWOmT59OQkICSUlJOBwOt9Z+oS7k+z5mzBjmz59P165defXVVxk5cqT7CvcgBdlFzuVyYbH8+vgCwzDO+Pq31v/f1wFnfX2xq27v5YqLi3n44YcpKSnhr3/9q3uKrkHV7T87O5uXXnqJxx9/3K311qTq9l5SUsKOHTvo1KkTixYtonfv3kycONGttV+oC/l7P2HCBKZOncoXX3zB3//+d0aNGoXhBQ84UZBd5CIiIsjOzq74Ojs7m/Dw8N9cf/jwYcLDw2nQoAEnT56ktLS00u3MoLq9A+Tl5TFixAhKSkp46aWXTPdTOVS//88//5zjx49XnPQHGDRoUMWUkxlUt/ewsDDq1atHz549ARgwYABbt251X+E1oLq9Hz16lF27dlXMPsTHx5Odnc2xY8fcV7yHKMgucl26dOGrr77i6NGjFBQUkJycTLdu3SrWR0ZG4nQ62bRpEwBLliyhW7duOBwOrr32Wj7++GMAFi9efMZ2ZlDd3gHGjx9Ps2bNeP755/Hx8fFI/Requv3fcsstrFixgiVLlrBkyZKKdQEBAR7pozqq2/ull15KREQEa9asAWD16tW0a9fOIz1UV3V7DwkJwel08s033wBlV+7Wq1ePBg0aeKQPt/LMNSZyPpYuXWr079/fiIuLM+bNm2cYhmGMGDHC2Lp1q2EYhpGWlmYkJCQY8fHxxtixY42ioiLDMAxj//79xrBhw4wbb7zRuOuuu4zjx497rIfqqk7v27dvN9q0aWP069fPuOmmm4ybbrrJGDFihCfbqLbqfu9PZ8arFg2j+r3//PPPxrBhw4z+/fsbf/zjH43du3d7qoVqq27v3333nXHzzTcbAwYMMP74xz8a27dv91gP7qQnRIuIiKlpalFERExNQSYiIqamIBMREVNTkImIiKkpyERExNQUZCJ1XGpqKgMGDDivbd57771K77oucjFSkInIWTZt2kRhYaGnyxCpErunCxCR2pefn09SUhJ79+6lfv36TJ06lcjISJ599lm+/vprSktLiYmJYfLkyXz11VesWrWKL7/8El9fX+Lj45kyZQpHjhwhOzubyMhInn/+eUJDQz3dlgigEZmIV8jMzOTOO+9kyZIlDBgwgEceeYR58+Zhs9n44IMPWLp0KeHh4Tz77LP06dOHXr16ceedd3LHHXewfPlyrrzySt555x1WrlyJr69vxa2vRC4GGpGJeIG2bdty9dVXAzBkyBCeeOIJTp06RUFBAevXrwfg1KlTlY6yEhMT+eabb/jvf//Lnj17+PHHH7niiivcWr/IuSjIRLyA1Xrm5Ev5Yz8ee+wxunfvDpQ9MaCoqOisbZ955hm2bt1KQkICsbGxlJSUeMWjQcQ8NLUo4gV27txJWloaAO+88w7XXHMN3bp1Y8GCBRQXF+NyuXj88ceZNWsWADabjZKSEgDWrVtHYmIigwcPJjQ0lPXr11c8HkjkYqARmYgXaNGiBXPnzmXfvn2EhoYyffp0QkNDmTFjBkOGDKG0tJTo6OiKh1B269aN6dOnA/DAAw8wc+ZM5syZg8Ph4Oqrr+Z///ufJ9sROYPufi8iIqamqUURETE1BZmIiJiagkxERExNQSYiIqamIBMREVNTkImIiKkpyERExNQUZCIiYmr/H39LNgRfvAmyAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.violinplot(x='beta', y='method', data=df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
