{
 "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\n",
    "from scipy import sparse\n",
    "from scipy.stats import gamma\n",
    "from scipy.stats import ttest_ind"
   ]
  },
  {
   "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_most_least_influential(Beta, most_thresh=0.5, least_lb=1e-3, least_ub=1e-2):\n",
    "    least = (Beta > least_lb) & (Beta < least_ub)\n",
    "    most = Beta > most_thresh\n",
    "    return least, most"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "pokec_out = '../pokec_mixture_sim_out/'\n",
    "num_exps = 10\n",
    "models = ['inf_only', 'pif', 'spf', 'naive']\n",
    "confounding_strength = (5., 5.)\n",
    "probs = np.arange(0., 1.1, step=0.1)\n",
    "exp_results = {}\n",
    "for i in range(1,num_exps+1):\n",
    "    for model in models:\n",
    "        for p in probs:\n",
    "            (u_c, i_c) = confounding_strength\n",
    "            f_name = 'u_conf=' + str(u_c) + ';i_conf=' + str(i_c) + ';p=' + str(p) +'_fitted.gz'\n",
    "            truth_fname = 'u_conf=' + str(u_c) + ';i_conf=' + str(i_c) +';p=' + str(p) + '_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 p in exp_results:\n",
    "                if model in exp_results[p]:\n",
    "                    exp_results[p][model].append((params, truth))\n",
    "                else:\n",
    "                    exp_results[p][model]= [(params, truth)]\n",
    "            else:\n",
    "                exp_results[p] = {model:[(params, truth)]}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prob: 0.000000\n",
      "Model: spf\n",
      "Mean MSE: 0.29516054591717616 and st dev.: 0.448486395083464\n",
      "Mean MSE for most influential: 10.664371881553198 and st dev.: 20.428390435110384\n",
      "Mean MSE for less influential: 0.04493674632661861 and st dev.: 0.01789933012848364\n",
      "------------------------------------------------------------\n",
      "Prob: 0.000000\n",
      "Model: pif\n",
      "Mean MSE: 0.06328427911531877 and st dev.: 0.020513124924144224\n",
      "Mean MSE for most influential: 0.5817845346051792 and st dev.: 0.7320988082485063\n",
      "Mean MSE for less influential: 0.06335799924766236 and st dev.: 0.03393956586228742\n",
      "------------------------------------------------------------\n",
      "Prob: 0.000000\n",
      "Model: naive\n",
      "Mean MSE: 0.13200790727904668 and st dev.: 0.22395973260757598\n",
      "Mean MSE for most influential: 4.152537043499158 and st dev.: 10.997292501156931\n",
      "Mean MSE for less influential: 0.05069592511001468 and st dev.: 0.01981294241774108\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.100000\n",
      "Model: spf\n",
      "Mean MSE: 0.13109286986457527 and st dev.: 0.12543150820794152\n",
      "Mean MSE for most influential: 3.2008021533936435 and st dev.: 4.592332532285142\n",
      "Mean MSE for less influential: 0.048507367400967276 and st dev.: 0.018886755040504383\n",
      "------------------------------------------------------------\n",
      "Prob: 0.100000\n",
      "Model: pif\n",
      "Mean MSE: 0.06351644379900381 and st dev.: 0.016111789179694407\n",
      "Mean MSE for most influential: 0.6394781615413302 and st dev.: 0.6455365471477692\n",
      "Mean MSE for less influential: 0.06746892491503355 and st dev.: 0.03480413210955383\n",
      "------------------------------------------------------------\n",
      "Prob: 0.100000\n",
      "Model: naive\n",
      "Mean MSE: 0.11566253801367321 and st dev.: 0.1810580724445878\n",
      "Mean MSE for most influential: 3.509182252410836 and st dev.: 9.333732738352358\n",
      "Mean MSE for less influential: 0.04499870036166854 and st dev.: 0.02409415954997372\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.200000\n",
      "Model: spf\n",
      "Mean MSE: 0.1432894969511908 and st dev.: 0.11468862213498407\n",
      "Mean MSE for most influential: 4.451105838082396 and st dev.: 5.36922409235349\n",
      "Mean MSE for less influential: 0.051491143822815555 and st dev.: 0.01803354684717492\n",
      "------------------------------------------------------------\n",
      "Prob: 0.200000\n",
      "Model: pif\n",
      "Mean MSE: 0.05750497474222225 and st dev.: 0.012328474768169312\n",
      "Mean MSE for most influential: 0.3981047380777637 and st dev.: 0.4738877643893389\n",
      "Mean MSE for less influential: 0.06809349355963809 and st dev.: 0.035205838897266896\n",
      "------------------------------------------------------------\n",
      "Prob: 0.200000\n",
      "Model: naive\n",
      "Mean MSE: 0.10125510460442315 and st dev.: 0.14244213568496214\n",
      "Mean MSE for most influential: 2.761921322348793 and st dev.: 7.32446990207729\n",
      "Mean MSE for less influential: 0.05292591496930614 and st dev.: 0.026231720785711655\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.300000\n",
      "Model: spf\n",
      "Mean MSE: 0.1976409707530543 and st dev.: 0.20163686774257586\n",
      "Mean MSE for most influential: 7.264483474014351 and st dev.: 10.351112190046965\n",
      "Mean MSE for less influential: 0.05541182875460558 and st dev.: 0.020188871857644602\n",
      "------------------------------------------------------------\n",
      "Prob: 0.300000\n",
      "Model: pif\n",
      "Mean MSE: 0.05570516831128243 and st dev.: 0.008865416577193804\n",
      "Mean MSE for most influential: 0.33924273924391285 and st dev.: 0.34724757474201295\n",
      "Mean MSE for less influential: 0.06928626848441136 and st dev.: 0.03410774170851563\n",
      "------------------------------------------------------------\n",
      "Prob: 0.300000\n",
      "Model: naive\n",
      "Mean MSE: 0.08992297563342895 and st dev.: 0.11116622724492432\n",
      "Mean MSE for most influential: 2.2705147622095536 and st dev.: 6.00865271798752\n",
      "Mean MSE for less influential: 0.0567240681958455 and st dev.: 0.025148320249320684\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.400000\n",
      "Model: spf\n",
      "Mean MSE: 0.10967091214210252 and st dev.: 0.0828668757625012\n",
      "Mean MSE for most influential: 3.0724431104833068 and st dev.: 4.133594787306541\n",
      "Mean MSE for less influential: 0.056071686433233625 and st dev.: 0.021139678626471762\n",
      "------------------------------------------------------------\n",
      "Prob: 0.400000\n",
      "Model: pif\n",
      "Mean MSE: 0.053762061587434365 and st dev.: 0.00611923593348273\n",
      "Mean MSE for most influential: 0.2634110125002008 and st dev.: 0.24601860383236882\n",
      "Mean MSE for less influential: 0.0757681472377376 and st dev.: 0.03729774705453279\n",
      "------------------------------------------------------------\n",
      "Prob: 0.400000\n",
      "Model: naive\n",
      "Mean MSE: 0.07820218749992805 and st dev.: 0.07927925242968323\n",
      "Mean MSE for most influential: 1.6923213501529208 and st dev.: 4.506998620802057\n",
      "Mean MSE for less influential: 0.060160667757394905 and st dev.: 0.028177678896683923\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.500000\n",
      "Model: spf\n",
      "Mean MSE: 0.08557345320263035 and st dev.: 0.055371344140686896\n",
      "Mean MSE for most influential: 2.0943787308495185 and st dev.: 3.0356816260386643\n",
      "Mean MSE for less influential: 0.05323340706146312 and st dev.: 0.024162949944134298\n",
      "------------------------------------------------------------\n",
      "Prob: 0.500000\n",
      "Model: pif\n",
      "Mean MSE: 0.054461867646522444 and st dev.: 0.003794263245766587\n",
      "Mean MSE for most influential: 0.3237651359447499 and st dev.: 0.20008427356115813\n",
      "Mean MSE for less influential: 0.07326888727014204 and st dev.: 0.037898837940241216\n",
      "------------------------------------------------------------\n",
      "Prob: 0.500000\n",
      "Model: naive\n",
      "Mean MSE: 0.06948676236019757 and st dev.: 0.05526498144037219\n",
      "Mean MSE for most influential: 1.2582922376701056 and st dev.: 3.406685197335409\n",
      "Mean MSE for less influential: 0.06319394620310034 and st dev.: 0.034411287015435964\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.600000\n",
      "Model: spf\n",
      "Mean MSE: 0.06869344213962424 and st dev.: 0.02611567686204009\n",
      "Mean MSE for most influential: 1.3636002712486504 and st dev.: 1.6526529651374606\n",
      "Mean MSE for less influential: 0.05093678281040289 and st dev.: 0.026432418058470554\n",
      "------------------------------------------------------------\n",
      "Prob: 0.600000\n",
      "Model: pif\n",
      "Mean MSE: 0.053345213097147626 and st dev.: 0.0028417539069848867\n",
      "Mean MSE for most influential: 0.27131851527475154 and st dev.: 0.2146768671508572\n",
      "Mean MSE for less influential: 0.06424869994364793 and st dev.: 0.04005963707021177\n",
      "------------------------------------------------------------\n",
      "Prob: 0.600000\n",
      "Model: naive\n",
      "Mean MSE: 0.06273002877336077 and st dev.: 0.03476401470119909\n",
      "Mean MSE for most influential: 0.8711506367091708 and st dev.: 2.325949448277698\n",
      "Mean MSE for less influential: 0.06541976272138883 and st dev.: 0.03400442421889603\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.700000\n",
      "Model: spf\n",
      "Mean MSE: 0.09030221640686832 and st dev.: 0.03121828337461856\n",
      "Mean MSE for most influential: 3.125356729445488 and st dev.: 2.334247405030269\n",
      "Mean MSE for less influential: 0.05201906226602694 and st dev.: 0.026399102427728832\n",
      "------------------------------------------------------------\n",
      "Prob: 0.700000\n",
      "Model: pif\n",
      "Mean MSE: 0.05202399750761313 and st dev.: 0.0019735058288170198\n",
      "Mean MSE for most influential: 0.19847819567008396 and st dev.: 0.12775017353022766\n",
      "Mean MSE for less influential: 0.06120241728272861 and st dev.: 0.03945305446473463\n",
      "------------------------------------------------------------\n",
      "Prob: 0.700000\n",
      "Model: naive\n",
      "Mean MSE: 0.05936539407939766 and st dev.: 0.021021465266246837\n",
      "Mean MSE for most influential: 0.7232561525578928 and st dev.: 1.6490357460920302\n",
      "Mean MSE for less influential: 0.05781229805412834 and st dev.: 0.035055357926728266\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.800000\n",
      "Model: spf\n",
      "Mean MSE: 0.07698779134075691 and st dev.: 0.015274117474515405\n",
      "Mean MSE for most influential: 2.7356232785197494 and st dev.: 1.2070462546410141\n",
      "Mean MSE for less influential: 0.05191739575322944 and st dev.: 0.03414668006376094\n",
      "------------------------------------------------------------\n",
      "Prob: 0.800000\n",
      "Model: pif\n",
      "Mean MSE: 0.05125364534233201 and st dev.: 0.0023551025505765787\n",
      "Mean MSE for most influential: 0.13553037722709343 and st dev.: 0.04800773410260485\n",
      "Mean MSE for less influential: 0.05074797413243447 and st dev.: 0.03383005557794691\n",
      "------------------------------------------------------------\n",
      "Prob: 0.800000\n",
      "Model: naive\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean MSE: 0.05530718663616556 and st dev.: 0.009659635349868351\n",
      "Mean MSE for most influential: 0.33303923070101094 and st dev.: 0.8462938479932608\n",
      "Mean MSE for less influential: 0.058352066281556904 and st dev.: 0.02101047962818696\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 0.900000\n",
      "Model: spf\n",
      "Mean MSE: 0.05564109193376217 and st dev.: 0.003506142037488962\n",
      "Mean MSE for most influential: 1.522834299996002 and st dev.: 0.76518038669335\n",
      "Mean MSE for less influential: 0.05669452523434733 and st dev.: 0.028627606302576433\n",
      "------------------------------------------------------------\n",
      "Prob: 0.900000\n",
      "Model: pif\n",
      "Mean MSE: 0.05077213907667527 and st dev.: 0.0023885978685180796\n",
      "Mean MSE for most influential: 0.09866424675426293 and st dev.: 0.07587309801980696\n",
      "Mean MSE for less influential: 0.05388853963754033 and st dev.: 0.019018095314475736\n",
      "------------------------------------------------------------\n",
      "Prob: 0.900000\n",
      "Model: naive\n",
      "Mean MSE: 0.054297277297281885 and st dev.: 0.003990106604649804\n",
      "Mean MSE for most influential: 0.14078585071617175 and st dev.: 0.23708756065570488\n",
      "Mean MSE for less influential: 0.05893343049878865 and st dev.: 0.0313581657706431\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n",
      "Prob: 1.000000\n",
      "Model: spf\n",
      "Mean MSE: 0.04690953390362496 and st dev.: 0.0016167826547781902\n",
      "Mean MSE for most influential: 0.0 and st dev.: 0.0\n",
      "Mean MSE for less influential: 0.0 and st dev.: 0.0\n",
      "------------------------------------------------------------\n",
      "Prob: 1.000000\n",
      "Model: pif\n",
      "Mean MSE: 0.05082044527314757 and st dev.: 0.0024980420219490864\n",
      "Mean MSE for most influential: 0.0 and st dev.: 0.0\n",
      "Mean MSE for less influential: 0.0 and st dev.: 0.0\n",
      "------------------------------------------------------------\n",
      "Prob: 1.000000\n",
      "Model: naive\n",
      "Mean MSE: 0.05489067062560192 and st dev.: 0.002942944272087856\n",
      "Mean MSE for most influential: 0.0 and st dev.: 0.0\n",
      "Mean MSE for less influential: 0.0 and st dev.: 0.0\n",
      "------------------------------------------------------------\n",
      "------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "models = ['spf', 'pif','naive']\n",
    "probs = np.arange(0., 1.1, step=0.1)\n",
    "\n",
    "mean_mse_results = {m:[] for m in models}\n",
    "\n",
    "for p in probs:\n",
    "    for model in models:\n",
    "        print(\"Prob: %f\" % p)\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[p][model][i][0]\n",
    "            if p < 1.:\n",
    "                beta = (1-p)*(exp_results[p][model][i][1])\n",
    "                least, most = get_most_least_influential(beta)\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",
    "            else:\n",
    "                beta = np.zeros(beta_hat.shape[0])\n",
    "                all_mses.append(mse(beta, beta_hat))\n",
    "                most_mses.append(0.)\n",
    "                least_mses.append(0.)\n",
    "                \n",
    "        print(\"Mean MSE:\", np.mean(all_mses), \"and st dev.:\", np.std(all_mses))\n",
    "        print(\"Mean MSE for most influential:\", np.mean(most_mses), \"and st dev.:\", np.std(most_mses))\n",
    "        print(\"Mean MSE for less influential:\", np.mean(least_mses), \"and st dev.:\", np.std(least_mses))\n",
    "            \n",
    "        mean_mse_results[model].append(np.mean(all_mses))\n",
    "        \n",
    "        print('-'*60)\n",
    "    print('-'*60)"
   ]
  },
  {
   "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": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_axis = np.arange(0., 1.1, step=0.1)\n",
    "for key, val in mean_mse_results.items():\n",
    "    plt.plot(x_axis, val, label=key)\n",
    "plt.xlabel(\"Values of p\")\n",
    "plt.ylabel(\"Overall Mean MSE\")\n",
    "plt.legend()\n",
    "# plt.show()\n",
    "plt.savefig('../doc/aistats20/img/simulation.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prob: 0.000000\n",
      "Model: pif\n",
      "[19.15524316  0.80068723  0.78859357  0.92496098  1.80069466  1.43600252\n",
      " 10.37297387  0.60574345  4.52284026  5.22648009  2.80597129 22.90596882\n",
      "  0.6190143   1.69811219  0.98596743  1.57121312  2.18965951  1.49762474\n",
      "  6.5899903   4.41048991  1.17268037  1.16408612  7.35041999  2.17547261\n",
      "  9.45651389  2.3797412  15.27748543  0.74401975  9.80986095  1.30389576\n",
      "  1.37307955  7.47436691  8.10602192  0.69075805 20.80396095  2.50596695\n",
      "  5.32397143  5.3947368   2.8493605   4.66326483 17.36187205  2.89307115\n",
      "  4.22161975  2.64341919  0.50657539  0.83441251  8.71074065  0.66128218\n",
      "  2.0911476   0.81656888  7.31597601 20.64048178  2.73143798  1.18420273\n",
      "  2.2911588   4.26128948  2.46735435  1.1439226   1.32768887  1.8840295\n",
      "  6.65924193  4.30697537  1.89863371  8.25202421  2.08759108  0.78324647\n",
      "  0.73885574  2.16125118  0.70814328  2.58730597] [1.93086139e+01 7.89599975e-01 6.24583159e-04 8.62344825e-01\n",
      " 1.00000000e+00 1.00000000e+00 1.04317736e+01 5.66819197e-01\n",
      " 4.55516199e+00 5.12025272e+00 3.00335401e+00 2.25573668e+01\n",
      " 6.03742103e-01 1.75301196e+00 9.82048624e-01 1.61342855e+00\n",
      " 2.24446602e+00 1.51822300e+00 6.49786465e+00 3.93574712e+00\n",
      " 1.15041783e+00 1.00000000e+00 7.37339452e+00 2.12929654e+00\n",
      " 9.52915480e+00 2.33222512e+00 1.52295254e+01 7.63111799e-01\n",
      " 9.57910394e+00 1.27938969e+00 1.40758572e+00 7.57341110e+00\n",
      " 8.12768638e+00 5.65325211e-01 2.09073225e+01 2.45756973e+00\n",
      " 5.29852685e+00 5.46955614e+00 2.77697044e+00 4.67297123e+00\n",
      " 1.74512092e+01 2.93780156e+00 4.18896909e+00 2.54098333e+00\n",
      " 4.66619277e-01 8.16679211e-01 8.32718553e+00 6.37835870e-01\n",
      " 2.05408456e+00 7.82250208e-01 7.41835674e+00 2.05421906e+01\n",
      " 2.78915280e+00 1.16367488e+00 2.28354624e+00 4.21230077e+00\n",
      " 2.49611016e+00 1.16231283e+00 1.24228398e+00 1.86548989e+00\n",
      " 6.73736594e+00 4.35706643e+00 1.86626106e+00 8.33270272e+00\n",
      " 2.13019085e+00 6.75159875e-01 7.29820731e-01 2.14256877e+00\n",
      " 6.62531448e-01 2.55522165e+00]\n",
      "Prob: 0.100000\n",
      "Model: pif\n",
      "[17.23971884  0.72061851  0.70973422  0.83246488  1.6206252   1.29240227\n",
      "  9.33567649  0.5451691   4.07055624  4.70383208  2.52537416 20.61537193\n",
      "  0.55711287  1.52830097  0.88737069  1.41409181  1.97069356  1.34786227\n",
      "  5.93099127  3.96944092  1.05541233  1.04767751  6.615378    1.95792535\n",
      "  8.5108625   2.14176708 13.74973689  0.66961778  8.82887485  1.17350618\n",
      "  1.23577159  6.72693022  7.29541973  0.62168224 18.72356485  2.25537026\n",
      "  4.79157428  4.85526312  2.56442445  4.19693834 15.62568484  2.60376404\n",
      "  3.79945777  2.37907727  0.75097126  7.83966658  0.59515396  1.88203284\n",
      "  0.734912    6.58437841 18.5764336   2.45829418  1.06578246  2.06204292\n",
      "  3.83516053  2.22061891  1.02953034  1.19491999  1.69562655  5.99331773\n",
      "  3.87627783  1.70877034  7.42682179  1.87883198  0.70492182  0.66497017\n",
      "  1.94512606  0.63732896  2.32857538] [17.1264436   0.74066165  0.65260711  0.85461954  1.          1.\n",
      "  9.31464965  0.5643249   4.13257318  4.94583304  2.49720983 21.24793165\n",
      "  0.57053917  1.58102937  0.85584035  1.29528985  1.7411196   1.3386484\n",
      "  5.81752857  4.09766775  1.0387775   1.          6.77876464  1.91259169\n",
      "  8.45318593  2.13410036 13.49938376  0.62768486  9.05782553  1.07887813\n",
      "  1.14888245  6.76975999  7.60592821  0.54045014 19.0612026   2.26238993\n",
      "  4.69015535  4.90299793  2.56166488  4.18914213 15.70428349  2.62826866\n",
      "  3.77738358  2.21098633  0.68406201  6.82591717  0.59451863  1.79856725\n",
      "  0.75336418  6.6126355  18.5088537   2.49688687  0.94195389  2.08946414\n",
      "  3.75018989  2.20112755  1.01301602  1.16612643  1.69739113  5.98940095\n",
      "  3.81193453  1.71524836  7.34102694  1.78101367  0.68791677  0.61074077\n",
      "  1.86650589  0.65658608  2.30915571]\n",
      "Prob: 0.200000\n",
      "Model: pif\n",
      "[15.32419452  0.64054979  0.63087486  0.73996878  1.44055573  1.14880202\n",
      "  8.2983791   3.61827221  4.18118407  2.24477703 18.32477505  1.35848975\n",
      "  0.78877395  1.2569705   1.75172761  1.19809979  5.27199224  3.52839193\n",
      "  0.93814429  0.9312689   5.880336    1.74037809  7.56521111  1.90379296\n",
      " 12.22198835  0.5952158   7.84788876  1.04311661  1.09846364  5.97949353\n",
      "  6.48481753  0.55260644 16.64316876  2.00477356  4.25917714  4.31578944\n",
      "  2.2794884   3.73061186 13.88949764  2.31445692  3.3772958   2.11473535\n",
      "  0.66753     6.96859252  0.52902574  1.67291808  0.65325511  5.85278081\n",
      " 16.51238542  2.18515038  0.94736219  1.83292704  3.40903158  1.97388348\n",
      "  0.91513808  1.0621511   1.5072236   5.32739354  3.44558029  1.51890697\n",
      "  6.60161937  1.67007287  0.62659718  0.59108459  1.72900094  0.56651463\n",
      "  2.06984478] [15.29041649  0.6527242   0.55531642  0.71564364  1.          1.\n",
      "  8.10428591  3.55303953  4.31777049  2.34066239 19.13675933  1.28745117\n",
      "  0.79535203  1.16420686  1.51987045  1.23226727  5.15237809  2.70137239\n",
      "  0.87446328  1.          6.02678472  1.76352719  6.42255895  1.97950881\n",
      " 11.97477759  0.62807491  7.81056379  0.93007095  0.89417927  5.93304889\n",
      "  6.82277748  0.44591639 16.95744159  2.02154617  4.12977985  4.40644203\n",
      "  2.24741874  3.77585801 13.72626892  2.33185851  3.30250195  2.17241392\n",
      "  0.65466826  6.44922354  0.51759982  1.67209831  0.63685972  5.8950808\n",
      " 17.05220106  2.136835    0.87514935  1.76451487  3.47922728  1.9701395\n",
      "  0.8555507   1.14732533  1.49392649  5.19928793  3.51404066  1.44355677\n",
      "  6.87756317  1.7378946   0.60866609  0.58960554  1.66869398  0.52871136\n",
      "  1.98142539]\n",
      "Prob: 0.300000\n",
      "Model: pif\n",
      "[13.40867021  0.56048106  0.5520155   0.64747268  1.26048626  1.00520177\n",
      "  7.26108171  3.16598818  3.65853606  1.9641799  16.03417817  1.18867853\n",
      "  0.6901772   1.09984918  1.53276166  1.04833732  4.61299321  3.08734294\n",
      "  0.82087626  0.81486029  5.145294    1.52283083  6.61955972  1.66581884\n",
      " 10.6942398   0.52081383  6.86690266  0.91272703  0.96115568  5.23205684\n",
      "  5.67421534 14.56277266  1.75417687  3.72678     3.77631576  1.99455235\n",
      "  3.26428538 12.15331043  2.02514981  2.95513382  1.85039343  0.58408875\n",
      "  6.09751845  1.46380332  0.57159822  5.12118321 14.44833725  1.91200659\n",
      "  0.82894191  1.60381116  2.98290264  1.72714804  0.80074582  0.92938221\n",
      "  1.31882065  4.66146935  3.01488276  1.3290436   5.77641695  1.46131376\n",
      "  0.54827253  0.51719902  1.51287582  1.81111418] [13.45513711  0.47717387  0.54672692  0.62164909  1.          1.\n",
      "  7.06916569  3.13542085  3.66019207  2.0033135  16.69742083  1.24291401\n",
      "  0.66444673  0.96884076  1.53340142  0.97436218  4.60819445  2.81783824\n",
      "  0.83143147  1.          5.0870684   1.55924485  6.37168407  1.60038403\n",
      " 10.73354241  0.58116906  6.67644148  0.73509821  0.88788408  5.35623271\n",
      "  5.60777705 15.10398476  1.70900381  3.84280947  3.79537364  1.94180264\n",
      "  3.47478607 12.2578428   2.05708822  2.91553238  1.91332667  0.58145815\n",
      "  6.29323684  1.44560976  0.56192127  5.09682149 14.11012013  1.84972311\n",
      "  0.76896731  1.39842471  2.91626722  1.75903593  0.70957815  0.90388297\n",
      "  1.22014794  4.5314472   3.02791824  1.21023681  6.13045303  1.4868061\n",
      "  0.58586817  0.47892209  1.33155568  1.80612296]\n",
      "Prob: 0.400000\n",
      "Model: pif\n",
      "[11.49314589  0.55497659  1.0804168   0.86160151  6.22378432  2.71370416\n",
      "  3.13588805  1.68358277 13.74358129  1.01886731  0.59158046  0.94272787\n",
      "  1.31379571  0.89857485  3.95399418  2.64629395  0.70360822  0.69845167\n",
      "  4.410252    1.30528357  5.67390833  1.42784472  9.16649126  5.88591657\n",
      "  0.78233745  0.82384773  4.48462015  4.86361315 12.48237657  1.50358017\n",
      "  3.19438286  3.23684208  1.7096163   2.7979589  10.41712323  1.73584269\n",
      "  2.53297185  1.58605152  0.5006475   5.22644439  1.25468856  4.38958561\n",
      " 12.38428907  1.63886279  0.71052164  1.37469528  2.55677369  1.48041261\n",
      "  0.68635356  0.79661332  1.1304177   3.99554516  2.58418522  1.13918023\n",
      "  4.95121453  1.25255465  1.29675071  1.55238358] [11.67659383  0.58554368  1.          1.          6.1110936   2.88411878\n",
      "  3.35212318  1.73646706 14.13498188  1.07145423  0.61916096  1.01784866\n",
      "  1.34233673  0.8602118   3.86258166  1.73333782  0.71627256  1.\n",
      "  4.61285421  1.33559969  5.6987103   1.33679408  9.45189826  5.85143161\n",
      "  0.52955435  0.68520128  4.488403    4.60895135 12.60369866  1.57056214\n",
      "  2.94685524  3.28114278  1.7327807   2.98732203 10.29082809  1.62842123\n",
      "  2.66541223  1.37378426  0.41080109  4.32662351  1.29199338  4.30976316\n",
      " 11.57223975  1.64066857  0.56407656  1.11644443  2.58103737  1.50925171\n",
      "  0.61102112  0.83485899  1.07015024  3.78164921  2.6368108   1.0923295\n",
      "  5.15623762  1.26003329  1.15467717  1.51887137]\n",
      "Prob: 0.500000\n",
      "Model: pif\n",
      "[ 9.57762158  0.90034733  0.71800126  5.18648694  2.26142013  2.61324004\n",
      "  1.40298565 11.45298441  0.8490561   0.78560656  1.09482976  0.74881237\n",
      "  3.29499515  2.20524496  0.58634018  0.58204306  3.67521     1.08773631\n",
      "  4.72825694  1.1898706   7.63874272  4.90493047  0.65194788  0.68653977\n",
      "  3.73718346  4.05301096 10.40198047  1.25298348  2.66198571  2.6973684\n",
      "  1.42468025  2.33163241  8.68093602  1.44653558  2.11080987  1.3217096\n",
      "  4.35537032  1.0455738   3.65798801 10.32024089  1.36571899  0.59210137\n",
      "  1.1455794   2.13064474  1.23367717  0.5719613   0.66384444  0.94201475\n",
      "  3.32962096  2.15348768  0.94931686  4.12601211  1.04379554  1.08062559\n",
      "  1.29365299] [ 9.71365422  1.          1.          4.82734465  2.23674344  2.71509501\n",
      "  1.40187418 11.59258138  0.9080023   0.64910776  1.20431382  0.63992137\n",
      "  3.25847798  1.167854    0.59005244  1.          3.4123057   1.10410324\n",
      "  4.44391512  1.16718346  7.09650309  4.68298635  0.39633321  0.45357005\n",
      "  3.80996971  3.96633901 10.38844432  1.26891065  2.89044598  2.67658761\n",
      "  1.39689535  2.13668447  8.04937333  1.3364649   2.10865936  1.44588009\n",
      "  3.95235055  1.01928092  3.68621068 10.86970119  1.38738566  0.42877051\n",
      "  1.08024115  1.98806933  1.21238355  0.47658786  0.59966751  0.86478389\n",
      "  3.24318825  2.12426991  0.91835833  4.38067997  0.92501306  0.89550736\n",
      "  1.2049398 ]\n",
      "Prob: 0.600000\n",
      "Model: pif\n",
      "[7.66209726 0.72027787 0.57440101 4.14918955 1.8091361  2.09059204\n",
      " 1.12238852 9.16238753 0.67924488 0.62848525 0.8758638  0.5990499\n",
      " 2.63599612 1.76419597 2.940168   0.87018905 3.78260556 0.95189648\n",
      " 6.11099417 3.92394438 0.5215583  0.54923182 2.98974677 3.24240877\n",
      " 8.32158438 1.00238678 2.12958857 2.15789472 1.1397442  1.86530593\n",
      " 6.94474882 1.15722846 1.6886479  1.05736768 3.48429626 0.83645904\n",
      " 2.9263904  8.25619271 1.09257519 0.91646352 1.70451579 0.98694174\n",
      " 0.53107555 0.7536118  2.66369677 1.72279015 0.75945349 3.30080969\n",
      " 0.83503643 0.86450047 1.03492239] [7.62139256e+00 1.00000000e+00 1.00000000e+00 4.06219485e+00\n",
      " 1.77806577e+00 2.26426513e+00 1.06318705e+00 9.30660005e+00\n",
      " 7.21437326e-01 5.24789519e-01 8.00920509e-01 4.31541366e-01\n",
      " 2.65775456e+00 9.85434624e-01 2.81259577e+00 7.74419715e-01\n",
      " 3.33011933e+00 9.86094260e-01 6.07353146e+00 3.38050552e+00\n",
      " 3.78192879e-05 4.01123695e-01 3.08216258e+00 3.28210469e+00\n",
      " 7.95867085e+00 1.07615550e+00 1.94166583e+00 1.82711819e+00\n",
      " 1.21112910e+00 1.72661820e+00 7.29149363e+00 1.11483414e+00\n",
      " 1.51707738e+00 1.32415237e+00 9.55890555e-01 7.64142918e-01\n",
      " 2.81784819e+00 7.30033377e+00 1.09334976e+00 6.71788429e-01\n",
      " 1.78463181e+00 9.33609821e-01 5.54411412e-01 5.96049594e-01\n",
      " 2.69084517e+00 4.95684390e-05 6.42962906e-01 3.49185804e+00\n",
      " 7.37153758e-01 6.69956652e-01 1.00429111e+00]\n",
      "Prob: 0.700000\n",
      "Model: pif\n",
      "[5.74657295 0.5402084  3.11189216 1.35685208 1.56794403 0.84179139\n",
      " 6.87179064 0.50943366 0.65689785 1.97699709 1.32314697 2.205126\n",
      " 0.65264178 2.83695417 0.71392236 4.58324563 2.94295828 2.24231007\n",
      " 2.43180658 6.24118828 0.75179009 1.59719143 1.61842104 0.85480815\n",
      " 1.39897945 5.20856161 0.86792135 1.26648592 0.79302576 2.61322219\n",
      " 0.62734428 2.1947928  6.19214453 0.81943139 0.68734764 1.27838684\n",
      " 0.7402063  0.56520885 1.99777258 1.29209261 0.56959011 2.47560726\n",
      " 0.62627733 0.64837535 0.77619179] [5.48002808 1.         3.0545961  1.45518537 1.66888282 0.93315066\n",
      " 5.92950899 0.52757632 0.74492758 2.00505383 0.10931353 2.35584945\n",
      " 0.65682688 2.97752494 0.69520001 3.85562589 2.78505287 2.3811066\n",
      " 2.50549242 5.42891623 0.72959398 1.83934208 1.57638494 0.86813089\n",
      " 1.33622465 5.13548265 0.82054888 1.12907576 1.24602794 0.08101148\n",
      " 0.62067414 2.21178049 7.00562102 0.79510471 0.44360197 1.12342806\n",
      " 0.68394897 0.46672755 1.91051571 1.09873681 0.49295267 2.5967101\n",
      " 0.69318523 0.41539728 0.6963888 ]\n",
      "Prob: 0.800000\n",
      "Model: pif\n",
      "[3.83104863 2.07459477 0.90456805 1.04529602 0.56119426 4.58119376\n",
      " 1.31799806 0.88209798 1.470084   1.89130278 3.05549709 1.96197219\n",
      " 1.49487338 1.62120438 4.16079219 0.50119339 1.06479429 1.07894736\n",
      " 0.5698721  0.93265297 3.47237441 0.57861423 0.84432395 0.52868384\n",
      " 1.74214813 1.4631952  4.12809636 0.5462876  0.8522579  1.33184839\n",
      " 0.86139507 1.65040484 0.51746119] [3.12670139e+00 1.97383415e+00 8.44751121e-01 1.07764366e+00\n",
      " 5.80029363e-01 3.84039688e+00 1.38799310e+00 7.99519344e-04\n",
      " 1.55032529e+00 2.30097981e+00 2.84994675e+00 1.78393118e+00\n",
      " 1.51160539e+00 1.62085501e+00 4.26766965e+00 4.66418685e-01\n",
      " 1.03971941e+00 8.98633268e-01 5.99769077e-01 9.89973527e-01\n",
      " 3.26774087e+00 5.68925521e-01 7.43417976e-01 3.87499330e-01\n",
      " 6.84676764e-04 1.37875184e+00 4.06599462e+00 5.60611928e-01\n",
      " 8.38227579e-01 1.30555903e+00 9.94866926e-05 1.95718300e+00\n",
      " 4.71601933e-01]\n",
      "Prob: 0.900000\n",
      "Model: pif\n",
      "[1.91552432 1.03729739 0.52264801 2.29059688 0.65899903 0.735042\n",
      " 0.94565139 1.52774854 0.98098609 0.74743669 0.81060219 2.08039609\n",
      " 0.53239714 0.53947368 1.7361872  0.87107406 0.7315976  2.06404818\n",
      " 0.66592419 0.82520242] [1.66563337e+00 1.09502443e+00 5.07136052e-01 2.27090710e+00\n",
      " 9.57941190e-01 6.55542584e-01 1.05077271e+00 1.70407869e+00\n",
      " 5.79423708e-01 7.62987321e-01 8.54307138e-01 1.93913244e+00\n",
      " 3.18589996e-01 5.50858314e-01 1.62710568e+00 1.14832438e-03\n",
      " 5.75509824e-01 1.77367858e+00 4.95872367e-01 8.96463618e-01]\n",
      "Prob: 1.000000\n",
      "Model: pif\n",
      "[] []\n"
     ]
    }
   ],
   "source": [
    "models = ['pif']\n",
    "probs = np.arange(0., 1.1, step=0.1)\n",
    "\n",
    "mean_mse_results = {m:[] for m in models}\n",
    "\n",
    "for p in probs:\n",
    "    for model in models:\n",
    "        print(\"Prob: %f\" % p)\n",
    "        print(\"Model:\", model)\n",
    "        all_mses = []\n",
    "        most_mses = []\n",
    "        least_mses = []\n",
    "        for i in range(1):\n",
    "            beta_hat = exp_results[p][model][i][0]\n",
    "            beta = (1-p)*(exp_results[p][model][i][1])\n",
    "            least, most = get_most_least_influential(beta)\n",
    "            print(beta[most], beta_hat[most])\n",
    "                "
   ]
  },
  {
   "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
