{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6b96d2cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib created a temporary config/cache directory at /tmp/matplotlib-jjhab5uc because the default path (/afs/csail.mit.edu/u/c/czw/.config/matplotlib) is not a writable directory; it is highly recommended to set the MPLCONFIGDIR environment variable to a writable directory, in particular to speed up the import of Matplotlib and to better support multiprocessing.\n",
      "/storage/czw/anaconda3/envs/sss/lib/python3.7/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "from hydra import initialize, initialize_config_module, initialize_config_dir, compose\n",
    "from omegaconf import OmegaConf\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.axes as ax\n",
    "import matplotlib.cm as cm\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "module_path = os.path.abspath(os.path.join('..'))\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(module_path)\n",
    "from data.subject_data import SubjectData\n",
    "samp_rate = 2048"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe61bfbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "FLOAT_FEATURES = [\"delta_magnitude\", \"delta_pitch\", \"magnitude\", \"word_length\", \"rms\", \"pitch\", \"max_vector_magnitude\", \"mean_pixel_brightness\", \"max_global_angle\", \"gpt2_surprisal\", \"morpheme_count\", \"delta_rms\", \"face_num\", \"is_onset\", \"max_global_magnitude\", \"max_vector_angle\", \"max_mean_magnitude\", \"charecter_num\", \"word_diff\", \"bin_head\"] #NOTE that is_onset and bin_head are categorical variables, but for our purposes, can be treated as a float"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a2041369",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'data': {'name': '???', 'high_gamma': False, 'samp_frequency': 2048, 'raw_brain_data_dir': '/storage/datasets/neuroscience/ecog', 'movie_transcripts_dir': '/storage/czw/seeg_decoding/updated_word_features', 'subject': '???', 'electrodes': '???', 'brain_runs': '???', 'rereference': 'None', 'normalization': False, 'despike': False, 'delta': 0.25, 'duration': 0.25, 'interval_duration': 1.0, 'words': [], 'cached_transcript_aligns': '/storage/czw/seeg_decoding/saved_aligns', 'val_split': 0.1, 'test_split': 0.1, 'preprocessor': 'stft'}}\n"
     ]
    }
   ],
   "source": [
    "# duration=1.5\n",
    "# delta=-0.5\n",
    "duration=0.25\n",
    "delta=0.25\n",
    "\n",
    "with initialize(version_base=None, config_path=\"../conf\"):\n",
    "    cfg = compose(overrides=[\"+data=finetuning_template\", \n",
    "                             f'++data.duration={duration}', \n",
    "                             \"++data.interval_duration=1.0\",\n",
    "                             f'++data.delta={delta}',\n",
    "                             \"++data.movie_transcripts_dir=/storage/czw/seeg_decoding/updated_word_features\"])\n",
    "    print(cfg)\n",
    "#    ++data.name=\"sentence_position_finetuning\"\n",
    "data_cfg = cfg.data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "05af5379",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "elec = \"T1b2\"\n",
    "# elec = \"T1cIe11\"\n",
    "subj = \"sub3\"\n",
    "# elec, subj = \"O1aIb7_sub3\".split(\"_\")\n",
    "# elec, subj = \"LT3d3_sub2\".split(\"_\")\n",
    "# elec, subj = \"RT1aIa6_sub2\".split(\"_\")\n",
    "# elec, subj = \"RT1aIa6_sub2\".split(\"_\")\n",
    "\n",
    "\n",
    "data_cfg.subject = subj \n",
    "data_cfg.electrodes = [elec]\n",
    "data_cfg.brain_runs = [\"trial002\"]\n",
    "# data_cfg.brain_runs = [\"trial000\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "aa82ff59",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "10242it [00:01, 9306.76it/s]\n"
     ]
    }
   ],
   "source": [
    "subj_data = SubjectData(data_cfg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3a5e170c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_control_idxs(features, control):\n",
    "    '''\n",
    "        features -- dataframe of word features per word\n",
    "        control -- the name of a feature, e.g. rms\n",
    "        returns\n",
    "            a list of indexs, each of which correspond with a subsample of the control conditions\n",
    "    '''\n",
    "    #restrict attention to high (low) rms and compare between targets\n",
    "    if control in FLOAT_FEATURES:\n",
    "        high = np.percentile(features[control], 75)\n",
    "        low = np.percentile(features[control], 25)\n",
    "        if control in [\"bin_head\", \"is_onset\"]:\n",
    "            low, high = 0.4, 0.6\n",
    "        assert high > low\n",
    "        control_high_idxs = features[features[control] >= high].index\n",
    "        control_low_idxs = features[features[control] <= low].index\n",
    "        assert len(control_high_idxs) > 2 and len(control_low_idxs) > 2\n",
    "        return [control_high_idxs, control_low_idxs]\n",
    "    elif control == \"idx_in_sentence\":\n",
    "        onset_idxs = features[features[\"is_onset\"]==1].index\n",
    "        offset_idxs = features[features[\"is_offset\"]==1].index\n",
    "        midset_idxs = features[(features[\"is_onset\"]==0) & (features[\"is_offset\"]==0)].index\n",
    "        return [onset_idxs, midset_idxs, offset_idxs]\n",
    "    else:\n",
    "        print(\"control not found\")\n",
    "        import pdb; pdb.set_trace()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "de2824e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "words_df, neural_data = subj_data.words, subj_data.neural_data\n",
    "neural_data = neural_data[0].mean(axis=1)\n",
    "# neural_data = neural_data[0,:,:512].mean(axis=-1)\n",
    "# neural_data = neural_data[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b6d2064c",
   "metadata": {},
   "outputs": [],
   "source": [
    "#get onset, offset, midset and plot their box plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "69cba28d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10242,)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neural_data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "aa2eae1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "onset_idxs, midset_idxs, offset_idxs = get_control_idxs(words_df, 'idx_in_sentence')\n",
    "onset_data = neural_data[onset_idxs]\n",
    "midset_data = neural_data[midset_idxs]\n",
    "offset_data = neural_data[offset_idxs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "5a9562f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pval2star(p):\n",
    "    if p > 0.05:\n",
    "        return 'ns'\n",
    "    elif p > 0.01:\n",
    "        return '*'\n",
    "    elif p > 0.001: \n",
    "        return '**'\n",
    "    else:\n",
    "        return '***'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "be54d446",
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = [\"Onset\"]*len(onset_idxs) + [\"Midset\"]*len(midset_idxs) + [\"Offset\"]*len(offset_idxs)\n",
    "all_data = np.concatenate([onset_data, midset_data, offset_data])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b19a2c47",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\"label\": labels, \"activity\": all_data})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "04adc928",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "455.75626957109864"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.activity.max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "0fba7f00",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_peak_boxplot(df,onset_data, midset_data, offset_data):\n",
    "    plt.figure(dpi=900)\n",
    "    fig, ax = plt.subplots(figsize=(5, 4))\n",
    "    g = sns.boxplot(df, x=\"label\", y=\"activity\", color=\"grey\", ax=ax)\n",
    "    plt.ylabel(\"Response ($\\mu V$)\",size=25)\n",
    "    plt.xlabel(\"\")\n",
    "    plt.ylim(-250,650)\n",
    "\n",
    "    onset_peak = df.activity.max()\n",
    "    h = 50\n",
    "    g.plot([0,0.9],[onset_peak+h,onset_peak+h],lw=1.5, c='k')\n",
    "    _, onset_midset_pval = stats.ttest_ind(onset_data, midset_data, axis=-1)\n",
    "    onset_midset_stars = pval2star(onset_midset_pval)\n",
    "    g.text(0.5, onset_peak+h/2, onset_midset_stars, ha='center', va='bottom', color=\"k\", fontsize=25)\n",
    "\n",
    "    _, onset_offset_pval = stats.ttest_ind(onset_data, offset_data, axis=-1)\n",
    "    onset_offset_stars = pval2star(onset_offset_pval)\n",
    "    g.plot([0,2],[onset_peak+2.5*h,onset_peak+2.5*h],lw=1.5, c='k')\n",
    "    g.text(1, onset_peak+2*h, onset_offset_stars, ha='center', va='bottom', color=\"k\", fontsize=25)\n",
    "\n",
    "    _, midset_offset_pval = stats.ttest_ind(midset_data, offset_data, axis=-1)\n",
    "    midset_offset_stars = pval2star(midset_offset_pval)\n",
    "    g.plot([1.1,2],[onset_peak+h,onset_peak+h],lw=1.5, c='k')\n",
    "    g.text(1.5, onset_peak+h/2, midset_offset_stars, ha='center', va='bottom', color=\"k\", fontsize=25)\n",
    "    sns.despine()\n",
    "    ax.tick_params(labelsize=25, rotation=0)\n",
    "\n",
    "# g.fig.set_size_inches(15,15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "8e497619",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 5760x4320 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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R40aJV68eCEfj4+PF19++aVGmS+++MJk9erCPixERJQX+e7xtHv3blGzZs1siYubm5v49ttvRWpqqpJxWhxDJCwRERHCzs5Orvfjjz/WWVY9ubC3t89xIiVD1ZsTJixERJQX+Z7HuFevXrh27Rq+++47lChRQn781atXmDhxImrXro29e/fmt3rSYuXKlUhOTgYAODg44Ntvv9VZdsaMGShfvjwAICkpCStWrDB6vUREREp5p4UXrKysMH78eNy5cwdffPEF7O3t5WNhYWH46KOP0L59e1y+fPld4yQAu3btkrd9fX3h5uams6yNjQ1GjBgh7+/evdvo9RIRESlFkZWinJycMHfuXNy+fRvDhw/X6JT7999/o0mTJhg5ciQeP36sxOUKpVu3bskLTQJAly5dcj2na9eu8nZYWBhu375ttHqJiIiUlK/VmnXx8PDAhg0b8J///AeTJ0+WR5xkre4cGBiIyZMnY/LkyRqtMZS7K1euaOy3aNEi13MaNWoEGxsbeVXsK1euoHr16kapl3QTQiAxMdHUYZABODg4aF2NWAl83RRchnzdFCSKJixZ6tati0OHDuGPP/7A5MmTERISAiBzno85c+Zg3bp1mDdvHoYOHWqIy5ud169fw9fXF0FBQYiOjoa1tTWKFy+O+vXro0OHDhg6dGiuQ3tDQ0PlbRsbG7kfSU6yyt29ezdbHYaul3RLTEy0uIkQST/x8fFwdHQ0SN183RRchnzdFCSK3BLSpWPHjggODsbGjRtRtmxZ+fHIyEiMGDECTZs2xYkTJwwZglmIiYlBYGAgHj58iOTkZMTHx+PBgwfYu3cv/u///g8VKlTAqlWrcqzj4cOH8na5cuX0zsYrVKggbz948MBo9RIRESnJIC0s6iRJwrBhw9C/f38sX74cixYtkicgu3jxItq2bYtevXph8eLFqFKliqHDMRlPT0+ULVsWtra2eP78OW7cuIG0tDQAmQnNp59+isuXL2P9+vVaz1eftM3V1VXv66q33MTFxRmt3relpKQgJSVF63ULGwcHB8THx5s6DDIABwcHg9bN103BZMjXTUFi8IQli52dHaZNm4bRo0dj9uzZ+PHHH5GamgohBPbs2YMDBw5gwoQJmDFjBooWLWqssAxGpVKhQ4cOGDFiBLp06ZJt5E18fDy2bt2KGTNm4Pnz5wCADRs2oHr16pg6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\n",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_peak_boxplot(df, onset_data, midset_data, offset_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "2d3f253c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# neural_data = neural_data[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "addbff0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "00c53b11",
   "metadata": {},
   "outputs": [],
   "source": [
    "# neural_data.mean(axis=1).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "77818904",
   "metadata": {},
   "outputs": [],
   "source": [
    "# neural_data.mean(axis=0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "629200d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def equalize_target_among_control(all_control_idxs, target_idxs):\n",
    "    controlled_target = [l.intersection(target_idxs) for l in all_control_idxs]\n",
    "    min_size = min([len(l) for l in controlled_target])\n",
    "    truncated_idxs = [l[:min_size] for l in controlled_target]\n",
    "#     print([len(l) for l in truncated_idxs])\n",
    "    equalized_idxs = np.concatenate(truncated_idxs)\n",
    "    return equalized_idxs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "ecb4e5e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "control = \"rms\"\n",
    "all_control_idxs = get_control_idxs(words_df, control)\n",
    "controlled_onset_idxs = equalize_target_among_control(all_control_idxs, onset_idxs)\n",
    "controlled_onset_data = neural_data[controlled_onset_idxs]\n",
    "\n",
    "controlled_midset_idxs = equalize_target_among_control(all_control_idxs, midset_idxs)\n",
    "controlled_midset_data = neural_data[controlled_midset_idxs]\n",
    "\n",
    "controlled_offset_idxs = equalize_target_among_control(all_control_idxs, offset_idxs)\n",
    "controlled_offset_data = neural_data[controlled_offset_idxs]\n",
    "\n",
    "labels = [\"Onset\"]*len(controlled_onset_idxs) + [\"Midset\"]*len(controlled_midset_idxs) + [\"Offset\"]*len(controlled_offset_idxs)\n",
    "all_data = np.concatenate([controlled_onset_data, controlled_midset_data, controlled_offset_data])\n",
    "df = pd.DataFrame({\"label\": labels, \"activity\": all_data})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "e2468cdd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 5760x4320 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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e+zYsQNLlizR+20XyOkoeebMmXzvWGjjdVE0tvgekKt8+fL4/PPP0a5du0InIaxTpw7WrVuHXbt2FToJ4SeffIKIiAgMGjSo0LJ169bFxx9/jMOHD+dbpnr16jh//jwWLlyIwMBA+Pj4FGnm76KShLDysYpERfDo0SOcPHkS9+7dw8OHD+Hk5ITy5cvDz88PzZo1K/DNzBLu3LmDCxcu4Pbt23j69CkkSYKnpyfq1KmDFi1a6ExSZowbN27gzJkzuH//PpKTk+Hq6ory5cujbt26CAgIkCdbI2Wo1Wr8+eefiIqKglqthq+vL1q1agU/P78i1cfrouhs7T0gV0ZGBs6fP48bN27g3r17SE9Ph6urKypUqIAmTZrojPwyRnp6Oo4fP47o6Gh5CL6npydq1KiBgIAA+Pr6KvlrmAQTFiIiIrJ61pliEhEREWlhwkJERERWjwkLERERWT0mLERERGT1mLAQERGR1WPCQkRERFaPCQsRERFZPSYsREREZPWYsBAREZHVY8JCREREVo8JCxEREVk9JixERERk9ZiwEBERkdVjwkJERERW7/8DYWKxsao941sAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_peak_boxplot(df, onset_data, midset_data, offset_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38fb7e12",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
