{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib\n",
    "from matplotlib import pyplot as plt\n",
    "import os\n",
    "from sklearn.metrics import mean_squared_error as mse, auc\n",
    "from scipy import sparse\n",
    "from scipy.stats import gamma\n",
    "from scipy.stats import ttest_ind\n",
    "import warnings\n",
    "import seaborn as sns\n",
    "sns.set(style=\"darkgrid\")\n",
    "warnings.filterwarnings(\"ignore\", category=DeprecationWarning)\n",
    "warnings.filterwarnings(\"ignore\", category=FutureWarning)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_set_overlap(Beta_p, Beta, k=50):\n",
    "    top = np.argsort(Beta)[-k:]\n",
    "    top_p = np.argsort(Beta_p)[-k:]\n",
    "    return np.intersect1d(top, top_p).shape[0]/np.union1d(top, top_p).shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_auc(beta_p, beta):\n",
    "    cutoffs = np.arange(10., 2000., step=50.)\n",
    "    precision = np.zeros(cutoffs.shape[0])\n",
    "    recall = np.zeros(cutoffs.shape[0])\n",
    "    beta_sorted = np.argsort(beta)\n",
    "    beta_p_sorted = np.argsort(beta_p)\n",
    "    for i, c in enumerate(cutoffs):\n",
    "        top = beta_sorted[-int(c):]\n",
    "        top_p = beta_p_sorted[-int(c):]\n",
    "        tp = np.intersect1d(top, top_p).shape[0]\n",
    "        fp = np.setdiff1d(top_p, top).shape[0]\n",
    "        fn = np.setdiff1d(top, top_p).shape[0]\n",
    "        p = tp/(tp + fp)\n",
    "        r = tp/(tp + fn)\n",
    "        precision[i] = p\n",
    "        recall[i] = r\n",
    "    return auc(precision, recall, reorder=True) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_most_least_influential(Beta,n=100):\n",
    "    sorted_inf = np.argsort(Beta)\n",
    "    highest = sorted_inf[-n:]\n",
    "    lowest = sorted_inf[:n]\n",
    "    return lowest, highest"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pokec simulation results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pokec_out = '../pokec_sim_out_high_v1/'\n",
    "pokec_out = '../pokec_sim_out/'\n",
    "num_exps = 10\n",
    "models = ['spf', 'naive', 'multi_cause']\n",
    "confounding_strengths = [2., 20., 100.,]\n",
    "exp_results = {}\n",
    "for i in range(1,num_exps+1):\n",
    "    for model in models:\n",
    "        for u_c in confounding_strengths:\n",
    "            for i_c in confounding_strengths:\n",
    "                f_name = 'u_conf=' + str(u_c) + ';i_conf=' + str(i_c) + '_fitted.gz'\n",
    "                truth_fname = 'u_conf=' + str(u_c) + ';i_conf=' + str(i_c) + '_true.gz'\n",
    "                result_file = os.path.join(pokec_out, str(i), model + '_model_fitted_params', f_name)\n",
    "                truth_file = os.path.join(pokec_out, str(i), model + '_model_fitted_params', truth_fname)\n",
    "                params = np.loadtxt(result_file)\n",
    "                truth = np.loadtxt(truth_file)\n",
    "                if (u_c, i_c) in exp_results:\n",
    "                    if model in exp_results[(u_c, i_c)]:\n",
    "                        exp_results[(u_c, i_c)][model].append((params, truth))\n",
    "                    else:\n",
    "                        exp_results[(u_c, i_c)][model]= [(params, truth)]\n",
    "                else:\n",
    "                    exp_results[(u_c, i_c)] = {model:[(params, truth)]}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "User confounding strength:  2 and item confounding strength: 2\n",
      "Model: spf\n",
      "Mean MSE: 0.10917345568306575 and st dev.: 0.04987534571500067\n",
      "Mean MSE for most influential: 7.12817766683291 and st dev.: 9.985576434258684\n",
      "Mean MSE for less influential: 0.04843251317209795 and st dev.: 0.0024297313149558783\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  2 and item confounding strength: 2\n",
      "Model: naive\n",
      "Mean MSE: 0.07989900876569657 and st dev.: 0.0782094236813353\n",
      "Mean MSE for most influential: 3.2902453808142913 and st dev.: 17.086248853800033\n",
      "Mean MSE for less influential: 0.05364490027185845 and st dev.: 0.002416898833336367\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  2 and item confounding strength: 2\n",
      "Model: multi_cause\n",
      "Mean MSE: 0.05959498838365218 and st dev.: 0.039183737870463246\n",
      "Mean MSE for most influential: 0.050976206658923315 and st dev.: 9.248162341259809\n",
      "Mean MSE for less influential: 0.049478947754149946 and st dev.: 0.0021431672896628858\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  20 and item confounding strength: 20\n",
      "Model: spf\n",
      "Mean MSE: 0.0833073710113632 and st dev.: 0.08731401389312812\n",
      "Mean MSE for most influential: 3.220937467070158 and st dev.: 12.439250069904789\n",
      "Mean MSE for less influential: 0.04859271597340124 and st dev.: 0.002442137829680797\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  20 and item confounding strength: 20\n",
      "Model: naive\n",
      "Mean MSE: 0.08449335446129129 and st dev.: 0.07802611731241352\n",
      "Mean MSE for most influential: 3.2633910943745295 and st dev.: 17.092936439189636\n",
      "Mean MSE for less influential: 0.058237636970769585 and st dev.: 0.002456515333915094\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  20 and item confounding strength: 20\n",
      "Model: multi_cause\n",
      "Mean MSE: 0.059619892810678504 and st dev.: 0.04052290538713707\n",
      "Mean MSE for most influential: 0.05117103959419417 and st dev.: 9.238829111064792\n",
      "Mean MSE for less influential: 0.049648259217931326 and st dev.: 0.0021399701225114196\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  100 and item confounding strength: 100\n",
      "Model: spf\n",
      "Mean MSE: 0.06590341074619305 and st dev.: 0.10931761509798864\n",
      "Mean MSE for most influential: 1.6839079103114807 and st dev.: 16.560335335969423\n",
      "Mean MSE for less influential: 0.0489399556822329 and st dev.: 0.002255964092089192\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  100 and item confounding strength: 100\n",
      "Model: naive\n",
      "Mean MSE: 0.08937330131864185 and st dev.: 0.07822954344269208\n",
      "Mean MSE for most influential: 3.315374303579493 and st dev.: 17.079384321650732\n",
      "Mean MSE for less influential: 0.06222335747388162 and st dev.: 0.002626730897209003\n",
      "------------------------------------------------------------\n",
      "User confounding strength:  100 and item confounding strength: 100\n",
      "Model: multi_cause\n",
      "Mean MSE: 0.06264299241803234 and st dev.: 0.04204250618851046\n",
      "Mean MSE for most influential: 0.08311679087125422 and st dev.: 9.219306254405915\n",
      "Mean MSE for less influential: 0.04970976174377054 and st dev.: 0.002097312739984508\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "models = ['spf', 'naive', 'multi_cause']\n",
    "regimes = [(2., 2.), (20., 20.), (100., 100.)]\n",
    "for (u_c, i_c) in regimes:\n",
    "    for model in models:\n",
    "        print(\"User confounding strength: % d and item confounding strength: %d\" % (u_c, i_c))\n",
    "        print(\"Model:\", model)\n",
    "        all_mses = []\n",
    "        most_mses = []\n",
    "        least_mses = []\n",
    "        for i in range(num_exps):\n",
    "            beta_hat = exp_results[(u_c, i_c)][model][i][0]\n",
    "            beta = exp_results[(u_c, i_c)][model][i][1]\n",
    "            most = [beta >=5]\n",
    "            least = [beta < 0.01]\n",
    "            all_mses.append(mse(beta, beta_hat))\n",
    "            most_mses.append(mse(beta[most], beta_hat[most]))\n",
    "            least_mses.append(mse(beta[least], beta_hat[least]))\n",
    "        print(\"Mean MSE:\", np.median(all_mses), \"and st dev.:\", np.std(all_mses))\n",
    "        print(\"Mean MSE for most influential:\", np.median(most_mses), \"and st dev.:\", np.std(most_mses))\n",
    "        print(\"Mean MSE for less influential:\", np.median(least_mses), \"and st dev.:\", np.std(least_mses))\n",
    "        print('-'*60)\n",
    "    print('-'*60)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "& 0.06 & 0.06 & 0.05 & 2.182 & 0.73 & 0.112 & 0.014 & 0.061 & 0.053 \\\\\n",
      "& 0.067 & 0.067 & 0.05 & 3.62 & 0.73 & 0.128 & 0.014 & 0.061 & 0.053 \\\\\n",
      "& 0.057 & 0.057 & 0.052 & 1.904 & 0.73 & 0.225 & 0.014 & 0.063 & 0.054 \\\\\n"
     ]
    }
   ],
   "source": [
    "models = ['spf', 'naive', 'pif'] #, 'multi_cause', 'inf_only']\n",
    "regimes = [(2., 2.), (20., 20.), (100., 100.)]\n",
    "for (u_c, i_c) in regimes:\n",
    "    mean_mses = []\n",
    "    mean_most_mses = []\n",
    "    mean_least_mses = []\n",
    "    for model in models:\n",
    "        mses = []\n",
    "        most_mses = []\n",
    "        least_mses = []\n",
    "        for i in range(num_exps):\n",
    "            beta_hat = exp_results[(u_c, i_c)][model][i][0]\n",
    "            beta = exp_results[(u_c, i_c)][model][i][1]\n",
    "            least, most = get_most_least_influential(beta)\n",
    "            mses.append(mse(beta, beta_hat))\n",
    "            most_mses.append(mse(beta[most], beta_hat[most]))\n",
    "            least_mses.append(mse(beta[least], beta_hat[least]))\n",
    "        mean_mses.append(np.mean(mses))\n",
    "        mean_most_mses.append(np.mean(most_mses))\n",
    "        mean_least_mses.append(np.mean(least_mses))\n",
    "    print(\"&\", round(mean_mses[0], 3), \"&\", round(mean_mses[0], 3), \"&\", round(mean_mses[2], 3), \"&\", round(mean_most_mses[0],3), \"&\",round(mean_most_mses[1],2) ,\"&\", round(mean_most_mses[2], 3), \"&\", round(mean_least_mses[0],3), \"&\",round(mean_least_mses[1],3) ,\"&\", round(mean_least_mses[2], 3) , '\\\\\\\\')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import gaussian_kde\n",
    "regime = (100., 100.)\n",
    "true_influence = []\n",
    "for model in exp_results[regime]:\n",
    "    per_user_mse = []\n",
    "    predicted = []\n",
    "    for i in range(len(exp_results[regime][model])):\n",
    "        beta_predicted = exp_results[regime][model][i][0]\n",
    "        truth = exp_results[regime][model][i][1]\n",
    "        mses = (beta_predicted - truth) ** 2\n",
    "        true_influence += list(truth)\n",
    "        per_user_mse += list(mses) \n",
    "        predicted += list(beta_predicted)\n",
    "    density = gaussian_kde(predicted)\n",
    "    xs = np.linspace(-0.25,0.25,10000)\n",
    "    plt.plot(xs, density(xs), label=model)\n",
    "\n",
    "true_density = gaussian_kde(true_influence)\n",
    "xs = np.linspace(-0.25,0.25,10000)\n",
    "plt.plot(xs, true_density(xs), label='truth')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/plots/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = [(2., 2.), (20., 20.),(100., 100.)]\n",
    "for regime in regimes:\n",
    "    for model in exp_results[regime]:\n",
    "        per_user_mse = []\n",
    "        predicted = []\n",
    "        true_influence = []\n",
    "        for i in range(len(exp_results[regime][model])):\n",
    "            beta_predicted = exp_results[regime][model][i][0]\n",
    "            truth = exp_results[regime][model][i][1]\n",
    "            mses = (beta_predicted - truth) ** 2\n",
    "            true_influence += list(truth)\n",
    "            per_user_mse += list(mses) \n",
    "            predicted += list(beta_predicted)\n",
    "\n",
    "        true_influence = np.array(true_influence)\n",
    "        per_user_mse = np.array(per_user_mse)\n",
    "        lowest, highest = get_most_least_influential(true_influence) \n",
    "        plt.scatter(true_influence[highest], per_user_mse[highest], label='High Influence Users')\n",
    "        plt.scatter(true_influence[lowest], per_user_mse[lowest], label='Low Influence Users')\n",
    "        plt.ylim((0., 0.5))\n",
    "        plt.title(\"Confounding strengths = \" + str(regime))\n",
    "        plt.legend()\n",
    "        plt.savefig(outdir + 'model=' + model + ';regime=' + str(regime) + '.pdf')\n",
    "        plt.clf()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/boxplots/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = [(2., 2.), (20., 20.),(100., 100.)]\n",
    "for regime in regimes:\n",
    "    for model in ['naive', 'spf', 'multi_cause']: #, 'inf_only']:\n",
    "#     for model in exp_results[regime]:\n",
    "        per_user_mse = []\n",
    "        predicted = []\n",
    "        true_influence = []\n",
    "        for i in range(len(exp_results[regime][model])):\n",
    "            beta_predicted = exp_results[regime][model][i][0]\n",
    "            truth = exp_results[regime][model][i][1]\n",
    "            mses = (beta_predicted - truth) ** 2\n",
    "            true_influence += list(truth)\n",
    "            per_user_mse += list(mses) \n",
    "            predicted += list(beta_predicted)\n",
    "\n",
    "        true_influence = np.array(true_influence)\n",
    "        per_user_mse = np.array(per_user_mse)\n",
    "        \n",
    "        highest = [true_influence >5]\n",
    "        lowest = [true_influence < 0.01]\n",
    "        plt.boxplot([per_user_mse[highest], per_user_mse[lowest]], labels=['High Influence Users', 'Low Influence Users'], showfliers=False)\n",
    "        plt.ylim((-0.005, 0.17))\n",
    "        plt.title(\"Confounding strengths = \" + str(regime))\n",
    "#         plt.show()\n",
    "        plt.savefig(outdir + 'model=' + model + ';regime=' + str(regime) + '.pdf')\n",
    "        plt.clf()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/boxplots/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = {'low':(2., 2.), 'med':(20., 20.), 'high':(100., 100.)}\n",
    "settings = {'high':\"High Influence Users\", 'low':\"Low Influence Users\"}\n",
    "axes = plt.axes()\n",
    "mse_results = {}\n",
    "for setting in settings:\n",
    "    for regime, config in regimes.items():\n",
    "        for model in ['naive', 'spf', 'multi_cause']:\n",
    "            per_user_mse = []\n",
    "            predicted = []\n",
    "            true_influence = []\n",
    "            for i in range(len(exp_results[config][model])):\n",
    "                beta_predicted = exp_results[config][model][i][0]\n",
    "                truth = exp_results[config][model][i][1]\n",
    "                mses = (beta_predicted - truth) ** 2\n",
    "                true_influence += list(truth)\n",
    "                per_user_mse += list(mses) \n",
    "                predicted += list(beta_predicted)\n",
    "\n",
    "            true_influence = np.array(true_influence)\n",
    "            per_user_mse = np.array(per_user_mse)\n",
    "\n",
    "            if setting == \"high\":\n",
    "                mask = [true_influence >= 5]\n",
    "            else:\n",
    "                mask = [true_influence < 0.01]\n",
    "\n",
    "            mse_results[(setting, model, regime)] = per_user_mse[mask]\n",
    "\n",
    "bp1 = plt.boxplot([mse_results[('high', 'naive', 'low')], mse_results[('high', 'spf', 'low')], mse_results[('high','multi_cause', 'low')],\n",
    "            mse_results[('high', 'naive', 'med')], mse_results[('high','spf', 'med')], mse_results[('high','multi_cause', 'med')],\n",
    "            mse_results[('high','naive', 'high')], mse_results[('high','spf', 'high')], mse_results[('high','multi_cause', 'high')]],\n",
    "            positions=[3, 4, 5, 8, 9, 10, 13, 14, 15],\n",
    "            showfliers=False, patch_artist=True)\n",
    "\n",
    "colors = ['slategrey', 'navy', 'maroon']\n",
    "for b_idx in range(9):\n",
    "    for item in ['boxes']:\n",
    "        c = colors[b_idx % 3]\n",
    "        plt.setp(bp1[item][b_idx], color=c)\n",
    "axes.set_xticklabels(['Low', 'Medium', 'High'])\n",
    "axes.set_xticks([4, 9, 14])\n",
    "plt.setp(bp1['medians'], color='white')\n",
    "\n",
    "grey = plt.plot([1,1], c=colors[0], label='Naive')\n",
    "navy = plt.plot([1,1], c=colors[1], label='mSPF')\n",
    "maroon = plt.plot([1,1], c=colors[2], label='PIF')\n",
    "plt.legend()\n",
    "plt.ylabel(\"Squared Error\")\n",
    "plt.ylim((-0.005, 0.17))\n",
    "plt.title(\"High Influence Users\")\n",
    "# plt.show()\n",
    "plt.savefig(outdir + 'setting=high.pdf')\n",
    "plt.clf()\n",
    "axes.clear()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "axes = plt.axes()\n",
    "bp2 = plt.boxplot([mse_results[('low', 'naive', 'low')], mse_results[('low', 'spf', 'low')], mse_results[('low','multi_cause', 'low')],\n",
    "            mse_results[('low', 'naive', 'med')], mse_results[('low','spf', 'med')], mse_results[('low','multi_cause', 'med')],\n",
    "            mse_results[('low','naive', 'high')], mse_results[('low','spf', 'high')], mse_results[('low','multi_cause', 'high')]],\n",
    "            positions=[3, 4, 5, 8, 9, 10, 13, 14, 15],\n",
    "            showfliers=False, patch_artist=True)\n",
    "colors = ['slategrey', 'navy', 'maroon']\n",
    "for b_idx in range(9):\n",
    "    for item in ['boxes']:\n",
    "        c = colors[b_idx % 3]\n",
    "        plt.setp(bp2[item][b_idx], color=c)\n",
    "axes.set_xticklabels(['Low', 'Medium', 'High'])\n",
    "axes.set_xticks([4, 9, 14])\n",
    "plt.setp(bp2['medians'], color='white')\n",
    "\n",
    "grey = plt.plot([1,1], c=colors[0], label='Naive')\n",
    "navy = plt.plot([1,1], c=colors[1], label='mSPF')\n",
    "maroon = plt.plot([1,1], c=colors[2], label='PIF')\n",
    "plt.legend()\n",
    "plt.ylabel(\"Squared Error\")\n",
    "plt.ylim((-0.005, 0.05))\n",
    "plt.title(\"Low Influence Users\")\n",
    "plt.savefig(outdir + 'setting=low.pdf')\n",
    "# plt.show()\n",
    "plt.clf()"
   ]
  },
  {
   "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": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import gaussian_kde\n",
    "regime = (100., 100.)\n",
    "xmin = 0.\n",
    "xmax = 1.\n",
    "ymin = 0.\n",
    "ymax = 1.\n",
    "# for model in exp_results[regime]:\n",
    "axes = plt.axes()\n",
    "for model in ['multi_cause']:\n",
    "    per_user_mse = []\n",
    "    predicted = []\n",
    "    true_influence = []\n",
    "    for i in range(len(exp_results[regime][model])):\n",
    "        beta_predicted = exp_results[regime][model][i][0]\n",
    "        truth = exp_results[regime][model][i][1]\n",
    "        mses = (beta_predicted - truth) ** 2\n",
    "        true_influence += list(truth)\n",
    "        per_user_mse += list(mses) \n",
    "        predicted += list(beta_predicted)\n",
    "    \n",
    "    true_influence = np.array(true_influence)\n",
    "    per_user_mse = np.array(per_user_mse)\n",
    "    lowest, highest = get_most_least_influential(true_influence,n=300)\n",
    "    high_inf_values = np.vstack([true_influence[highest], per_user_mse[highest]])  \n",
    "    low_inf_values = np.vstack([true_influence[lowest], per_user_mse[lowest]])\n",
    "    values = np.hstack([high_inf_values, low_inf_values])\n",
    "    density = gaussian_kde(values)\n",
    "    X, Y = np.mgrid[xmin:xmax:100j, ymin:ymax:100j]\n",
    "    positions = np.vstack([X.ravel(), Y.ravel()])\n",
    "    Z = np.reshape(density(positions).T, X.shape)\n",
    "    plt.imshow(np.rot90(Z), cmap=plt.cm.gist_earth_r,extent=[xmin, xmax, ymin, ymax])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import gaussian_kde, norm\n",
    "xmin = 0.\n",
    "xmax = 3.\n",
    "ymin = 0.\n",
    "ymax = 3.\n",
    "\n",
    "low = norm.rvs(0.0, scale=0.1, size=(2,1000))\n",
    "high = norm.rvs(1.0, scale=0.1, size=(2,1000))\n",
    "values = np.hstack([low, high])\n",
    "density = gaussian_kde(values)\n",
    "X, Y = np.mgrid[xmin:xmax:100j, ymin:ymax:100j]\n",
    "positions = np.vstack([X.ravel(), Y.ravel()])\n",
    "Z = np.reshape(density(positions), X.shape)\n",
    "plt.imshow(np.rot90(Z), cmap=plt.cm.gist_earth_r,extent=[xmin, xmax, ymin, ymax])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### bar plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'os' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-1-34dbd7b73ad4>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0moutdir\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m'../doc/aistats20/img/barplot/'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mos\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmakedirs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutdir\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexist_ok\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mscipy\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstats\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mgaussian_kde\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mregimes\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m'low'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2.\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m2.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'med'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m20.\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m20.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'high'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m100.\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m100.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0msettings\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m'high'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\"High Influence Users\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'low'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\"Low Influence Users\"\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'os' is not defined"
     ]
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/barplot/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = {'low':(2., 2.), 'med':(20., 20.), 'high':(100., 100.)}\n",
    "settings = {'high':\"High Influence Users\", 'low':\"Low Influence Users\"}\n",
    "model_colors = {'spf':'navy', 'naive':'slategrey', 'multi_cause':'maroon'}\n",
    "model_names = {'spf':'mSPF', 'naive':'Naive', 'multi_cause':'PIF'}\n",
    "mse_results = {}\n",
    "for setting in settings:\n",
    "    for regime, config in regimes.items():\n",
    "        for model in ['naive', 'spf', 'multi_cause']:\n",
    "            n_exp = len(exp_results[config][model])\n",
    "            mse = np.zeros(n_exp)\n",
    "            for i in range(n_exp):\n",
    "                beta_predicted = exp_results[config][model][i][0]\n",
    "                truth = exp_results[config][model][i][1]\n",
    "                if setting == \"high\":\n",
    "                    mask = [truth >= 1]\n",
    "                else:\n",
    "                    mask = [truth < 0.00001]\n",
    "                sq_err = (beta_predicted[mask] - truth[mask]) ** 2\n",
    "                mse[i] = sq_err.mean()\n",
    "                \n",
    "            mse_results[(model, regime)] = (mse.mean(), mse.std())\n",
    "    for comparison in ['naive', 'spf']:\n",
    "        fig, ax = plt.subplots()\n",
    "        index = np.arange(len(regimes.keys()))\n",
    "        bar_width = 0.2\n",
    "        \n",
    "        means_compare = [mse_results[(comparison, 'low')][0], mse_results[(comparison, 'med')][0],\n",
    "                        mse_results[(comparison, 'high')][0]]\n",
    "        stderr_compare = [mse_results[(comparison, 'low')][1], mse_results[(comparison, 'med')][1],\n",
    "                        mse_results[(comparison, 'high')][1]]\n",
    "        comparator = plt.bar(index, means_compare, bar_width,\n",
    "        color=model_colors[comparison],\n",
    "        label=model_names[comparison],\n",
    "        yerr=stderr_compare)\n",
    "        \n",
    "        means_method = [mse_results[('multi_cause', 'low')][0], mse_results[('multi_cause', 'med')][0],\n",
    "                        mse_results[('multi_cause', 'high')][0]]\n",
    "        stderr_method = [mse_results[('multi_cause', 'low')][1], mse_results[('multi_cause', 'med')][1],\n",
    "                        mse_results[('multi_cause', 'high')][1]]\n",
    "        main_method = plt.bar(index + bar_width, means_method, bar_width,\n",
    "        color=model_colors['multi_cause'],\n",
    "        label=model_names['multi_cause'],\n",
    "        yerr=stderr_method)\n",
    "\n",
    "        plt.xlabel('Confounding')\n",
    "        plt.ylabel('Squared Error')\n",
    "        plt.title(settings[setting])\n",
    "        plt.xticks(index + bar_width, ('Low', 'Medium', 'High'))\n",
    "        plt.legend()\n",
    "\n",
    "        plt.tight_layout()\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## pairwise comparison boxplots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "high low naive 0.00633826148690636\n",
      "high low spf 0.004476397591732014\n",
      "high low multi_cause 0.0036947964267469175\n",
      "high med naive 0.0094319600687437\n",
      "high med spf 0.004171749964171437\n",
      "high med multi_cause 0.004407276347996018\n",
      "high high naive 0.013459781462107002\n",
      "high high spf 0.004334318023987244\n",
      "high high multi_cause 0.006468050023822535\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    },
    {
     "data": {
      "image/png": "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k08+ASA/P58DBw5QXV3NRx99xIABAxo56ubpnnvuYevWrQDs2rWLrl270qpVK0pKSnj55Zd54403yMjIoH///qSmplJRUcHMmTN59dVXSU9P54orrqjT9fbt20diYiKZmZl89tlnHD58mA0bNjBixAg2bNhgxi22WEVFRcTGxnr8O1dlZSXJycm89NJLZGRkYLV6Dta0bduWd955h9mzZ7NixYqGDN2nKIH4mE8++YThw4cTGBiI1Wpl1KhR5OXlMXDgQPLy8igtLQXOjNd++eWX7Nixg0GDBjVy1M3TXXfdxY4dO3A6nfz1r3/lnnvuAeCKK67gyJEjJCQkEBsby9q1a/n666/Zt28fdrudzp07AzBy5Mg6Xa9Dhw7cfPPN+Pn5ERYWRr9+/QC45pprOHHiRP3eXAtnt9vJzMz0+Heur776iquvvppu3boBEB8f71E/ZMgQALp06eLufbZEmgPxMU6n84JtVVVVdOzYEafTSU5ODrfeeisdOnTgk08+4csvv6R3796NEGnz16ZNG7p160ZBQQGffPIJTz/9NFu2bKG6uppbb72V1157DYDTp09z6tQpvv32W85dHeHs3Mm5LBaLxz6VlZXunwMCAjz2vdjx0jD8/f0v+n/x3Ho4054tmXogPiYiIoLNmzdTXl5OVVUVf/rTn4iIiAAgKiqKtLQ0br/9diIiInjzzTe55ZZb9IfGRPfccw8vv/wy3bt3dw9jnD59mn/+85/85z//AWDlypUsWrSIrl27cvToUfbu3QvA5s2bLzhfu3btOHjwIKdPn+b48eMUFBQ03M1Ird1www2cOHGCffv2AWeW55YLqQfSyPLz8z16EDExMQwcOJBRo0ZRVVVF//79eeCBBwAYOHAgq1ev5qc//SlBQUFUVlZq+MpkgwYNIiUlhWnTprm3dejQgQULFvDkk0/idDoJDQ3lpZdeolWrVixevJikpCSsVis333zzBee78cYbGTBgAMOHD6dTp0789Kc/bcjbkVoKCAhg0aJFzJgxAz8/P66//vo6z2m1BFqRUETkPE6nk9TUVCZPnkxQUBCrV6+msLDQ/QktOUM9EBGR8/j5+RESEkJ8fDytWrWiU6dO+i7PRagHIiIihmgSXUREDFECERERQ5RARETEECUQERExRAlEREQMUQIRERFD/h9iVFAoXABhMAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEJCAYAAAC61nFHAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAIABJREFUeJzt3Xtc1HXe///HcDIQC80ZMPdWm7mrCZq2VkgFmialsihSeUhsSzp9TbMWsvCQG6mXkWaW1LatXuuqqS3BcuUiZQe7gtqga9M8dbntlpoxo2iKgRxmfn/4ay5HxYEPfGCA5/1283bj/Xl/Dq/PvJHXvN/vmc/b4nK5XIiIiDSSX2sHICIibZMSiIiIGKIEIiIihiiBiIiIIUogIiJiiBKIiIgYogQiPqdPnz6Ul5d7bMvJyeGBBx4AYPny5eTm5l7wHGfub+R6Z6uoqGDChAmMHj2aVatWMWjQoAaduzWc734KCgqYMmVKK0Uk7VVAawcg0lgzZ85s8Wvu3r2bI0eO8M4773DgwAFefPHFFo9BxNcogUibM3v2bH7xi19w33338eGHH5KVlYWfnx9XX301RUVFrFu3DgCHw8H999/PoUOH8Pf35/nnn+eqq66q97wHDhzgnnvuIS4uji+++ILjx4+TlpbGVVddxVNPPUVZWRmJiYksXbrUfcyKFSs4evQo8+bNO6d84sQJnn32Wb766itqamoYMmQI6enpBAQE0L9/f+6//34+/vhj7HY706ZNY9KkSQC8+uqrvPXWWwQEBHDFFVewePFiunTpwqZNm1i/fj1Op5OwsDDmzp17wfupzz//+U8yMjKorq7G5XKRnJzM5MmTAcjOzqawsBCn00nPnj2ZP38+4eHhTJkyhUsuuYSvv/6aiRMnEh4eTnZ2NhaLBX9/f9LT07nuuusaHYu0bRrCEp80depUEhMT3f/O947/6NGjpKen89xzz5GXl8cNN9xAWVmZu37//v1kZGSQn5/P4MGDef31171ed//+/dx00028+eabPP744yxcuJBevXqRmZnJ5ZdfTl5eHp06dWrQPSxcuJDIyEhycnLIzc3l6NGjrFq1CoDq6mq6du3KG2+8wYsvvsiiRYs4deoUW7duJScnhw0bNvBf//Vf/OxnP+PPf/4zf//738nNzWXt2rXk5uYybdo0pk+f3sBX09Prr7/OLbfcQk5ODr///e8pKSnB6XSSm5vLV199xaZNm8jLyyMuLo45c+a4j7v44ovZvHkzU6ZMYcmSJcyfP5+cnBxmzpzJp59+aigWadvUAxGf9J//+Z9069bNXc7JyWHLli0e+5SUlHDVVVfRt29fAMaNG0dmZqa7fsCAAVxxxRUAXH311bzzzjterxsYGEhcXBwA/fr149ixY4bv4YMPPmDHjh28+eabAFRVVXnUDx8+HIDIyEiqq6v58ccfKS4u5rbbbuOSSy4B4MknnwRgyZIlfPPNN0yYMMF9/PHjxzl27BhhYWEe57VYLOfE4nQ68fM7/X7x1ltv5YknnmD79u0MGTKEOXPm4Ofnx/vvv8+OHTsYP368+5jKykr3OQYPHuz+efTo0UyfPp24uDhuvPFGUlNTjb1I0qYpgUib5e/vz9mPcvvpjyRAQMD//XpbLJZz9j2fwMBA9znO94f4bGeft6amxv2z0+lk+fLl7mGm48ePe5zzp57MT9tcLhf+/v4e+xw/fpzjx4/jdDpJTEwkLS3NfW673e5ONGfq2rUrx44d80jAR44ccSeaYcOGsWXLFoqKiiguLubll18mJycHp9PpMZRWXV3NDz/84D5HSEiI++dZs2Yxfvx4Pv74Y3JycvjjH//oTpTScWgIS9qsa6+9ln//+9/s2bMHgC1btpzzR9psXbt2ZefOnbhcLioqKnj//ffddTfddBOrV6/G5XJRXV3NQw89xJ///OcLni8mJoZ33nmHiooK4PScyurVq7npppt4++23sdvtAKxfv56pU6ee9xyxsbGsWbMGp9MJwA8//MBbb73l7lk9/vjjbN68mdGjRzN//nxCQ0P59ttv3UN3P117+fLlpKenn3P+2tpabrnlFiorK5k4cSLz589n7969VFdXN/LVk7ZOPRBps8LCwli6dClPPPEEfn5+REVFERAQQHBwcIvF8Otf/5qPPvqIkSNHEh4ezvXXX+/ukWRkZPDss8+SkJBATU0NMTExTJs27YLni4uLY9++fUycOBGA3r1788wzzxAaGkpqair33nsvFouF0NBQXnrppfMmy4yMDBYvXsyYMWPw9/cHIDExkXHjxgHw8MMPk5GRwYYNG/D392fEiBFcd911DB48mLKyMu68804sFgs9evRg8eLF55w/ICCAp556it/+9rcEBARgsVhY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cyfbtm1j2LBhrRx1+3TLLbewbds2nE4nf/vb37j99tsBuOiiizh06BApKSkkJiaydu1avvnmG/bu3YvNZuOqq64CYNy4cY26Xvfu3enXrx9+fn5EREQwZMgQAC677DKOHz/evDfXwdlsNvLy8jz+nemrr77i0ksvpW/fvgAkJyd71I8YMQKA3r17u3ufHZHmQHyM0+k8Z1ttbS09evTA6XRSWFjItddeS/fu3fnkk0/YuXMngwYNaoVI27/OnTvTt29fSktL+eSTT3j88cfZvHkzdXV1XHvttbzyyisAnDp1ipMnT/Ldd99x5uoIP82dnMlisXjsU1NT4/45KCjIY9/zHS8tw9/f/7z/F8+sh9Pt2ZGpB+JjoqOjefvtt6mqqqK2tpa//OUvREdHAxAbG0t2djbXX3890dHRrFmzhmuuuUZ/aEx0++238/zzzxMVFeUexjh16hT/+Mc/+Ne//gXAypUrWbJkCX369OHw4cPs2bMHgLfffvuc83Xt2pX9+/dz6tQpjh07RmlpacvdjDRYr169OH78OHv37gVOL88t51IPpJWVlJR49CASEhIYOnQo48ePp7a2lptuuom7774bgKFDh7Jq1Sp+9atfERISQk1NjYavTDZs2DAyMjKYOXOme1v37t1ZuHAhjz76KE6nk/DwcJ577jkCAwNZunQpaWlpBAQE0K9fv3PO94tf/IK4uDhGjx5Nz549+dWvftWStyMNFBQUxJIlS3jiiSfw8/PjyiuvbPScVkegFQlFRM7idDrJyspi+vTphISEsGrVKsrKytyf0JLT1AMRETmLn58fYWFhJCcnExgYSM+ePfVdnvNQD0RERAzRJLqIiBiiBCIiIoYogYiIiCFKICIiYogSiIiIGKIEIiIihvx/bSRUYHyL+5IAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "low low naive 0.004278614642257223\n",
      "low low spf 3.004031104147739e-08\n",
      "low low multi_cause 3.987773502714772e-06\n",
      "low med naive 0.005944691653200599\n",
      "low med spf 1.574287989530892e-07\n",
      "low med multi_cause 1.4427956187878678e-05\n",
      "low high naive 0.0073873935490947175\n",
      "low high spf 6.391922202491082e-07\n",
      "low high multi_cause 9.28774752784381e-06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    },
    {
     "data": {
      "image/png": "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cw0+Pj6EhYXRrVs3AP7yl79w7Nix2l05L2exWMjMzKzy73Tff/89LVu2pH379gAMHTq0Sn+/fv0AaNu2rXPr0xvpGIiHsdvtZ02z2Wy0bt0au93O+vXr6dKlC61atWLLli18++23REVF1UOll76goCDat2/P9u3b2bJlC//85z9ZvXo1lZWVdOnShddeew2AkydPcvz4cX799VdOfzrCn8dOTmcymaq8pqKiwvlzQEBAldeea36pG76+vuf8v3h6P/wxnt5MWyAeJjo6mlWrVlFeXo7NZuPDDz8kOjoagJiYGDIyMrjxxhuJjo7m/fff59prr9UXjRvdcsstvPTSS3Ts2NG5G+PkyZN8/fXX/PTTTwDMnz+ftLQ0IiIiKCoqIj8/H4BVq1adtbzLLruMX375hZMnT3L06FG2b99edysjF+yqq67i2LFj7NmzB4CsrKx6rsgzaQuknuXm5lbZgoiPj6d3797cfvvt2Gw2evTowb333gtA7969WbBgAddddx2BgYFUVFRo95Wb9enTh+TkZMaMGeOc1qpVK2bMmMHYsWOx2+2Ehoby4osv4u/vz6xZs5gwYQJ+fn5cc801Zy3vb3/7G7169WLQoEGEh4dz3XXX1eXqyAUKCAggLS2NiRMn4uPjw1//+tcaH9PyBnoioYjIGex2O+np6YwePZrAwEAWLFhAQUGB8wwt+YO2QEREzuDj40NISAhDhw7F39+f8PBwXctzDtoCERERQ3QQXUREDFGAiIiIIQoQERExRAEiIiKGKEBERMQQBYiIiBjy/wETXE64aui6kQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    },
    {
     "data": {
      "image/png": "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ZrD84x//aIg6RESkmbAZLMuXL2+IOkREpJlws7XAzTffzJo1awgODsbLy8s6v2fPng4tTEREnJPNYPnyyy/58ssv2bZtm3WewWBg586dDi1MRESck81g2bVrV0PUISIizYTNYDl37hyJiYns3r2bqqoqfvvb3xIfH4+Pj09D1CciIk7G5sX7hIQEfv75Z1atWsXq1asxGAwsXry4IWoTEREndF3XWP7+979bp5csWUJERIRDixIREedl84iluroas9lsnTabzbi6ujq0KBERcV42j1hCQkKIiYlhwoQJAGzevJn+/fs7vDAREXFOBovFYrnWAlVVVaxZs4bdu3dTXV3NwIEDeeyxx2jVqlVD1Wg3xcXlmM3X3F2nEhDgS2FhWWOXIfWgvnNuLaX/XFwMtG9f9xu1bB6xzJ8/n8TERJ544ok6bzw9PZ01a9ZQVVXF1KlTmTRpUo32I0eOEB8fz9mzZwkODmbRokW4ublx4sQJYmNjKS4u5sYbbyQpKQlvb29yc3NZsGAB586do23btjz//PN06dKlznWJiIjj2LzGcuTIEWwc1FxVfn4+y5cv5+233yY1NZUtW7aQm5tbY5nY2FgWLlzIBx98gMViYevWrQAsWrSIiRMnkpmZSa9evVi9erV1/mOPPcbf//53Ro4cSXJycp3rEhERx7IZLEajkYiICObNm8eSJUusP7bs3buXkJAQ/Pz88PLyIjw8nMzMTGt7Xl4elZWVBAUFARAVFUVmZiYmk4msrCzCw8NrzAfYuHEjYWFhmM1mTpw4QZs2beq10yIi4jg2T4X17duXvn371nnDBQUFBAQEWKeNRiOHDh2qtT0gIID8/HxKS0vx8fHBzc2txnwANzc3zpw5w8iRI6msrOStt96qc10iIuJYNoPlhx9+IDExsc4bNpvNGAwG67TFYqkxXVv75csBNabbtGnDJ598wu7du5kxYwY7d+687tuf63MRqqkLCPBt7BKkntR3zk39VzubwZKTk3PVP/a2dOrUiezsbOt0YWEhRqOxRnthYaF1uqioCKPRiL+/P2VlZVRXV+Pq6lpjvYyMDEaMGIHBYCAsLIzKykpOnz6Nv7//ddWku8KkqVDfObeW0n8OuyssICCAiIgIbr/9dry9va3zFyxYcM31QkNDWblyJSUlJXh6erJjx44aQ8F06dKFVq1aceDAAfr160da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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/split_boxplots/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = {'low':(2., 2.), 'med':(20., 20.), 'high':(100., 100.)}\n",
    "settings = {'high':\"High Influence Users\", 'low':\"Low Influence Users\"}\n",
    "mse_results = {}\n",
    "for setting in settings:\n",
    "    for regime, config in regimes.items():\n",
    "        for model in ['naive', 'spf', 'multi_cause']:\n",
    "            per_user_mse = []\n",
    "            predicted = []\n",
    "            true_influence = []\n",
    "            for i in range(len(exp_results[config][model])):\n",
    "                beta_predicted = exp_results[config][model][i][0]\n",
    "                truth = exp_results[config][model][i][1]\n",
    "                mses = (beta_predicted - truth) ** 2\n",
    "\n",
    "                true_influence += list(truth)\n",
    "                per_user_mse += list(mses) \n",
    "                predicted += list(beta_predicted)\n",
    "\n",
    "            true_influence = np.array(true_influence)\n",
    "            per_user_mse = np.array(per_user_mse)\n",
    "            if setting == \"high\":\n",
    "                mask = [true_influence >= 2]\n",
    "            else:\n",
    "                mask = [true_influence < 0.01]\n",
    "            print(setting, regime, model, np.median(per_user_mse[mask]))\n",
    "            mse_results[(model, regime)] = per_user_mse[mask]\n",
    "    for comparison in ['naive', 'spf']:\n",
    "        bp1 = plt.boxplot([mse_results[(comparison, 'low')], mse_results[('multi_cause', 'low')],\n",
    "                    mse_results[(comparison, 'med')], mse_results[('multi_cause', 'med')], \n",
    "                    mse_results[(comparison, 'high')], mse_results[('multi_cause', 'high')]],\n",
    "                    positions=[1,1.5, 2.5,3, 4,4.5],\n",
    "                    widths=0.2,\n",
    "                    showfliers=False, patch_artist=True,\n",
    "                    showmeans=True)\n",
    "        axes = plt.axes()\n",
    "        colors = ['slategrey', 'maroon'] if comparison=='naive' else ['navy', 'maroon'] \n",
    "        for b_idx in range(6):\n",
    "            for item in ['boxes']:\n",
    "                mod = 2\n",
    "                c = colors[b_idx % mod]\n",
    "                plt.setp(bp1[item][b_idx], color=c)\n",
    "        axes.set_xticklabels(['Low', 'Medium', 'High'])\n",
    "        axes.set_xticks([1.2, 2.7, 4.2])\n",
    "        plt.setp(bp1['medians'], color='white')\n",
    "\n",
    "        model = plt.plot([1,1], c=colors[1], label='PIF')\n",
    "        if comparison == 'spf':\n",
    "            comp = plt.plot([1,1], c=colors[0], label='mSPF')\n",
    "        else:\n",
    "            comp = plt.plot([1,1], c=colors[0], label='Naive')\n",
    "        plt.legend()\n",
    "        plt.ylabel(\"Squared Error\")\n",
    "        ymax = 0.17 if setting=='high' else 0.05\n",
    "        ymin = -0.005\n",
    "        if setting == 'low' and comparison == 'spf':\n",
    "            ymax = 0.005\n",
    "            ymin = 0.\n",
    "        plt.ylim((ymin, ymax))\n",
    "        plt.title(settings[setting])\n",
    "        plt.show()\n",
    "#         plt.savefig(outdir + 'setting=' + setting + ';comparison=' +comparison +'.pdf')\n",
    "        plt.clf()\n",
    "        axes.clear()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### trying out boxplot but per experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n",
      "/anaconda3/lib/python3.6/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "outdir = '../doc/aistats20/img/homophily_plots/'\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "from scipy.stats import gaussian_kde\n",
    "regimes = {'low':(2., 2.), 'med':(20., 20.), 'high':(100., 100.)}\n",
    "settings = {'high':\"High Influence Users\", 'low':\"Low Influence Users\"}\n",
    "for setting in settings:\n",
    "    mse_results = {}\n",
    "    for regime, config in regimes.items():\n",
    "        for model in ['naive', 'spf', 'multi_cause']:\n",
    "            n_exp = len(exp_results[config][model])\n",
    "            mse = np.zeros(n_exp)\n",
    "            for i in range(n_exp):\n",
    "                beta_predicted = exp_results[config][model][i][0]\n",
    "                truth = exp_results[config][model][i][1]\n",
    "                if setting == \"high\":\n",
    "                    mask = [truth >= 1]\n",
    "                else:\n",
    "                    mask = [truth < 0.01]\n",
    "                sq_err = (beta_predicted[mask] - truth[mask]) ** 2\n",
    "                mse[i] = sq_err.mean()\n",
    "            mse_results[(model, regime)] = mse\n",
    "    \n",
    "    \n",
    "    bp = plt.boxplot([mse_results[('naive', 'low')], mse_results[('spf', 'low')] ,mse_results[('multi_cause', 'low')],\n",
    "                mse_results[('naive', 'med')],mse_results[('spf', 'med')], mse_results[('multi_cause', 'med')],\n",
    "                mse_results[('naive', 'high')], mse_results[('spf', 'high')], mse_results[('multi_cause', 'high')]],\n",
    "                positions=[3, 4,5, 8,9,10, 13,14,15],\n",
    "                showfliers=False, patch_artist=True)\n",
    "\n",
    "    colors = ['slategrey', 'navy', 'maroon']\n",
    "    for b_idx in range(9):\n",
    "        for item in ['boxes']:\n",
    "            c = colors[b_idx % 3]\n",
    "            plt.setp(bp[item][b_idx], color=c)\n",
    "    axes = plt.axes()\n",
    "    axes.set_xticklabels(['Low', 'Medium', 'High'])\n",
    "    axes.set_xticks([4, 9, 14.5])\n",
    "    plt.setp(bp['medians'], color='white')\n",
    "    \n",
    "    model = plt.plot([40,40], c=colors[2], label='PIF')\n",
    "    comp1 = plt.plot([40,40], c=colors[1], label='mSPF')\n",
    "    comp2 = plt.plot([40,40], c=colors[0], label='Naive')\n",
    "#     plt.legend()\n",
    "    plt.ylabel(\"Squared Error\")\n",
    "    ymin = -1 if setting =='high' else 0.04\n",
    "    ymax= 10. if setting=='high' else 0.08\n",
    "    plt.ylim((ymin, ymax))\n",
    "    plt.title(settings[setting])\n",
    "#     plt.show()\n",
    "    plt.savefig(outdir + 'setting=' + setting +'.pdf')\n",
    "    plt.clf()\n",
    "    axes.clear()"
   ]
  },
  {
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
