{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "32e72bb8-6a8d-475c-9432-612a24bff552",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pylab as plt\n",
    "\n",
    "import itertools\n",
    "import seaborn as sns\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "38eb3ec0-548b-40bb-b079-b5b17ee2c543",
   "metadata": {},
   "outputs": [],
   "source": [
    "from literal_listener import StatelessLiteralListener\n",
    "from literal_speaker import LiteralSpeaker\n",
    "from pragmatic_listener import PragmaticListener\n",
    "from learner import LearnerAgent\n",
    "\n",
    "from configuration import TRUE_REWARDS\n",
    "\n",
    "from visualizations import visualize_pragmatic_beliefs, plot_point_estimate"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e2b3a366-0dd4-4c9e-a4dc-a50e0bea6b99",
   "metadata": {},
   "source": [
    "# Cache Pragmatic Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1775498b-ee33-40ae-9909-63f4370398ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import time\n",
    "\n",
    "human_utterances = json.load(open(\"data/exp_utterances.json\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4bee6d5e-f975-41bb-9d33-e23f0e0537c0",
   "metadata": {},
   "source": [
    "## Pragmatic - Uncertain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c04c185b-1cb0-452b-906d-49468ed6ef5c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished utterance 0 of 2772, took 0.036 seconds.\n",
      "Finished utterance 500 of 2772, took 1.05 seconds.\n",
      "Finished utterance 1000 of 2772, took 0.992 seconds.\n",
      "Finished utterance 1500 of 2772, took 0.987 seconds.\n",
      "Finished utterance 2000 of 2772, took 0.983 seconds.\n",
      "Finished utterance 2500 of 2772, took 0.986 seconds.\n"
     ]
    }
   ],
   "source": [
    "n_trials = 25\n",
    "alphaS = 3\n",
    "n_iters = 5\n",
    "\n",
    "utterances_to_use = human_utterances\n",
    "prior_var = 5\n",
    "importance_samples = 100\n",
    "unique_str=\"-v4-ER\"\n",
    "\n",
    "\n",
    "exp_literal = StatelessLiteralListener()\n",
    "exp_speaker = LiteralSpeaker(exp_literal, utterances=\"exp\", alphaS=alphaS)\n",
    "exp_pragmatic_listener = PragmaticListener(exp_speaker)\n",
    "\n",
    "start_time_ms = round(time.time() * 1000)   \n",
    "\n",
    "for i, u in enumerate(utterances_to_use):\n",
    "\n",
    "    pragmatic = LearnerAgent.cache_pragmatic_thompson_sampling(exp_pragmatic_listener, u[\"utt\"], u[\"action_context\"], \n",
    "                                                               horizons=[1,2,4], workerid=u['workerid'],\n",
    "                                                               n_trials=n_trials, prior_var=prior_var, \n",
    "                                                               min_importance_samples=importance_samples, \n",
    "                                                               n_iterations=n_iters, verbose=False,\n",
    "                                                               unique_str=unique_str)\n",
    "\n",
    "    if i%500 == 0:\n",
    "        end_time_ms = round(time.time() * 1000)\n",
    "        n_seconds = (end_time_ms - start_time_ms) / 1000\n",
    "        print(f'Finished utterance {i} of {len(utterances_to_use)}, took {n_seconds} seconds.')\n",
    "        start_time_ms = end_time_ms"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a596a887-b278-4fe8-87a6-01bc1c420a66",
   "metadata": {},
   "source": [
    "## Pragmatic - Misaligned"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "878af297-7edd-42f7-88a8-cf634219c658",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished utterance 0 of 2772, took 0.003 seconds.\n",
      "Finished utterance 500 of 2772, took 1.064 seconds.\n",
      "Finished utterance 1000 of 2772, took 1.022 seconds.\n",
      "Finished utterance 1500 of 2772, took 1.005 seconds.\n",
      "Finished utterance 2000 of 2772, took 1.001 seconds.\n",
      "Finished utterance 2500 of 2772, took 1.004 seconds.\n"
     ]
    }
   ],
   "source": [
    "start_time_ms = round(time.time() * 1000)   \n",
    "\n",
    "for i, u in enumerate(utterances_to_use):\n",
    "\n",
    "    pragmatic = LearnerAgent.cache_pragmatic_thompson_sampling(exp_pragmatic_listener,\n",
    "                                                               u[\"utt\"], u[\"action_context\"], \n",
    "                                                               workerid=u['workerid'], unique_str=unique_str, \n",
    "                                                               prior_var=prior_var, min_importance_samples=importance_samples,\n",
    "                                                               n_iterations=n_iters, n_trials=n_trials, verbose=False,\n",
    "                                                               horizons=[1]) # This changes\n",
    "\n",
    "    if i%500 == 0:\n",
    "        end_time_ms = round(time.time() * 1000)\n",
    "        n_seconds = (end_time_ms - start_time_ms) / 1000\n",
    "        print(f'Finished utterance {i} of {len(utterances_to_use)}, took {n_seconds} seconds.')\n",
    "        start_time_ms = end_time_ms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2199fdf8-3097-47be-9179-0d9cc238597c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished utterance 0 of 2772, took 0.003 seconds.\n",
      "Finished utterance 500 of 2772, took 1.011 seconds.\n",
      "Finished utterance 1000 of 2772, took 1.018 seconds.\n",
      "Finished utterance 1500 of 2772, took 1.037 seconds.\n",
      "Finished utterance 2000 of 2772, took 1.012 seconds.\n",
      "Finished utterance 2500 of 2772, took 1.031 seconds.\n"
     ]
    }
   ],
   "source": [
    "start_time_ms = round(time.time() * 1000)   \n",
    "\n",
    "for i, u in enumerate(utterances_to_use):\n",
    "\n",
    "    pragmatic = LearnerAgent.cache_pragmatic_thompson_sampling(exp_pragmatic_listener,\n",
    "                                                               u[\"utt\"], u[\"action_context\"], \n",
    "                                                               workerid=u['workerid'], unique_str=unique_str, \n",
    "                                                               prior_var=prior_var, min_importance_samples=importance_samples,\n",
    "                                                               n_iterations=n_iters, n_trials=n_trials, verbose=False,\n",
    "                                                               horizons=[4]) # This changes\n",
    "\n",
    "    if i%500 == 0:\n",
    "        end_time_ms = round(time.time() * 1000)\n",
    "        n_seconds = (end_time_ms - start_time_ms) / 1000\n",
    "        print(f'Finished utterance {i} of {len(utterances_to_use)}, took {n_seconds} seconds.')\n",
    "        start_time_ms = end_time_ms"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c732e0cc-ff06-47a4-9190-b6ed7a3d77b4",
   "metadata": {},
   "source": [
    "## Pragmatic - Known"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "8a889de3-d9b3-4135-9a00-c48d8531b17f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished utterance 0 of 2772, took 0.002 seconds.\n",
      "Finished utterance 500 of 2772, took 1.006 seconds.\n",
      "Finished utterance 1000 of 2772, took 0.974 seconds.\n",
      "Finished utterance 1500 of 2772, took 0.948 seconds.\n",
      "Finished utterance 2000 of 2772, took 0.981 seconds.\n",
      "Finished utterance 2500 of 2772, took 0.989 seconds.\n"
     ]
    }
   ],
   "source": [
    "start_time_ms = round(time.time() * 1000)   \n",
    "\n",
    "for i, u in enumerate(utterances_to_use):\n",
    "    \n",
    "    pragmatic = LearnerAgent.cache_pragmatic_thompson_sampling(exp_pragmatic_listener,\n",
    "                                                               u[\"utt\"], u[\"action_context\"], \n",
    "                                                               workerid=u['workerid'], unique_str=unique_str, \n",
    "                                                               prior_var=prior_var, min_importance_samples=importance_samples,\n",
    "                                                               n_iterations=n_iters, n_trials=n_trials, verbose=False,\n",
    "                                                               horizons=[u[\"horizon\"]]) # This changes\n",
    "\n",
    "    if i%500 == 0:\n",
    "        end_time_ms = round(time.time() * 1000)\n",
    "        n_seconds = (end_time_ms - start_time_ms) / 1000\n",
    "        print(f'Finished utterance {i} of {len(utterances_to_use)}, took {n_seconds} seconds.')\n",
    "        start_time_ms = end_time_ms"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f867dd1c-f323-4619-a3a4-64af55c976ee",
   "metadata": {},
   "source": [
    "# Load cached results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "31a806b2-6af6-4374-9744-653b67dedc14",
   "metadata": {},
   "outputs": [],
   "source": [
    "from configuration import utt_to_string\n",
    "\n",
    "results = []\n",
    "\n",
    "pragmatics_list = [\"pragmatic_uncertain\", \n",
    "                   \"pragmatic_misaligned_conservative\", \n",
    "                   \"pragmatic_misaligned_pedagogic\", \n",
    "                   \"pragmatic_aligned\"]\n",
    "\n",
    "for i, u in enumerate(utterances_to_use):\n",
    "    \n",
    "    for pragmatics in pragmatics_list:\n",
    "        \n",
    "        if pragmatics == \"pragmatic_uncertain\":\n",
    "            horizons = [1, 2, 4]\n",
    "        elif pragmatics == \"pragmatic_aligned\":\n",
    "            horizons = [u[\"horizon\"]]\n",
    "        elif pragmatics == \"pragmatic_misaligned_conservative\":\n",
    "            horizons = [1]\n",
    "        elif pragmatics == \"pragmatic_misaligned_pedagogic\":\n",
    "            horizons = [4]\n",
    "        \n",
    "        pragmatic = LearnerAgent.cache_pragmatic_thompson_sampling(exp_pragmatic_listener,\n",
    "                                                                   u[\"utt\"], u[\"action_context\"], \n",
    "                                                                   workerid=u['workerid'], unique_str=unique_str, \n",
    "                                                                   prior_var=prior_var, min_importance_samples=importance_samples,\n",
    "                                                                   n_iterations=n_iters, n_trials=n_trials,\n",
    "                                                                   horizons=horizons) # This changes\n",
    "        pragmatic[\"listener\"] = pragmatics\n",
    "\n",
    "        pragmatic[\"alphaS\"] = alphaS\n",
    "        pragmatic[\"horizon\"] = u[\"horizon\"]\n",
    "\n",
    "        for k in [\"color\", \"shape\", \"feature\", \"value\", \"type\"]:\n",
    "            pragmatic[k] = u[\"utt\"].get(k)\n",
    "\n",
    "        utt_str = utt_to_string(u[\"utt\"])\n",
    "        pragmatic[\"utt\"] = utt_str\n",
    "        pragmatic[\"utt_key\"] = f'{u[\"action_context\"]}-{utt_str}'\n",
    "\n",
    "        pragmatic[\"trial_iteration_key\"] = pragmatic[\"iteration\"].apply(lambda x: f'{u[\"action_context\"]}-{u[\"workerid\"]}-{x}')\n",
    "\n",
    "        pragmatic[\"random_effects_key\"] = f'{u[\"action_context\"]}-{u[\"workerid\"]}'\n",
    "        results.append(pragmatic)    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "034a6524-dffb-453d-afba-855d764001a0",
   "metadata": {},
   "source": [
    "## Literal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "dca7f1f7-8f2a-4e55-8e5f-4fb9ed5c360a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished 5 iters on utterance 0.\n",
      "Finished 5 iters on utterance 500.\n",
      "Finished 5 iters on utterance 1000.\n",
      "Finished 5 iters on utterance 1500.\n",
      "Finished 5 iters on utterance 2000.\n",
      "Finished 5 iters on utterance 2500.\n"
     ]
    }
   ],
   "source": [
    "for i, u in enumerate(utterances_to_use):\n",
    "    \n",
    "    random_effects_key = f'{u[\"action_context\"]}-{u[\"workerid\"]}'\n",
    "        \n",
    "    literal = LearnerAgent.cache_literal_thompson_sampling(u[\"utt\"], unique_str=random_effects_key,\n",
    "                                                           n_iterations=n_iters, \n",
    "                                                           n_trials=n_trials, \n",
    "                                                           prior_var=prior_var,\n",
    "                                                           min_importance_samples=importance_samples,\n",
    "                                                           verbose=False)\n",
    "    \n",
    "    literal[\"listener\"] = \"literal\"\n",
    "    literal[\"utt\"] = utt_str\n",
    "\n",
    "    for k in [\"color\", \"shape\", \"feature\", \"value\", \"type\"]:\n",
    "        literal[k] = u.get(k)\n",
    "        \n",
    "    literal[\"trial_iteration_key\"] = literal[\"iteration\"].apply(lambda x: f'{u}-{x}')\n",
    "    literal['random_effects_key'] = random_effects_key\n",
    "    results.append(literal)  \n",
    "    \n",
    "    if i%500 == 0:\n",
    "        print(f'Finished {n_iters} iters on utterance {i}.')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "64b7261a-1132-4bd2-8ffa-8ffcbc24ce0d",
   "metadata": {},
   "source": [
    "## Individual Baseline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6329dda9-6008-4260-96b7-3004cd8492f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished 5 iters on utterance 0.\n",
      "Finished 5 iters on utterance 500.\n",
      "Finished 5 iters on utterance 1000.\n",
      "Finished 5 iters on utterance 1500.\n",
      "Finished 5 iters on utterance 2000.\n",
      "Finished 5 iters on utterance 2500.\n"
     ]
    }
   ],
   "source": [
    "for i, u in enumerate(utterances_to_use):\n",
    "    \n",
    "    random_effects_key = f'{u[\"action_context\"]}-{u[\"workerid\"]}'\n",
    "    \n",
    "    individual_learning_results = LearnerAgent.cache_individual_thompson_sampling(n_iterations=n_iters,  \n",
    "                                                                                  n_trials=n_trials, \n",
    "                                                                                  prior_var=prior_var, \n",
    "                                                                                  unique_str=random_effects_key)\n",
    "    \n",
    "    individual_learning_results[\"listener\"] = \"individual\"\n",
    "        \n",
    "    individual_learning_results[\"trial_iteration_key\"] = literal[\"iteration\"].apply(lambda x: f'{u}-{x}')\n",
    "    individual_learning_results['random_effects_key'] = random_effects_key\n",
    "    results.append(individual_learning_results)  \n",
    "    \n",
    "    if i%500 == 0:\n",
    "        print(f'Finished {n_iters} iters on utterance {i}.')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba2f1682-ec6f-49c3-b785-00ead08a2da7",
   "metadata": {},
   "source": [
    "## Plot Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1fa080c7-3012-466e-9bf7-048940a15b10",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = pd.concat(results)\n",
    "results[\"horizon\"] = results.horizon.fillna(\"N/A\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3713250a-319b-469c-acb9-a313d21bf1bb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "listener\n",
       "individual                           2772.0\n",
       "literal                              2772.0\n",
       "pragmatic_aligned                    2772.0\n",
       "pragmatic_misaligned_conservative    2772.0\n",
       "pragmatic_misaligned_pedagogic       2772.0\n",
       "pragmatic_uncertain                  2772.0\n",
       "Name: trial_iteration_key, dtype: float64"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Should have 2772 * 5 trials for each listener\n",
    "results.groupby([\"listener\"]).trial_iteration_key.nunique() / 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "de91a024-c1e3-4754-b8ce-e5d6474bbf1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy \n",
    "\n",
    "to_plot = copy.deepcopy(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e7b3749f-2494-41bc-a9db-9b5a9d6d8503",
   "metadata": {},
   "outputs": [],
   "source": [
    "rename_dict = {\"pragmatic_uncertain\": \"Pragmatic - Latent $H$\", \"literal\": \"Literal Listener\", \"individual\": \"Individual Learner\"}\n",
    "to_plot = to_plot[to_plot.listener.isin(list(rename_dict.keys()))]\n",
    "\n",
    "to_plot[\"listener\"] = to_plot.listener.apply(lambda x: rename_dict.get(x, x))\n",
    "hue_order = [\"Pragmatic - Latent $H$\", \"Literal Listener\", \"Individual Learner\"]\n",
    "palette = ['green', 'black', 'gray']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e1554760-40af-4544-80ee-698ec24da5b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'Individual Learning Actions')"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "sns.lineplot(data=to_plot, x='trial', y='future_rewards', hue='listener', hue_order=hue_order, palette=palette,\n",
    "             linewidth=3, alpha=.6)\n",
    "\n",
    "plt.ylim(.75, 1.8) \n",
    "plt.axhline(1.75, c='k', label=\"Optimal\", linestyle='--', linewidth=3, alpha=.6)\n",
    "plt.legend(loc='best', fontsize=15)\n",
    "\n",
    "ys = [1, 1.25, 1.5, 1.75]\n",
    "for y in ys:\n",
    "    plt.axhline(y, c='k', alpha=.2, linestyle='--', zorder=0)\n",
    "\n",
    "plt.yticks(ys, fontsize=15)\n",
    "plt.ylabel(\"Future Rewards\", fontsize=20)\n",
    "plt.xticks([1, 5, 10, 15, 20, 25], fontsize=15)\n",
    "plt.xlim(1, 25);\n",
    "plt.xlabel(\"Individual Learning Actions\", fontsize=20)\n",
    "\n",
    "# plt.xlim(.5, 15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "816f1633-6e70-4be1-8b2d-5e151fcb6063",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f885efb3580>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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du1agC5FadWqVUgpOeaYYw5ms7pFiVIPCCFITExkzJgxuFwu1VtSdCI2NpZp06YhpaSwsJB58+YhhGD+/Pk8/PDD5OXlERERwX/+8x8Ampubuf/++zn22GNJTEzEaDQyfPhw7rnnnrDCVVxczPnnn09sbCxms5lzzjmHoqIisrOzmTlzZihdsN4FCxbwhz/8gWHDhhEZGcmxxx7LihUrAFiyZAnHH388JpOJ1NRUHn744U719bZ9c+fO5dprrwVg1qxZoSHNa665Buh6TsnlcvGXv/yF8ePHExUVhdlsZtKkSTz11FMH8jEcEP11zgBOp5NHHnmEMWPGEBERQVxcHGeddRbr1q1rV2fw81q4cCF/+9vfyMvLw2g0kp+fzyuvvLJfdXbFmjX+TbanTJkSNn7lypUAQ0qU1OLZXmAymUhJSSE7O5vNmzczfPhwGhoaSExMHOymKYYAUkp27doF+I1jtm/fDsBdd92F2+3m5z//ObGxsYwcORKA8vJyXnjhBc4//3wuu+wydDodS5Ys4S9/+Qvr1q3jyy+/DJVdW1vLCSecQGVlJTfeeCOjRo1i6dKlzJo1i9bW1rDtueeee/B6vdx22224XC7+/ve/c9ppp/HKK69w3XXXccMNN3D55Zfzn//8hwcffJCcnByuuOKKUP7etu+8886joqKC559/nvvuu49Ro0YBkJeX1+W1crlcnHbaaSxevJhTTz2VK664goiICH744Qfef/99brnllgP4JPpOf52z2+3m9NNPZ9myZVx55ZXccsstNDY28u9//5vp06fzzTffMGnSpHZ133fffdjtdn7xi19gNBp55plnuOaaaxg+fDjTp0/v03UOsnbtWtLT06mvr6e+vr5T/DfffAMoUTrkCM4tjR49muLiYnbs2IHRaMRsNqPX6we7eUOS27+4nfX71g92M9oxPmU8T5z+xAGXY7PZqKmpQUpJRUUF//znP9mwYQNTp05lxIgRfPfddwDY7XbWrVtHVFRUu/y5ubmUlpa2u3d++ctf8sADD/DHP/6RVatWhX7ZPvroo5SVlfH6669z+eWXA3DTTTfxm9/8hr/+9a9h2+f1elmxYgUGgwGA0aNHc84553DBBRewfPlyJk+eDMB1113HsGHD+Ne//tVOlHrbvqOOOopp06bx/PPPc8opp7TrtXXFE088weLFi7n33nt55JFH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o4mIiDhiho774tFhJrC4hzTDgBP7UPaQoWhXEae0nsIx0cfw7JpnGZc0DgBLhAVLpOWgtMFkMpGamhry9JCXl0dERAQZGRnqF/AQ4rPPPuPpp5/mxhtv5Gc/+xkfffQRf/vb37BYLNx3332hdB988AHnn38+2dnZPPjgg+h0Ol5++WU++eSTHusYNWoUkydP5s033+Svf/1rux5UU1MTH330EXPmzMFqtXZZRlFRESeccAJOp5NbbrmFzMxMPv74Y04//fQDuwCBc9u2bRsXXXQRw4YNo7a2lldeeYXzzjuPN954g8suu+yA6+iO+++/nz/96U+cfvrpPPzww2g0Gj744AMuvPBCnnrqKX75y1+G0j711FPEx8dzww03kJKSwu7du3n++eeZPn06a9euZcSIEe3KLikpYfbs2Vx44YWcf/757Xosra2tzJgxg6lTp/LII49QVFTEk08+yTnnnMOmTZtCn5Pb7eb0009n2bJlXHnlldxyyy00Njby73//m+nTp/PNN98waVL73R6eeOIJamtr+fnPf05KSgqZmZkDeAWHDgPlZigS/xbkhyw+n493n3uX6+deT5mrjPsX3c/L57zMuop1TM+ajlFnHPA2CCFCnh4KCwv5/vvvsVgstLS0EBMTM+D1HwhffPFF2N1tB5OUlJR+eQB3ZPPmzWzevJns7GwAbrzxRsaNG8c///nPkCh5vV5uu+024uPjWbVqFYmJiQD84he/CP3y7omrr76aW265hS+//JIzzjgjFP7uu+9it9u5+uqru83/u9/9jvr6ehYuXMisWbMA+OUvf8l5553X6df6/nL//ffz5z//uV3YrbfeyoQJE/jjH/84oKK0du1a/vSnP3HvvffyyCOPtKv/3HPP5d577+Wqq64KfWe++OILTCZTuzKuuuoqxo8fz+OPP87TTz/dLq6oqIh///vfXH/99Z3qrqmp4e677+Y3v/lNKMxqtfKb3/yG+fPnc9pppwF+IVy8eDFffPFFKAzg5ptvZuzYsdx1110sXry4XdklJSVs27aNpKQkjiT6OqcU1j5Z+BmG3+t3aZ9bNQQYNmwYddV1vP+v97ks4TKaHE38YckfcPvcbK7efNBMtNsaPdTV1VFUVER1dXXYLZsVg8O5554bEiTw/5iYNWsW+/btC/2qXrNmDaWlpVx77bUhQQIwm83ceOONvaon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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.lineplot(data=to_plot, x='trial', y='regret', hue='listener', hue_order=hue_order, palette=palette)\n",
    "\n",
    "ys=[0, .25, .5, .75, 1, 1.25, 1.5, 1.75]\n",
    "plt.yticks(ys, fontsize=15)\n",
    "for y in ys:\n",
    "    plt.axhline(y, c='k', alpha=.2, linestyle='--', zorder=0)\n",
    "\n",
    "plt.ylabel(\"Regret\", fontsize=20)\n",
    "plt.xticks([1, 5, 10, 15, 20, 25], fontsize=15)\n",
    "plt.xlim(1, 25);\n",
    "plt.xlabel(\"Individual Learning Actions\", fontsize=20)\n",
    "plt.legend(fontsize=18)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9eb59d43-2287-4eef-8e70-b7db1390ddd2",
   "metadata": {},
   "source": [
    "## Summarize Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "9dafc3b7-4429-4120-beeb-33d274dad2cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_to_summarize = results"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "10e9cfd6-fbd4-4a53-ab5c-fe229edf5dd6",
   "metadata": {},
   "source": [
    "### Regret @ 25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "cd004bf9-6b3f-481b-bb58-fed79c67fb1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "regret_totals = results_to_summarize.groupby([\"listener\", \"trial_iteration_key\"])[\"regret\"].sum().reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "ef87b0fd-bc36-45c2-a9c0-ccede94cc54e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "listener\n",
       "individual                           12.14\n",
       "literal                              10.23\n",
       "pragmatic_aligned                     9.42\n",
       "pragmatic_misaligned_conservative     9.76\n",
       "pragmatic_misaligned_pedagogic        9.67\n",
       "pragmatic_uncertain                   9.55\n",
       "Name: regret, dtype: float64"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "regret_totals.groupby(\"listener\").regret.agg(np.mean).round(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "81ced09a-760f-4bd6-a069-dc106ec283bf",
   "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>listener</th>\n",
       "      <th>trial_iteration_key</th>\n",
       "      <th>random_effects_key</th>\n",
       "      <th>regret</th>\n",
       "      <th>centered_regret</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>individual</td>\n",
       "      <td>{'action_context': [{'color': 'blue', 'shape':...</td>\n",
       "      <td>[{'color': 'blue', 'shape': 'circle'}, {'color...</td>\n",
       "      <td>8</td>\n",
       "      <td>-2.128595</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>individual</td>\n",
       "      <td>{'action_context': [{'color': 'blue', 'shape':...</td>\n",
       "      <td>[{'color': 'blue', 'shape': 'circle'}, {'color...</td>\n",
       "      <td>8</td>\n",
       "      <td>-2.128595</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>individual</td>\n",
       "      <td>{'action_context': [{'color': 'blue', 'shape':...</td>\n",
       "      <td>[{'color': 'blue', 'shape': 'circle'}, {'color...</td>\n",
       "      <td>16</td>\n",
       "      <td>5.871405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>individual</td>\n",
       "      <td>{'action_context': [{'color': 'blue', 'shape':...</td>\n",
       "      <td>[{'color': 'blue', 'shape': 'circle'}, {'color...</td>\n",
       "      <td>8</td>\n",
       "      <td>-2.128595</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>individual</td>\n",
       "      <td>{'action_context': [{'color': 'blue', 'shape':...</td>\n",
       "      <td>[{'color': 'blue', 'shape': 'circle'}, {'color...</td>\n",
       "      <td>27</td>\n",
       "      <td>16.871405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83155</th>\n",
       "      <td>pragmatic_uncertain</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>14</td>\n",
       "      <td>3.871405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83156</th>\n",
       "      <td>pragmatic_uncertain</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>10</td>\n",
       "      <td>-0.128595</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83157</th>\n",
       "      <td>pragmatic_uncertain</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>16</td>\n",
       "      <td>5.871405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83158</th>\n",
       "      <td>pragmatic_uncertain</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>11</td>\n",
       "      <td>0.871405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83159</th>\n",
       "      <td>pragmatic_uncertain</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>[{'color': 'red', 'shape': 'circle'}, {'color'...</td>\n",
       "      <td>15</td>\n",
       "      <td>4.871405</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>83160 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                  listener                                trial_iteration_key  \\\n",
       "0               individual  {'action_context': [{'color': 'blue', 'shape':...   \n",
       "1               individual  {'action_context': [{'color': 'blue', 'shape':...   \n",
       "2               individual  {'action_context': [{'color': 'blue', 'shape':...   \n",
       "3               individual  {'action_context': [{'color': 'blue', 'shape':...   \n",
       "4               individual  {'action_context': [{'color': 'blue', 'shape':...   \n",
       "...                    ...                                                ...   \n",
       "83155  pragmatic_uncertain  [{'color': 'red', 'shape': 'circle'}, {'color'...   \n",
       "83156  pragmatic_uncertain  [{'color': 'red', 'shape': 'circle'}, {'color'...   \n",
       "83157  pragmatic_uncertain  [{'color': 'red', 'shape': 'circle'}, {'color'...   \n",
       "83158  pragmatic_uncertain  [{'color': 'red', 'shape': 'circle'}, {'color'...   \n",
       "83159  pragmatic_uncertain  [{'color': 'red', 'shape': 'circle'}, {'color'...   \n",
       "\n",
       "                                      random_effects_key  regret  \\\n",
       "0      [{'color': 'blue', 'shape': 'circle'}, {'color...       8   \n",
       "1      [{'color': 'blue', 'shape': 'circle'}, {'color...       8   \n",
       "2      [{'color': 'blue', 'shape': 'circle'}, {'color...      16   \n",
       "3      [{'color': 'blue', 'shape': 'circle'}, {'color...       8   \n",
       "4      [{'color': 'blue', 'shape': 'circle'}, {'color...      27   \n",
       "...                                                  ...     ...   \n",
       "83155  [{'color': 'red', 'shape': 'circle'}, {'color'...      14   \n",
       "83156  [{'color': 'red', 'shape': 'circle'}, {'color'...      10   \n",
       "83157  [{'color': 'red', 'shape': 'circle'}, {'color'...      16   \n",
       "83158  [{'color': 'red', 'shape': 'circle'}, {'color'...      11   \n",
       "83159  [{'color': 'red', 'shape': 'circle'}, {'color'...      15   \n",
       "\n",
       "       centered_regret  \n",
       "0            -2.128595  \n",
       "1            -2.128595  \n",
       "2             5.871405  \n",
       "3            -2.128595  \n",
       "4            16.871405  \n",
       "...                ...  \n",
       "83155         3.871405  \n",
       "83156        -0.128595  \n",
       "83157         5.871405  \n",
       "83158         0.871405  \n",
       "83159         4.871405  \n",
       "\n",
       "[83160 rows x 5 columns]"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "### Export to R\n",
    "for_r = results_to_summarize.groupby([\"listener\", \"trial_iteration_key\", \"random_effects_key\"]).regret.sum().reset_index()\n",
    "for_r[\"centered_regret\"] = for_r.regret - for_r.regret.mean()\n",
    "\n",
    "for_r"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a8cd5bb4-639c-40a3-a41c-28be5e266317",
   "metadata": {},
   "outputs": [],
   "source": [
    "for_r.to_csv(\"regret_results_for_r.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b1a0e50-704a-48d4-8296-aab4e52e4871",
   "metadata": {},
   "source": [
    "# Simulation Details"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72d9d32f-9171-4ab4-96b9-eb9b9d223d49",
   "metadata": {},
   "source": [
    "\n",
    "## Gaussian Prior\n",
    "How wide should initial variance be?\n",
    "\n",
    "First, we want this to be large in order to approximate a uniform on the interval [-2, 2]  \n",
    "However, for importance-sampling we need to sample from it and stay within the (-2.5, 2.5) range.\n",
    "\n",
    "With variance=5 and 6 dimensions, we should get 66% of samples within (-2.5, 2.5) which means .66^6 ~~ 8% of our initial samples will be accepted."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "63511ad8-b642-4bff-86d1-73a7888a8458",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Interval of (-2.1335783678031857, 2.133578367803187) --> acceptance of 0.08265395001600002.\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import norm\n",
    "import math\n",
    "\n",
    "variance = 5\n",
    "\n",
    "interval = norm.interval(.66, loc=0, scale=math.sqrt(variance))\n",
    "acceptance = .66**6\n",
    "\n",
    "print(f'Interval of {interval} --> acceptance of {acceptance}.')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
