{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f0f09095-bba1-4569-83a2-182e7ee5a3be",
   "metadata": {},
   "source": [
    "# Experiment Analysis\n",
    "\n",
    "This notebook loads the (anonymized) human data from the behavioral experiment and analyzes it."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cdcf9027-4a32-4cdc-b958-a6dd03e08797",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "import hashlib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import json\n",
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "36d0c6db-ac4b-4900-a545-f0a3ea6735f0",
   "metadata": {},
   "source": [
    "## Load data and unpack conditions, etc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e2bd2dca-11a3-400c-aabb-15c90050dd6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "trials = pd.read_csv(\"final_exp_human_trials.csv\")\n",
    "questions = pd.read_csv(\"final_human_exp_questions.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "86c5c8e8-7596-4948-8081-f6b544bc0591",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Sanity check randomizations\n",
    "\n",
    "if False:\n",
    "    print(\"\\nLog message counts:\")\n",
    "    print(questions.key.value_counts())\n",
    "    \n",
    "    print(\"\\nFull condition messages:\")\n",
    "    print(questions[questions.key == \"condition\"].value.value_counts())\n",
    "    \n",
    "    print(\"\\nTrial data files used:\")\n",
    "    print(questions[questions.key == \"trialDataFile\"].value.value_counts())\n",
    "\n",
    "    print(\"\\nFeature randomizations:\")\n",
    "    feature_randomizations = questions[questions.key == \"featureRandomization\"].value\n",
    "    feature_randomizations = feature_randomizations.apply(lambda x: json.loads(x))\n",
    "    feature_randomizations = pd.DataFrame(list(feature_randomizations.values))\n",
    "    for feature in [\"Green\", \"Red\", \"Blue\", \"Spotted\", \"Solid\", \"Striped\"]:\n",
    "        print(feature_randomizations[feature].value_counts())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c70a16d9-3b68-4e62-afc5-45800991044e",
   "metadata": {},
   "source": [
    "## Read in trial data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "845a502b-7d51-455b-be4a-d7f32d18d6ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "survey-html-form        3780\n",
       "html-button-response    1143\n",
       "survey-likert            607\n",
       "instructions             231\n",
       "survey-multi-choice      186\n",
       "survey-text              105\n",
       "Name: trial_type, dtype: int64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load data, filter out debug, hash ID\n",
    "\n",
    "# Read JSON data into Python objects\n",
    "trials[\"data\"] = trials.value.apply(lambda x: json.loads(x))\n",
    "\n",
    "for field in [\"rt\", \"trial_type\"]:\n",
    "    trials[field] = trials.data.apply(lambda x: x.get(field))\n",
    "    \n",
    "trials.trial_type.value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "055a2357-e96e-41b6-9396-be47d65f75a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pre-Quiz Count: 119 participants.\n"
     ]
    }
   ],
   "source": [
    "print(\"Pre-Quiz Count: {} participants.\".format(trials.workerid.nunique()))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "42b662d7-7e33-409c-be6b-b1927e8b341d",
   "metadata": {},
   "source": [
    "# Experiment Duration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "749b4fcf-2f7b-4d9a-94aa-217a8454f85d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    119.000000\n",
       "mean      18.525471\n",
       "std        7.624343\n",
       "min        3.082400\n",
       "25%       12.996092\n",
       "50%       17.425250\n",
       "75%       22.826625\n",
       "max       41.320933\n",
       "Name: time_elapsed, dtype: float64"
      ]
     },
     "execution_count": 6,
     "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": [
    "trials[\"time_elapsed\"] = trials.data.apply(lambda x: x.get(\"time_elapsed\"))\n",
    "minutes_in_experiment = trials.groupby(\"workerid\").time_elapsed.max() / 1000 / 60\n",
    "\n",
    "sns.histplot(minutes_in_experiment, bins=10)\n",
    "plt.title(\"Minutes in experiment (total)\")\n",
    "\n",
    "minutes_in_experiment.describe()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f1ec4d67-9ebd-4ab1-b0f8-d03e026f03b5",
   "metadata": {},
   "source": [
    "## Quiz\n",
    "How many attempts do people take?\n",
    "What fraction pass?\n",
    "Which pages are \"hardest\"?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "09be5a56-34e5-4ad2-823a-1b35a3a83a97",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/1755126429.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quizResults[\"passed_quiz\"] = quizResults.key.apply(lambda x: True if x == \"quizPassed\" else False)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True     104\n",
       "False     14\n",
       "Name: passed_quiz, dtype: int64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "quizResults = questions[questions.key.str.contains('quizPassed') | questions.key.str.contains('quizFailed')]\n",
    "quizResults[\"passed_quiz\"] = quizResults.key.apply(lambda x: True if x == \"quizPassed\" else False)\n",
    "\n",
    "quizResults = quizResults[[\"workerid\", \"passed_quiz\"]].set_index(\"workerid\")\n",
    "\n",
    "quizResults.passed_quiz.value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cd060a27-a5cd-4310-967e-5cc0e2bdf339",
   "metadata": {},
   "outputs": [],
   "source": [
    "quizAttempts = questions[questions.key.str.contains('quizAttempt')]\n",
    "quizAttempts = quizAttempts[quizAttempts.workerid.isin(trials.workerid.unique())]\n",
    "\n",
    "quizAttempts[\"data\"] = quizAttempts.value.apply(lambda x: json.loads(x))\n",
    "quizAttempts[\"correct\"] = quizAttempts[\"data\"].apply(lambda x: x[\"correct\"])\n",
    "quizAttempts[\"total\"] = quizAttempts[\"data\"].apply(lambda x: x[\"total\"])\n",
    "quizAttempts[\"cum_correct\"] = quizAttempts[\"correct\"] + 14 - quizAttempts[\"total\"]\n",
    "quizAttempts[\"passed\"] = quizAttempts[\"data\"].apply(lambda x: x[\"total\"] == x[\"correct\"])\n",
    "\n",
    "if False:\n",
    "    quizAttempts.groupby(\"key\").cum_correct.agg([\"size\", \"mean\", \"std\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0c03d608-6c5f-4de9-b9fc-6a3e0014e8ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "participant_quiz_results = quizAttempts.groupby(\"workerid\").size()\n",
    "\n",
    "trials = trials.set_index(\"workerid\").merge(participant_quiz_results.to_frame(name=\"quiz_attempts\"), left_index=True, right_index=True, how=\"left\").reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "67fa8d01-74b5-4a4f-934e-4cbb4d11307c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3177066139.py:3: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quiz_trials[\"total\"] = quiz_trials.data.apply(lambda x: int(x.get(\"total\")))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3177066139.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quiz_trials[\"correct\"] = quiz_trials.data.apply(lambda x: int(x.get(\"correct\")))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3177066139.py:5: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quiz_trials[\"wrong\"] = quiz_trials.total - quiz_trials.correct\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3177066139.py:7: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quiz_trials[\"response\"] = quiz_trials.data.apply(lambda x: x.get(\"response\"))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3177066139.py:9: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  quiz_trials[\"first_attempt\"] = quiz_trials.num <= 12\n"
     ]
    }
   ],
   "source": [
    "quiz_trials = trials[trials.data.apply(lambda x: x.get(\"total\") is not None)]\n",
    "\n",
    "quiz_trials[\"total\"] = quiz_trials.data.apply(lambda x: int(x.get(\"total\")))\n",
    "quiz_trials[\"correct\"] = quiz_trials.data.apply(lambda x: int(x.get(\"correct\")))\n",
    "quiz_trials[\"wrong\"] = quiz_trials.total - quiz_trials.correct\n",
    "\n",
    "quiz_trials[\"response\"] = quiz_trials.data.apply(lambda x: x.get(\"response\"))\n",
    "\n",
    "quiz_trials[\"first_attempt\"] = quiz_trials.num <= 12\n",
    "wrong_answers = quiz_trials[quiz_trials.wrong >=1]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "91749a47-1d2b-4ce3-9c50-faf8cd551c3a",
   "metadata": {
    "tags": []
   },
   "source": [
    "## Exit Survey"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1c03e75c-38e8-4cb9-9ea9-7fdad83afe51",
   "metadata": {},
   "outputs": [],
   "source": [
    "exit_survey = trials[trials.trial_type == 'survey-text']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0256fec7-2c45-4f04-8396-35641a8175e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment Objective:\n",
      "\n",
      "['to ensure tourists chose tasty mushrooms'\n",
      " 'to provide them with the knowledge of the tatsiest mushrooms'\n",
      " 'To get them as many tasty mushrooms as possible'\n",
      " 'For tourists to collect the tastiest mushrooms possible each time.'\n",
      " 'maximise the score' 'To get them the best'\n",
      " 'Get them to pick the best mushrooms'\n",
      " 'TO DIRECT PEOPLE TO THE MOST ENJOYYABLE TO EAT'\n",
      " 'to help them work out the tasty mushrooms'\n",
      " 'to help them pick the best mushroom' 'select good tasting mushrooms'\n",
      " 'To make sure that the tourists picked the highest value mushrooms.'\n",
      " 'To help them pick good mushrooms.'\n",
      " 'To get teh highest possible taste in mushrooms for the people'\n",
      " 'To get the tourists to pick the tastiest mushrooms'\n",
      " 'Help the tourists chose the tastiest mushrooms'\n",
      " 'To make help the tourist pick the tastiest mushroom'\n",
      " 'to inform tourists about mushrooms'\n",
      " 'give out the best flavours to attract more tourists'\n",
      " 'To give the customer the best tasting mushroom'\n",
      " 'To teach them to avoid the bad mushrooms more so'\n",
      " 'I had to get the tourists to pick tasty mushrooms' 'to make them happy'\n",
      " 'Help them find the best mushrooms'\n",
      " 'inform the visitors how to pick the tastiest mushrooms'\n",
      " 'To get them to pick the tastiest mushrooms.'\n",
      " 'My objective was to help the tourists pick'\n",
      " 'To help them pick good mushrooms.'\n",
      " 'To help people get the tastiest mushrooms'\n",
      " 'Maximise their tastiness score.' 'help them pick good mushrooms'\n",
      " 'Help them pick the best tasting mushrooms'\n",
      " 'to try and teach as much as possible'\n",
      " 'To help them pick the tastiest mushroom'\n",
      " 'To help them get the most points/tastiest mushrooms'\n",
      " 'To make sure tourist pick tasty mushrooms.'\n",
      " 'To help the tourist avoid the least tasty mushrooms'\n",
      " 'helping the tourists pick the tastiest mushrooms'\n",
      " 'to help pick tasty mushrooms' 'maximise tastiness'\n",
      " 'to help them to pick the most tasty mushroom'\n",
      " 'Help tourists to pick tasty mushrooms'\n",
      " 'To help the tourists pick the tastiest mushrooms.'\n",
      " 'to give them the tastiest mushrooms'\n",
      " 'To help tourists pick the best mushrooms' 'asda'\n",
      " 'to help make them pick the tasty mushrooms'\n",
      " 'To help the tourists pick good mushrooms. '\n",
      " 'get them to pick the tastiest mushrooms'\n",
      " 'To educate tourists on  how to identofy and pick the tastiest mushrooms.'\n",
      " 'For the people to find the tastiest mushrooms'\n",
      " 'To guide the tourists to pick the tastiest mushrooms'\n",
      " 'To ensure customers took the tastiest mushrooms'\n",
      " 'to help guide the tourist pick the best mushrooms'\n",
      " 'To help the tourists pick the tastiest mushrooms.'\n",
      " 'choose the best value' 'Make sure the tourists gets the best mushrooms.'\n",
      " 'To help the people pick the tastiest mushrooms'\n",
      " 'To help the tourist find the tastiest mushrooms'\n",
      " 'To help visitors pick tasty mushrooms'\n",
      " 'To help visitors pick the best mushrooms'\n",
      " 'To help tourists find tasty mushrooms in the patches'\n",
      " 'To get them to learn to pick the best mushrooms'\n",
      " 'to help them pick good mushrooms'\n",
      " 'To maximise the number of blue mushrooms the tourist would choose.'\n",
      " 'To help them gain as many tasty mushrooms as possible'\n",
      " 'To help them avoid the worst tastes and try to guide them towards tasty mushrooms'\n",
      " 'To get the tastiest mushrooms' 'help people pick tasty mushrooms'\n",
      " 'To guide tourists to picking good mushrooms'\n",
      " 'to advise the tastiest fungi to eat' 'help visitors pick good mushrooms'\n",
      " 'To help the customers pick the best mushrooms'\n",
      " 'To help the tourists choose the most tasty mushroom in the most easiest way possible'\n",
      " 'Help tourists pick the good (highest value) mushrooms'\n",
      " 'To ensure the tourist get good mushroom'\n",
      " 'To guide them to make the best choices.'\n",
      " 'to help them pick the tastiest mushrooms' 'add the most value'\n",
      " 'guide tourists to the tasty mushrooms'\n",
      " 'to help them pick good mushrooms throughout their visit'\n",
      " 'To help the tourists pick the mushrooms with the highest points'\n",
      " 'To make sure they picked the tastiest mushrooms.'\n",
      " 'to help tourists pick the tasty mushrooms'\n",
      " 'To help pick the best mushroom '\n",
      " 'To help the customers decide which mushrooms are tastiest.'\n",
      " 'To be consistent' 'to get max points' 'to instruct'\n",
      " 'help them pick the tastiest mushrooms' 'maximize taste = points'\n",
      " 'To help the tourists to identify tasty mushrooms.'\n",
      " 'To guide tourists to the best tastiest mushrooms'\n",
      " 'To help them pick good mushrooms'\n",
      " 'to help them choose the best mushrooms' 'get the most points'\n",
      " 'To help them pick the tastiest mushrooms'\n",
      " 'I did not give them the chance to really choose by themselves.'\n",
      " 'to help them pick the tastiest mushrooms'\n",
      " 'To help them pick the best mushrooms possible'\n",
      " 'To make them choose good ones'\n",
      " 'to help people pick or learn about the best mushrooms'\n",
      " 'To ensure that my guests took the mushrooms with the highest points and therefore would be the tastiest'\n",
      " 'To do my best to help the tourists select the tastiest mushroom'\n",
      " 'To correctly guide them or teach them to pick the tasty mushrooms from each patch.']\n",
      "\n",
      "Participant Strategies:\n",
      "\n",
      "['depending on which option could give them more info on the mushrooms'\n",
      " 'based on the number of patches they would visit'\n",
      " 'I looked at what mushrooms they had and gave the best advice '\n",
      " 'If there was more than one patch they visited - the principle could be applied to more than one patch.'\n",
      " 'always tried to teach them, if possible' 'Just chose randomly'\n",
      " 'Number of patches and if there was the best possible combination there'\n",
      " 'BASED ON WHAT WOULD TASTE THE BEST'\n",
      " 'i prefer to teach, it makes it a learning experience'\n",
      " 'i looked at the 3 visible mushrooms'\n",
      " 'depending on how many pathes and if they had a good choice on the visable patch'\n",
      " 'Depending on the number of potential picks the tourist would have. If there were many patches, I would choose to teach them.'\n",
      " 'If there was one patch I instructed and if there was more than one patch I taught.'\n",
      " 'If they were going to choose their own - I taught them - if it was a simple choice of 3 then I instructed to get the highest score'\n",
      " 'If it was just one patch then I woujld instruct but if there was more then I tended to teach as the other patches are unknow.'\n",
      " 'If they were visiting more than one patch I chose to teach them'\n",
      " 'If a tourist had multiple patches then i tried to teach them'\n",
      " 'just varied for a change of instructin to be honest'\n",
      " 'according to taste score i wanted to give most tasty ones'\n",
      " 'Varied depending on what was dislayed'\n",
      " 'i instructed based on if the texture and colour gave the best mushroom, if there was more bad mushrooms i would teach and the solid texture.'\n",
      " 'I tried to give them the instructions to have better chances to pick tasty mushrooms'\n",
      " 'which one I could remember'\n",
      " 'If they are only visiting one patch, and there is a clear best option, I struct them which to pick'\n",
      " 'figured the best bet would be to teach them what is worth the most and what is worth the least, so they can make informed decisions'\n",
      " 'If there was more than one patch I gave them the highest rated info.'\n",
      " 'I chose depending on the given scenario'\n",
      " 'Instruct if only visiting one patch otherwise teach.'\n",
      " \"Basically on the current mushrooms and the amount of patches. If there was a green or two and no blues, I'd teach against green. If one patch and blue, I'd instruct. \"\n",
      " 'Depended on whether they were going to more where teaching would aid them further, and whether in teaching you could guide their first choice too.'\n",
      " 'guessed'\n",
      " 'Chose instruct if they were only visiting one patch; more than i decided to teach'\n",
      " 'depending what the mushrooms were'\n",
      " 'I chose to instruct if there was only one patch they were visiting and teach if there were more patches to visit'\n",
      " 'Depending on how many patches they would be going to'\n",
      " 'I instructed tourists because I felt it was easierfor the tourists. I taught some tourists that reappeared so they could know what to pick without me.'\n",
      " 'Teach if more than one patch visited'\n",
      " 'depending on how many patches they had to visit'\n",
      " 'by which i thought would get the tastiet mushrrom'\n",
      " 'the value of the visibel mushrooms versus potential value of not visible mushrooms'\n",
      " 'see how many patches they are visiting' 'Teaching is more polite'\n",
      " 'I instructed the tourists when there was a clear tastiest mushroom on offer. I taught the tourists when the selection was a little ambiguous.'\n",
      " 'if there were unseen patches chose to teach them'\n",
      " 'If they had one or more colour/pattern I would teach them what those meant for their rating but if they had no high scoring mushrooms I would instruct them to pick the highest rated one'\n",
      " 'asda' 'i advised them which had the highest points'\n",
      " 'in case of multiple patches, if blue-spotted exists in the first one, then I instruct them to choose it, otherwise I will teach them that blue is the most important feature so they focus on it in the other patches.'\n",
      " 'tried to share what would allow them to deduce other features'\n",
      " 'Based on the mushrooms present. More teaching was given as the mushrooms of any kind could spawn in other patches. Guidence was given to ensure no tourist recieved a bad tasting mushroom.'\n",
      " 'If there was only one patch, then it made sense to instruct them, if more than one patch then teach them to always go for blue'\n",
      " 'By the lot of the mushrooms'\n",
      " 'If there was a blue solid mushroom, always instruct.'\n",
      " 'Based on the mushrooms that were already shown'\n",
      " 'I considered if they were visiting other patches of mushrooms. '\n",
      " 'What seemed best'\n",
      " 'If there is patch they need to go on their own, then I chose to teach them. But just instruct them when I accompany them.'\n",
      " 'If they were visiting more than one patch'\n",
      " 'Instruct when only one patch, teach when more than one'\n",
      " 'I was trying to deduct what one piece of information would be most helpful to them to make sure they pick tasty mushrooms overall'\n",
      " 'If they were going to visit more patches i would teach. If they were only visiting one i would instruct'\n",
      " 'I liked pointing them to a specific mushroom that I knew was the tastiest.'\n",
      " 'If there was a big enough difference, I would teach to go for green and stripe if present'\n",
      " 'If it was blue stripe i instructed them'\n",
      " 'I looked at what was available, and tried to consider what a reasonable person might infer from the instructions. It is possible that the tourist could infer that the value of stripes, for example, was high (when directing a tourist to a blue striped mushroom) so I seldom chose direct instruction.'\n",
      " 'Entirely by the number of patches they would visit'\n",
      " 'I tried to think of information that would help them steer clear or gravitate towards things most usefully and rule out many choices'\n",
      " 'it depended how may patches they were visiting.  I could only go to one so I had to teach them how to pick the best mushrooms'\n",
      " 'teach'\n",
      " 'When I knew the mushrooms available I instructed but when I wasn;t sure what was in the other patches I taught them instead.'\n",
      " 'Based on available choices to them'\n",
      " 'If more than one patch and visible patch had sample selection '\n",
      " 'If they had multiple patches, teach them so they can apply logic to those. If there is only one patch, instruct them to make sure they get the best outcome'\n",
      " 'I chose the easier option by telling them which mushroom to choose'\n",
      " 'If there was one patch, I would instruct. If there were more than one patch, I would teach.'\n",
      " 'Depend on how many patch they visit and option available for first patch'\n",
      " 'The highest bonus and how informative it would be to their decisions'\n",
      " 'I thought the information ws betterso tey could know for later'\n",
      " 'depending on how many. patches'\n",
      " 'depending on how many patches they were visiting, if visiting only 1 then instruct them.'\n",
      " 'Depends if they are choosing from multiple patches or a single patch of mushroms'\n",
      " 'If they had a mushroom worth 3 I instructed. If not I taught'\n",
      " 'If they would be visiting more than one patch I taught them. '\n",
      " 'Just did what i though made sense' 'Based on colour '\n",
      " 'I almost always chose to instruct tourists because it seemed like the easiest option.'\n",
      " 'random if only negatives on view' 'to guide them more' 'random'\n",
      " 'depended on how many patches' 'depended on mix in a patch'\n",
      " 'If they were going to be picking from further patches, I chose to teach them to give them a better chance of finding good mushrooms. And also if teaching would guarantee they picked the best mushroom from just one patch.'\n",
      " 'Preferred teach choices'\n",
      " 'I chose teach if there was more than 1 patch to choose from so they could work it out for themselves'\n",
      " 'If they were going to multiple fields or not'\n",
      " 'just went with what felt most appropriate'\n",
      " 'Depending on how many patches they visited'\n",
      " 'I was instructing themall the time as I knew the colours and numbers.'\n",
      " 'unsure' 'Instruct if just one patch, teach if visiting more than one'\n",
      " 'Depending upon the easiness for them to understand while picking.'\n",
      " 'because of the number of patches they were going to'\n",
      " 'I went for the best possible points'\n",
      " 'If there was more than one mushroom patch I would teach rather than instruct'\n",
      " 'I instructed them when they visited only one patch and teach them if they visited more than one.']\n",
      "\n",
      "Anything Confusing:\n",
      "\n",
      "['no' 'no'\n",
      " \"The third question of the first set of questions to which the answer was 'all of the above' I don't remember reading that information\"\n",
      " 'Yes, I got initially mixed up with the colours by themselves and solids.'\n",
      " 'n/a' 'No' 'N/A'\n",
      " 'INSTRUCTIONS REGARDING VALUES COULD HAVE BEEN CLEARER, BUT WELL PRESENTED OVERALL'\n",
      " 'no' 'no' 'NO' 'No' 'no' 'no - it was fun' 'No' 'No' 'no'\n",
      " 'not sure i think i got it right!' 'none' 'no' 'no, it was clear.' 'no'\n",
      " 'nope'\n",
      " \"I wasn't totally sure if the visible mushroom patch was an indication of how common certain types of mushroom would be\"\n",
      " 'no' 'No' 'no' 'No' 'No' 'No' 'no' 'No, the instructions were excellent!'\n",
      " 'no' 'no' 'No' 'No.' 'No' 'no' 'no' 'No' 'no' 'no' 'No' 'no' 'No' 'asd'\n",
      " 'none' 'no' 'no' 'None. Very clear and concise.' 'No' 'NO' 'NA' 'N/A'\n",
      " 'No. ' 'no' 'no' 'No' 'None' 'No' 'no' 'No' 'No' 'no'\n",
      " 'No, everything was really clear.' 'No' 'Nothing' 'o' 'no ' 'No' 'no'\n",
      " 'No' 'No' 'no' \"I didn't understand the goal of the experiment. \" 'No'\n",
      " 'No' 'No' 'no' 'no' 'No' 'No' 'Nothing at all. ' 'no' 'no' 'None' 'no'\n",
      " 'no' 'no' 'no' 'no' 'No' 'No I enjoyed the challenge ' 'No' 'no' 'no'\n",
      " 'Sometimes unsure on whether to teach or instruct'\n",
      " 'Nothing was unclear or confusing. All instructions were clear enough.'\n",
      " 'no' 'N/A' 'No' 'no' 'No, it was fine' 'No' 'No']\n",
      "\n",
      "Misc Feedback:\n",
      "\n",
      "['no' 'no' 'None, thank you' 'Just to make the above a little clearer. '\n",
      " 'n/a' 'No' 'N/A'\n",
      " 'WELL PRESENTED AND GOOD USE OF PICTURES / TABULAR PRESENTATION.  MAYBE PRACTICE WOULD BE GOOD WITH OUTCOME TO SHOW HOW IT WORKS,'\n",
      " 'interesting study!' 'no' 'NO' 'No' 'n/a'\n",
      " 'I liked this a great deal - thank you' 'No' 'No'\n",
      " 'Thanks for the opportunity' 'no' 'none' 'was interesting'\n",
      " 'no, but i did enjoy this study. It was fun.' 'no' 'nope!' 'No'\n",
      " 'no further comments' 'No' 'no' 'No' 'Hope my answers are helpful ' 'No'\n",
      " 'no' 'This was a very enjoyable experiment. Thank you.' 'no' 'no' 'No'\n",
      " 'None.' 'No' 'none' 'no' 'good fun, thanks!' 'no' 'no thanks'\n",
      " 'Fun study!' 'no' '-' 'ad' 'none' 'no' 'NO' 'A Fun experiment.'\n",
      " 'Thanks for the study, it was a lot of fun.' 'Interesting task' 'NA'\n",
      " 'n/a' 'No.' 'no sorry, was fun' 'no' 'None' 'It was fun, thank you' 'No'\n",
      " 'no' 'No' 'None, it was fun though.' 'none'\n",
      " \"I thought it was a lot of fun to work through this, although I have no idea what information you'll get from it!\"\n",
      " 'It was extremely fun and i would love to participate in similar experiments you run in the future.'\n",
      " 'I enjoyed this task' 'no' 'no' 'No' 'no' 'thanks' 'No'\n",
      " 'interesting study about learning'\n",
      " 'I also would like to know whether my answers were correct.' 'No' 'No.'\n",
      " 'No' 'no' 'no' 'Its pretty interesting :)' 'This was fun'\n",
      " 'Nothing at all. ' 'no' 'no' 'No.' 'No, it was actually enjoyable' 'no'\n",
      " 'no' 'none' 'none' 'No' 'Loved the test ' 'None' 'no' 'no' 'No'\n",
      " 'It was an enjoyable task.' 'no' 'N/A' 'No' 'no' 'No it was all good'\n",
      " 'No' 'No, thank you.']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/1776341517.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exit_survey[question] = exit_survey.data.apply(lambda x: x[\"response\"][question])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/1776341517.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exit_survey[question] = exit_survey.data.apply(lambda x: x[\"response\"][question])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/1776341517.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exit_survey[question] = exit_survey.data.apply(lambda x: x[\"response\"][question])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/1776341517.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exit_survey[question] = exit_survey.data.apply(lambda x: x[\"response\"][question])\n"
     ]
    }
   ],
   "source": [
    "for question in [\"experiment_objective\", \"participant_strategy\", \"experiment_confusing\", \"misc_feedback\"]:\n",
    "    exit_survey[question] = exit_survey.data.apply(lambda x: x[\"response\"][question])\n",
    "\n",
    "print(\"Experiment Objective:\\n\")\n",
    "print(exit_survey.experiment_objective.values)\n",
    "\n",
    "print(\"\\nParticipant Strategies:\\n\")\n",
    "print(exit_survey.participant_strategy.values)\n",
    "\n",
    "print(\"\\nAnything Confusing:\\n\")\n",
    "print(exit_survey.experiment_confusing.values)\n",
    "\n",
    "print(\"\\nMisc Feedback:\\n\")\n",
    "print(exit_survey.misc_feedback.values)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "afea41f6-9a76-4602-ab62-9e8ef0df8331",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Catch Trials\n",
    "Do people get these right?  \n",
    "What is % correct by person?   \n",
    "By context / question? (are some harder than others?)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "2f7739d4-9cd3-445f-917c-7405c922109e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"belief_model\"] = catch_trials.data.apply(lambda x: 1 if x.get(\"belief\") else 0)\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:5: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"response\"] = catch_trials.data.apply(lambda x: bool(int(x['response'][\"utterance\"])))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:6: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"catch_trial_correct\"] = catch_trials[\"belief_model\"] == catch_trials[\"response\"]\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:8: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"feature\"] = catch_trials.data.apply(lambda x: x.get(\"features\")[0])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:9: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"feature_value\"] = catch_trials.data.apply(lambda x: x.get(\"values\")[0])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"action_context\"] = catch_trials.data.apply(lambda x: str([x.get(\"action_context\")[0]]))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3387171192.py:14: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  catch_trials[\"action_context\"] = catch_trials.data.apply(lambda x: str(x.get(\"action_context\")))\n"
     ]
    }
   ],
   "source": [
    "select_trials = trials[trials.trial_type == 'survey-html-form']\n",
    "catch_trials = select_trials[select_trials['data'].apply(lambda x: bool(x.get('features', 'all') != 'all'))]\n",
    "\n",
    "catch_trials[\"belief_model\"] = catch_trials.data.apply(lambda x: 1 if x.get(\"belief\") else 0)\n",
    "catch_trials[\"response\"] = catch_trials.data.apply(lambda x: bool(int(x['response'][\"utterance\"])))\n",
    "catch_trials[\"catch_trial_correct\"] = catch_trials[\"belief_model\"] == catch_trials[\"response\"]\n",
    "\n",
    "catch_trials[\"feature\"] = catch_trials.data.apply(lambda x: x.get(\"features\")[0])\n",
    "catch_trials[\"feature_value\"] = catch_trials.data.apply(lambda x: x.get(\"values\")[0])\n",
    "\n",
    "# Grab only the first action context, so multi-horizon participants join correctly\n",
    "catch_trials[\"action_context\"] = catch_trials.data.apply(lambda x: str([x.get(\"action_context\")[0]]))\n",
    "\n",
    "catch_trials[\"action_context\"] = catch_trials.data.apply(lambda x: str(x.get(\"action_context\")))\n",
    "# catch_trials[\"context_hash\"] = catch_trials.action_context.apply(hash_id)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "34559087-7d2f-4d40-bef6-7372faa76895",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Fraction of participants')"
      ]
     },
     "execution_count": 14,
     "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": [
    "participant_catch_results = catch_trials[[\"catch_trial_correct\",  \"workerid\"]].groupby([\"workerid\"]).mean().reset_index()\n",
    "participant_catch_results[\"passed_catch_trial\"] = participant_catch_results.catch_trial_correct > .75\n",
    "\n",
    "sns.histplot(participant_catch_results, x=\"catch_trial_correct\", multiple=\"dodge\")\n",
    "plt.ylabel(\"Fraction of participants\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "d5741caa-b789-477a-9b44-128fca8b5cea",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Join catch results into main dataframe to simplify analysis\n",
    "joined_trials = trials.set_index(\"workerid\").join(participant_catch_results[[\"passed_catch_trial\", \"catch_trial_correct\", \"workerid\"]].set_index('workerid'))\n",
    "\n",
    "joined_trials = joined_trials.join(quizResults).reset_index()\n",
    "\n",
    "joined_trials.passed_catch_trial = joined_trials.passed_catch_trial.fillna(False)\n",
    "joined_trials[\"no_catch_data\"] = joined_trials.passed_catch_trial.isnull()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "521736dc-0277-46f8-9154-5fc22b391989",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "119 unique workers before join, 119 after.\n"
     ]
    }
   ],
   "source": [
    "print(\"{} unique workers before join, {} after.\".format(trials.workerid.nunique(), joined_trials.workerid.nunique()))\n",
    "\n",
    "# joined_trials.groupby([\"objective\", \"horizon\", \"passed_catch_trial\"]).workerid.nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "9db7eefc-edc4-4e57-8024-a5f30a531321",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "passed_quiz  passed_catch_trial\n",
       "False        False                 14\n",
       "True         False                  5\n",
       "             True                  99\n",
       "Name: workerid, dtype: int64"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "joined_trials.groupby([\"passed_quiz\", \"passed_catch_trial\"]).workerid.nunique()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "968ef0be-a7c8-46f9-8ce4-74e8197237cc",
   "metadata": {},
   "source": [
    "## Drop participants that did not pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "29c61b80-b78d-42a5-bb67-24273dc68571",
   "metadata": {},
   "outputs": [],
   "source": [
    "joined_trials = joined_trials[joined_trials.passed_catch_trial]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c372062-6a2a-4905-8784-a0ca13feb86f",
   "metadata": {},
   "source": [
    "## Visualize Responses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "0a0414dc-da48-46f1-ba31-23553bbd923a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2772"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "select_trials = joined_trials[joined_trials.trial_type == 'survey-html-form']\n",
    "\n",
    "exp1_trials = select_trials[select_trials[\"data\"].apply(lambda x: x.get(\"features\", \"all\") == \"all\")]\n",
    "\n",
    "len(exp1_trials)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "7157db15-3699-4af6-a8ad-ee6881021bf9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'feature': 'Green', 'feature_value': '2', 'texture': '', 'color': ''}"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp1_trials.data.iloc[1][\"response\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "955fd4a7-6427-4738-b5cc-5e5628dfd885",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:1: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"feature\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"feature\"])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"feature_value\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"feature_value\"])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:3: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"instruction_texture\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"texture\"])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"instruction_color\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"color\"])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:5: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"horizon\"] = exp1_trials.data.apply(lambda x: int(x[\"horizon\"]))\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:7: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"utterance\"] = exp1_trials.data.apply(lambda x: x[\"response\"])\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:9: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"instruction\"] = exp1_trials.data.apply(lambda x: (x[\"response\"][\"feature\"]) == \"\")\n",
      "/var/folders/gv/42lb0z1j4dxf3wsk74nrxwx80000gn/T/ipykernel_60670/3512373998.py:11: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  exp1_trials[\"feature_value\"] = exp1_trials.apply(lambda x: int(x[\"feature_value\"]) if not x[\"instruction\"] else None, axis=1)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "           1203\n",
       "Green       860\n",
       "Blue        389\n",
       "Spotted     213\n",
       "Striped     107\n",
       "Name: feature, dtype: int64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp1_trials[\"feature\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"feature\"])\n",
    "exp1_trials[\"feature_value\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"feature_value\"])\n",
    "exp1_trials[\"instruction_texture\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"texture\"])\n",
    "exp1_trials[\"instruction_color\"] = exp1_trials.data.apply(lambda x: x[\"response\"][\"color\"])\n",
    "exp1_trials[\"horizon\"] = exp1_trials.data.apply(lambda x: int(x[\"horizon\"]))\n",
    "\n",
    "exp1_trials[\"utterance\"] = exp1_trials.data.apply(lambda x: x[\"response\"])\n",
    "\n",
    "exp1_trials[\"instruction\"] = exp1_trials.data.apply(lambda x: (x[\"response\"][\"feature\"]) == \"\")\n",
    "\n",
    "exp1_trials[\"feature_value\"] = exp1_trials.apply(lambda x: int(x[\"feature_value\"]) if not x[\"instruction\"] else None, axis=1)\n",
    "\n",
    "# Sanity check chosen messages\n",
    "exp1_trials.feature.value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9025f4ed-d1a3-4cf4-b3d9-2b77cf80ed74",
   "metadata": {},
   "outputs": [],
   "source": [
    "def align_instructions(row):\n",
    "    \n",
    "    if not row[\"instruction\"]:\n",
    "        return row\n",
    "    \n",
    "    # Is this row aligned already? If so, return\n",
    "    if row[\"instruction_texture\"] in [\"Spotted\", \"Solid\", \"Striped\"]:\n",
    "        return row\n",
    "    \n",
    "    # Otherwise, switch 'em\n",
    "    row_color = row[\"instruction_texture\"]\n",
    "    row[\"instruction_texture\"] = row[\"instruction_color\"]\n",
    "    row[\"instruction_color\"] = row_color\n",
    "        \n",
    "    return row\n",
    "\n",
    "exp1_trials = exp1_trials.apply(align_instructions, axis=1)## Visualize Responses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5d0cb05d-dba0-4e29-973c-a75d1a2d201c",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp1_trials[\"message_type\"] = exp1_trials.instruction.apply(lambda x: \"Instructions\" if x else \"Descriptions\")\n",
    "\n",
    "n_instructions = exp1_trials[exp1_trials[\"message_type\"] == \"Instructions\"].workerid.value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "3311fae0-c461-4371-8e54-f283940bd2c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_instructions = exp1_trials[exp1_trials[\"message_type\"] == \"Instructions\"].workerid.value_counts()\n",
    "\n",
    "exp1_joined = pd.merge(exp1_trials, n_instructions.to_frame(name=\"n_instructions\"), \n",
    "                       left_on='workerid', right_index=True, how='left').reset_index()\n",
    "\n",
    "exp1_joined[\"n_instructions\"].fillna(0, inplace=True)\n",
    "\n",
    "exp1_trials = exp1_joined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "eb6a87db-3580-4b5c-897e-d06ca3b2f356",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Message Count')"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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4Ap3n5fuWKT00ZmBiIgoGYiIiJqJREQEnRmIiAhKBiIigpKBiIigZCAiIigZiIgISgYiIoKSgYiIoGQgIiIoGYiICEoGIiKCkoGIiKBkICIiKBmIiAhKBiIiAlRKdwBFVb9+fW/ZsmW6wxARKVOWLFmy0d0bxM8vs8mgZcuWLF68ON1hiIiUKWb2TaL5aiYSERElAxERUTIQERGUDEREBCUDERFByUBERCjDQ0slPbZv38769evZvXt3ukORMiojI4OGDRtSq1atdIciMZQMJLLt27ezbt06mjVrRtWqVTGzdIckZYy7s3PnTlatWgWghFCKqJlIIlu/fj3NmjWjWrVqSgRSJGZGtWrVaNasGevXr093OBKjzCeDFSOPyfN97LQU3+7du6latWq6w5CDQNWqVdXUmGQdb/5Lrvfx0wUp88lAUktnBJIM+ndU+igZiIiIkoGUP8OHD8fMMDMqVKhA3bp1OfHEE7njjjtYu3ZtusPLMXz4cOrXr1/o9SZNmsSzzz57wPwuXbrQr1+/JEQmByONJpJii9IeWRKWjPl1kdetXbs2r7/+OgDbtm3jgw8+YPz48UyYMIHXX3+djh07JivMIrviiis499xzC73epEmT2LhxI5dddlmu+ePGjSMjIyNJ0cnBRslAyqVKlSpxyimn5Ez36NGDa665htNPP53+/fvz+eefU7FixbTEtnv3bipUqEBWVhZZWVlJq/fII49MWl1y8FEzkUioTp06jB49mq+++oq5c+cCsGvXLm655RaaN29O5cqVOe6443j11VdzrTdz5kw6duxI9erVqVu3LieffDILFy7MWb53714eeOABDj/8cCpXrkxWVlauX+3ZzTcTJkygdevWVKlShdWrVx/QTLRgwQLMjDlz5tCnTx+qV6/OoYceyuOPP55T5rLLLmPKlCksXLgwpyls+PDhubYT68033+Tkk0+mSpUqNGrUiGuvvZbvvvvugG0uWLCAiy++mBo1atCqVSvGjRuXq55PP/2Unj17kpmZSfXq1TniiCN47LHHivZFSFqUm2SgYaYSRdeuXalUqRLvvfceAP369ePZZ5/l9ttvZ9asWZx44omcd955fPjhhwB89dVX9OvXjzPPPJNZs2bx/PPP06dPHzZv3pxT51VXXcU999zDJZdcwuzZs3n44Yf5/vvvc2333XffZfz48YwaNYpZs2ZRu3btPGP8zW9+w7HHHsvUqVM555xzuOaaa5g9ezYAd911F127dqVDhw4sWrSIRYsWccUVVySsZ9myZfTs2ZP69eszZcoURowYwQsvvJCwX+HKK6/kuOOOY9q0aXTp0oXrrruO999/P2f5eeedR8WKFfnb3/7GzJkzGTJkCDt27Ii20yWyogwZjUrNRCIxKleuTP369Vm3bh3/+Mc/eOWVV1iwYAFnnHEGAGeffTb//e9/ue+++5g8eTJLly6lZs2ajBkzJqeOXr165bz/7LPPmDhxIn/84x/57W9/mzO/f//+uba7detWli5dSuPGjQuM8ZxzzuH+++8Hguat5cuXc++999KnTx9at25NZmYm+/bty9UMlsjIkSNp0aIFM2fOzGkSy8zMpH///ixatIjOnTvnlL300ku58847geAMY9asWUydOpWTTjqJjRs3snz5cqZPn84xxwQ/urp161bg55DSpdycGYhE5e4AzJs3j8aNG3PqqaeyZ8+enFe3bt1yHrl6zDHHsG3bNgYOHMicOXMO+MU/f/58gAM6c+N17NgxUiIA6Nu3b67pCy+8kCVLlrB3795I62d7//336du3b66+kYsuuohKlSrxzjvv5Cp79tln57zPyMigbdu2rFy5EggSSPPmzbn66qt5+eWXdWVxGaVkIBJj165dbNq0iUaNGrFx40bWrl1LRkZGrtfw4cP59ttvAWjXrh0zZsxg+fLl9OrVi/r16zNgwAA2bNgAwKZNm6hevXqB9+Bp1KhR5BgbNmx4wPSePXvYuHFjoT7rmjVrDthuxYoVqVevXq5mLgj6U2Idcsgh7Nq1C4AKFSowZ84cGjduzOWXX07jxo057bTTWLp0aaHikfRSMhCJMX/+fPbs2UPnzp3JzMykWbNm/Pvf/z7gld2nANC7d2/efvttNm3axMSJE5k3bx5DhgwBoF69enz//fds37493+0W5orc+F/e69evp1KlSoW+JqFJkyYH1LV37142bdpEZmZmoepq3749U6ZMYevWrcybN49du3bRu3dv9u3bV6h6JH2UDERCW7du5dZbb6VNmzacddZZdOvWjbVr11KjRg06dep0wCte7dq1GTBgAH379mXZsmUAnHnmmQD85S/J6+ibNm3aAdMdO3bMae6J/dWen5NPPplp06blal6aOnUqe/bs4ec//3mRYsvIyODMM89k2LBhrFmzhq1btxapHkk9dSBLubRnz56cX/c7duxgyZIljB8/nh9++IHXX3+dihUr0r17d3r06EH37t259dZbOeqoo9i+fTsffvghu3bt4oEHHuCJJ55g0aJF9OzZk6ZNm/LFF18wefJkfv3r4IK4du3aMWjQIG688UbWr1/P6aefztatW/n73//OSy+9VKTYX3vtNe644w7OOOMMpk6dyty5c5kxY0bO8vbt2zNjxgymT59OVlYWTZs2pWnTpgfUc+edd9KhQwcuuOACrrnmGlauXMmtt95Kjx49cnUeF+Sjjz7ipptuon///rRq1YotW7YwatQojjvuuEKfYUj6KBlIubRt2zY6d+6MmVGrVi3atGnDL3/5S4YMGZLTkWtmTJ06lfvvv5+xY8eyYsUKMjMzOf7443OagY499lhmzpzJsGHD2Lx5M02aNOHKK69k5MiROdsaN24cLVq04KmnnuLBBx+kYcOGdO/evcixP/XUU4wdO5ZHHnmEzMxMHnvsMc4777yc5ddeey1Lly7l8ssvZ8uWLdxzzz051xrEOuqoo3jttde4/fbbufDCC6lVqxaXXnopo0ePLlQ8jRs3plGjRtx3332sXr2aOnXq0LVrV0aNGlXkzyhp4O5l8tWxY0d3d/9mxNGeLf59UZdJYsuWLUt3COXa/PnzHfCPP/443aEkhf497XfCTc/leh8/HXVZlHLAYk9wTFWfgYiIKBmIiIj6DETKjC5duuRcECeSbCk9MzCz5mY238z+Y2afmtn14fzhZrbKzD4MX70KqktERJIn1WcGe4Ab3f0DM6sJLDGzueGyR9z9oRTHIyIipDgZuPsaYE34foeZ/QdolsoYRETkQGnrQDazlkAH4F/hrMFm9pGZPW1mdfNYZ5CZLTazxdn3fhERKQtK8vbTyZCWZGBmNYApwA3uvh0YD7QGjic4c3g40XruPsHdO7l7pwYNGqQqXBGRg17Kk4GZZRAkgufdfSqAu69z973uvg94Ejgp1XGJiJRnqR5NZMBE4D/u/oeY+U1iivUFPkllXCIi5V2qzwxOBX4FnBk3jHS0mX1sZh8BXYGhKY5LypH4Zwsnw4QJE5g+fXpS64xi9OjRLFiw4ID5Zsajjz6a8nik7Er1aKJ3gEQ3bn81wTwpI9L1fOlD7/44LdtNZMKECRx99NFccMEFKd3u6NGjGTx4MF26dMk1f9GiRRx22GEpjUXKNl2BLJJCO3fupGrVqiW+nYKefywST/cmyseKkcfk+tWbrl/AUnIWLFiAmbFgwQIuvvhiatSoQatWrRg3blyucp9++ik9e/YkMzOT6tWrc8QRR/DYY48BwW0ilixZwnPPPYeZYWY8++yzALRs2ZIbb7yR3//+92RlZeU8/rJLly7069cvYSyffLK/y2znzp3ccssttGjRgsqVK3PYYYfxu9/9LqfuTZs2MWLEiJztZjcZJWomevTRR2nbti2VK1emTZs2PPLII7mWZzefLV26lFNOOYVq1arRoUMH3n777VzlZs6cSceOHalevTp169bl5JNPZuHChUXY+we/0jZ8ND86MxABrrzySgYOHMigQYN48cUXue666+jUqRMnnRQMbDvvvPNo3749f/vb36hcuTKff/55zqMsx40bx0UXXUSrVq246667AGjdunVO3S+88AJHHXUU48aNY8+ePZFjcnfOP/98Fi1axF133UXHjh1ZtWpVzsF52rRpdO3alX79+nHFFVcAcOSRRyas68knn2TIkCEMGzaMHj16MH/+fG688UZ+/PFHbrvttpxyP/zwAwMHDmTo0KE0btyYESNG0LdvX1asWEG1atX46quv6NevH9dffz1jxoxh165dLFmy5IBnJkvZo2QgAlx66aXceeedQPCrfdasWUydOpWTTjqJjRs3snz5cqZPn84xxwRnh926dctZ98gjj6R69eo0aNAgz+aZ2bNnU6VKlULFNGfOnJynmMU+vCb7KWodOnSgUqVKZGVl5dsstG/fPoYPH85ll13Gww8Hl/CcffbZbNu2jQceeIAbbrghJ7adO3cyduzYnMd1NmnShA4dOvDWW2/Rs2dPli5dSs2aNRkzZkxO/b166VZiBwM1E4kQHByzZWRk0LZtW1auXAlAZmYmzZs35+qrr+bll18+4CHyBenWrVuhEwHAm2++SWZmZq5EUBQrV65k9erVXHzxxbnm9+/fn+3bt/Pxx/s74jMyMnJ1RmefaWTvi2OOOYZt27YxcOBA5syZw/fff1+s2KT0UDIQAerUqZNrOvah8hUqVGDOnDk0btyYyy+/nMaNG3PaaaexdOnSSHU3atSoSDFt2rSJJk2aFFywAGvWrEkYR/Z0bBNPrVq1qFBh/2HhkEMOAcjZF+3atWPGjBksX76cXr16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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ordering = exp1_trials.drop_duplicates([\"workerid\", \"n_instructions\"]).sort_values(\"n_instructions\", ascending=False).workerid\n",
    "\n",
    "sns.countplot(data=exp1_trials, x=\"workerid\", hue=\"message_type\", order=ordering, hue_order=[\"Descriptions\", \"Instructions\"])\n",
    "plt.suptitle(\"Data from {} participants.\".format(exp1_trials.workerid.nunique()))\n",
    "plt.xticks([])\n",
    "plt.xlabel(\"Individual Participants\", fontsize=15)\n",
    "plt.legend(loc='best', fontsize=15)\n",
    "plt.ylabel(\"Message Count\", fontsize=15)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "a3d42a97-0f6f-454b-87d4-1b1ddce58925",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp1_trials[exp1_trials.n_instructions.isin([0, 28])].workerid.nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "98beba5a-ac61-4c69-a633-060c8e789991",
   "metadata": {},
   "outputs": [],
   "source": [
    "count_by_horizon = exp1_trials.groupby([\"horizon\", \"message_type\"]).size().reset_index()\n",
    "count_by_horizon = count_by_horizon.rename({0:\"size\"}, axis=1)\n",
    "\n",
    "count_by_horizon[\"pct\"] = count_by_horizon.groupby(\"horizon\")[\"size\"].transform(lambda x: x/x.sum())\n",
    "# count_by_horizon.size()#.transform(lambda x: x / x.sum())\n",
    "# mean_by_horizon = exp1_trials"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "4fb4bdca-e234-44b7-afb7-154748f32a0b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'Speaker Horizon $H$')"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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r1789re/bRT5QkWw+/n379/P559/zpw5c1i6dCkzZszwuvann36ib9++9nlKSgpDhw61hwm9e/dutj2ipkiD7uc3BIenO+zmOtEXDAkJCQwfPpzhw4cHzPedL9i9ezdvv/02b7/9NmB5Lj7ppJPsh0Hnzp0bXGZDzRjlryelpaWA1dIVFBSEWZrwMWbMGNLT05k9ezZz5szxiw24ZcsWXn31VV599VWOPvpovvzyyzBJanBjlD9ENGTI7eZAZmYmF110ERdddBGqyvLly+35grlz57Jz5067rO98AcDTTz/N8uXLGTZsGIMHDyY5ObkxxY9IjPKHiKbgraepICJ0796d7t27c80111BZWcn3339vPwxGjhzpd83kyZP58ssvefjhh4mJiWHQoEH2EOGYY45p8kZTzREz4VcNwU74AeTn53PJJZc0hlghpyk48CwpKSE9Pb3aQKKJiYmccMIJDBs2jOHDh3PYYYdFdC8LzIRfk6ElT/Q1BvHx8bz99tt2z8A3pmBpaSmzZs1i1qxZgDXJagKg1B8nzjwqReSuWsrcISIV9Rer+RAfH0/Pnj3DLUazJi4ujtNPP52HH36YH374ga1bt/L6669zxRVX+E2itm/f3mtJEawQ6Jdeeikvv/yycVDiACctf7AReyJqMbd///7GmCXEtG/fnjFjxjBmzBgA1qxZY/cK2rZt62cv8NFHHzF58mTbLVnv3r3t+YIhQ4YYM+RqCPW/Ng0oC3GdTYr9+73dGTTlffvBcM8994RbhFrJy8tjwoQJXv4HPfG1MVi6dClLly7lscceIyoqioEDB9oPg+OOO474+PjGELvJU6Pyi8hgn6S8AGkA0Vg7/i4ElgXIbzH4jkezsrLCJEloaAkhuv785z/Tp08f5syZwxdffOFlhlxVVcVXX33FV199xQMPPMCf/vQnHnnkkTBK23SoreWfx6EQXQqMcx2BEKAKuCkkkjVR1q2L+DCETY4BAwYwYMAA7rzzTkpLS/nss8/sYcK3337rtYpx0kkn+V1/9913065dO4YNG0avXr3CbobcWPETa1zqE5FCDnnwuRvrYTA/QNFKoAiYq6q/hFzKMFDdUp+qcu+9h4IWNYducySzc+dO5s2bx5w5c5g3bx4LFizwCqKyf/9+0tLSOHDgAADZ2dleZsidOtUalzbkBLP82uBLfapa6HGzccAM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aGCcmPcOBGYAO4AbgKOxdvkBoKoLRWQ1cC7wWmjFNDQ2J554IjExMSxcuJBTTjmF0aNH89VXXzFx4kS6dOnClClTOOuss1i0aBGHH344K1euZPTo0Vx//fX8/e9/p6ysjG+++YadO3fadV511VW8+OKL3HzzzQwZMoSdO3f6jbs///xzVq5cyYMPPkhiYiKpqanVyjhhwgQuvvhirr32WqZNm8Y111xDbm4uZ5xxBnfddRfr1q1j165dtoJW13tYunQpp5xyCiNGjGDq1KmsX7+eW2+9lVWrVtlDIjdXXHEF48aN48orr+S1117jD3/4AwMHDuToo48G4KyzzqJnz568/PLLxMXFsWzZMnbv3l2n36DBUdWgDmAmsBPIcp3fA1T6lHkNWBZsnU35GDBggNbE0qVLa8x3SmFhoX00Fvfcc49mZGRUm5+VlaVXX321zp49WwGdN2+eV/4JJ5ygo0ePVlXVN998U9PT06ut6+eff1ZAH3300WrLDBkyROPj43Xz5s01yjl37lwF9IorrvAqN3z4cB00aJB9ft555+mQIUMC3ue8886zz8eMGaNdu3bViooKO+2NN95QQL/44guve9511112mfLycm3btq3ecsstqqq6fft2BXTx4sXVfsbqcPp/AhZpPf/jTsb8xwEzVHVLDWXWA6c7evq0INwz5+GsJ5RBHq3/GMyePZusrCyOO+44KioOBWQaNmwYkydPBqBfv36UlJQwbtw4LrzwQo477jiSkpLssnPnzgXwm3zzZcCAAUGvMpx77rle56NGjeK6666jsrLS0TzFV199xejRo72uOe+884iJieGzzz7j2GOPtdNPPvlk+31sbCzdunVjw4YNAKSnp9OxY0euvvpqrrvuOk488UTat28ftByNjZMxfzJWl78mEh3WaWiilJWVUVRURGZmJjt27GDLli3ExsZ6HYWFhaxfvx6AHj16MHPmTFatWsVpp51G27ZtGTt2LNu3W4GcioqKSEpKqtV+PTMzM2gZfRWrffv2VFRUOF4S3Lx5s999o6OjycjI8Bq2gDUf4kmrVq0oK7Oi0kdFRfHhhx+SlZXFZZddRlZWFieccALfffedI3kaCyeKuhHoU0uZw7E8+BqaOXPnzqWiooJjjz2W9PR0cnJy+Prrr/2OhQsX2tecfvrpfPrppxQVFTFp0iRmz57NtddeC0BG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\n",
      "text/plain": [
       "<Figure size 216x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import math\n",
    "\n",
    "descriptions = count_by_horizon[count_by_horizon.message_type == \"Descriptions\"]\n",
    "instructions = count_by_horizon[count_by_horizon.message_type != \"Descriptions\"]\n",
    "\n",
    "# plt.plot(instructions.horizon, instructions.pct, c='black', linewidth = 5)\n",
    "# plt.plot(descriptions.horizon, descriptions.pct, c='black', linewidth = 5)\n",
    "\n",
    "description_err = descriptions.apply(lambda x: 1.96 * math.sqrt(x['pct']*(1-x['pct'])/x['size']), axis=1)\n",
    "# instruction_err = instructions.apply(lambda x: 1.96 * math.sqrt(x['pct']*(1-x['pct'])/x['size']), axis=1)\n",
    "\n",
    "plt.figure(figsize=(3,5))\n",
    "ax = plt.gca()\n",
    "ax.errorbar(descriptions.horizon, descriptions.pct, description_err,  color='gray', ecolor='gray',  linewidth=3, label=\"Descriptions\")\n",
    "ax.errorbar(instructions.horizon, instructions.pct, description_err,  color='k', ecolor='k', linewidth=3, linestyle='--', label=\"Instructions\")\n",
    "\n",
    "plt.legend(loc='best', fontsize=15)\n",
    "ax.set_ylim(0, .8)\n",
    "plt.xticks([1, 2, 4], fontsize=15)\n",
    "ys = [0, .25, .5, .75]\n",
    "for y in ys:\n",
    "    plt.axhline(y, alpha=.2, linestyle='--', c='k', zorder=0)\n",
    "plt.yticks(ys, fontsize=15);\n",
    "\n",
    "plt.ylabel(\"Percent of Utterances\", fontsize=20)\n",
    "plt.xlabel(\"Speaker Horizon $H$\", fontsize=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "150cdcd3-19fe-48a9-9d22-dd377da3fd9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<seaborn.axisgrid.FacetGrid at 0x7fb981635cd0>"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 904.65x576 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "random_ids = exp1_trials.workerid.sample(8)\n",
    "\n",
    "random_sample = exp1_trials[exp1_trials.workerid.isin(random_ids)]\n",
    "\n",
    "g = sns.catplot(x=\"horizon\", hue=\"message_type\", col=\"workerid\",\n",
    "                data=random_sample, kind=\"count\", col_wrap = 4, hue_order=[\"Descriptions\", \"Instructions\"],\n",
    "                height=4, aspect=.7);\n",
    "\n",
    "g.set_titles(\"\")\n",
    "g.set_axis_labels(x_var=\"Horizon $H$\", y_var=\"Message Type Count\", fontsize=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "29f9292e-8d6f-479a-a3a5-5163dfab1420",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 15.0, '')"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def heatmap_descriptions(to_plot_messages, title=\"\", vmax=None):\n",
    "    \n",
    "    descriptions = to_plot_messages[~to_plot_messages.instruction]\n",
    "    if len(descriptions) == 0:\n",
    "        print(\"{}: found 0 descriptions.\".format(to_plot_messages.workerid.unique()))\n",
    "        return\n",
    "              \n",
    "    to_plot_messages = descriptions\n",
    "        \n",
    "    percent_of_messages = (to_plot_messages.groupby([\"feature\", \"feature_value\"]).size() / len(to_plot_messages)).reset_index()\n",
    "\n",
    "    unique_values = set(percent_of_messages.feature_value.unique())\n",
    "    missing_vals = unique_values.symmetric_difference({-2, -1, 1, 2})\n",
    "    \n",
    "    if missing_vals:\n",
    "        print(\"Message with val {} not found-- appending.\".format(missing_vals))\n",
    "        for val in missing_vals:\n",
    "            percent_of_messages = percent_of_messages.append({\"feature\": \"Blue\", \"feature_value\": val}, ignore_index=True)\n",
    "    \n",
    "    message_table = percent_of_messages.pivot(\"feature_value\", \"feature\", 0)\n",
    "\n",
    "    features_in_descending_order = [\"Green\", \"Spotted\", \"Striped\", \"Blue\"]\n",
    "    message_table = message_table.reindex(features_in_descending_order, axis=1).fillna(0)\n",
    "    \n",
    "    plt.figure()\n",
    "    ax = sns.heatmap(message_table, cmap=\"Oranges\", vmax=vmax, annot=True)\n",
    "    ax.invert_yaxis()\n",
    "    ax.set_title(\"{} Descriptions\".format(len(to_plot_messages)), fontsize=20)\n",
    "#     ax.set_xticks([])\n",
    "#     ax.set_yticks([])\n",
    "    ax.set_xlabel(\"Features\")\n",
    "    ax.set_ylabel(\"Values\")\n",
    "    \n",
    "heatmap_descriptions(exp1_trials, vmax=.45)#, annot=True)\n",
    "plt.yticks(fontsize=15)\n",
    "plt.ylabel(\"Values\", fontsize=20)\n",
    "plt.xticks([])\n",
    "plt.xlabel(\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "9859c843-d06e-4ee5-9916-f0b19259fdbc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "instruction_color  instruction_texture\n",
       "Blue               Solid                    4\n",
       "                   Spotted                 16\n",
       "                   Striped                  2\n",
       "Green              Solid                  266\n",
       "                   Spotted                514\n",
       "                   Striped                152\n",
       "Red                Solid                   83\n",
       "                   Spotted                142\n",
       "                   Striped                 24\n",
       "dtype: int64"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "instructions = exp1_trials[exp1_trials.instruction]\n",
    "\n",
    "instructions.groupby([\"instruction_color\", \"instruction_texture\"]).size()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "b0fd8a79-18ba-4275-91c8-76515d4b9c37",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([], [])"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def heatmap_instructions(to_plot_messages, title=\"\", vmax=None):\n",
    "    \n",
    "    instructions = to_plot_messages[to_plot_messages.instruction]\n",
    "    if len(instructions) == 0:\n",
    "        print(\"{}: found 0 descriptions.\".format(to_plot_messages.workerid.unique()))\n",
    "        return\n",
    "              \n",
    "    to_plot_messages = instructions\n",
    "        \n",
    "    percent_of_messages = (to_plot_messages.groupby([\"instruction_color\", \"instruction_texture\"]).size() / len(to_plot_messages)).reset_index()\n",
    "\n",
    "    message_table = percent_of_messages.pivot(\"instruction_texture\", \"instruction_color\", 0)\n",
    "\n",
    "    color_order = [\"Green\", \"Red\",  \"Blue\"]\n",
    "    texture_order = [\"Spotted\", \"Solid\", \"Striped\"]\n",
    "\n",
    "    message_table = message_table.reindex(color_order, axis=1).fillna(0)\n",
    "    message_table = message_table.reindex(texture_order, axis=0).fillna(0)\n",
    "    \n",
    "    plt.figure()\n",
    "    ax = sns.heatmap(message_table, cmap=\"Oranges\", annot=True)\n",
    "    ax.set_title(title, fontsize=20)\n",
    "    ax.set_xlabel(\"\")\n",
    "    ax.set_ylabel(\"\")\n",
    "    \n",
    "title = \"{} Instructions\".format(len(instructions))\n",
    "\n",
    "heatmap_instructions(instructions, title=title, vmax=.45)\n",
    "plt.xticks([])\n",
    "plt.yticks([])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5803012d-f940-4f02-ad4a-adb39a67ae8f",
   "metadata": {},
   "source": [
    "## Export for R"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "a1cd74a0-c043-47e6-a23f-6387320f11ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "def utterance_to_string(utt):\n",
    "    if utt['texture'] != '':\n",
    "        return f'{utt[\"texture\"]} {utt[\"color\"]}'\n",
    "    else:\n",
    "        return f'{utt[\"feature\"]} {utt[\"feature_value\"]}'\n",
    "\n",
    "exp1_trials['utterance_for_r'] = exp1_trials.utterance.apply(lambda x: utterance_to_string(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "4ac2f46a-b1a1-4e15-a02a-a168cb2ca6a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp1_trials[['horizon', 'utterance_for_r']].to_csv(\"utterance_counts_for_r.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "9e599f8e-8651-427a-893f-afad1f411305",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1    939\n",
       "2    917\n",
       "4    916\n",
       "Name: horizon, dtype: int64"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp1_trials.horizon.value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "0543266b-9c86-4030-8106-f5b242c1811c",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp1_trials[\"utt\"] = exp1_trials.data.apply(lambda x: x.get('response'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "2745b6d2-b32a-435b-afce-7a105a1000bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_to_theory_map = {\"Blue\": \"blue\", \"Green\": \"green\", \"Red\": \"red\",\n",
    "                     \"Spotted\": \"circle\", \"Solid\": \"triangle\", \"Striped\": \"square\"}\n",
    "\n",
    "def extract_single_action_trials(trial):\n",
    "    \n",
    "    action_context = trial[\"data\"][\"action_context\"][0]\n",
    "    context = [{\"color\": exp_to_theory_map[a[\"color\"]], \"shape\": exp_to_theory_map[a[\"texture\"]]} for a in action_context]\n",
    "    \n",
    "    base = {\"action_context\": context,\n",
    "            \"workerid\": trial[\"workerid\"],\n",
    "            \"horizon\": trial[\"horizon\"]}\n",
    "    \n",
    "    utt = {}\n",
    "    \n",
    "    if trial[\"instruction\"]:\n",
    "        utt[\"color\"] = exp_to_theory_map[trial[\"instruction_color\"]]\n",
    "        utt[\"shape\"] = exp_to_theory_map[trial[\"instruction_texture\"]]\n",
    "        utt[\"type\"] = \"instruction\"\n",
    "    \n",
    "    elif not trial[\"instruction\"]:\n",
    "        utt[\"type\"] = \"description\"\n",
    "        utt[\"feature\"] = exp_to_theory_map[trial[\"feature\"]]\n",
    "        utt[\"value\"] = int(trial[\"feature_value\"])\n",
    "    base[\"utt\"] = utt\n",
    "    return base"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "6fb3b768-ad05-4b6f-a221-36bf30436baa",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = exp1_trials.apply(lambda x: extract_single_action_trials(x), axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "84a5453d-cc90-4892-b29f-57fdf1860433",
   "metadata": {},
   "outputs": [],
   "source": [
    "json.dump(list(results.values), open(\"data/exp_utterances.json\", \"w\"))"
   ]
  }
 ],
 "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
}
