{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import warnings\n",
    "import scipy.stats as stats\n",
    "\n",
    "pd.set_option('display.max_columns', None)\n",
    "pd.set_option('display.max_rows', 5000)\n",
    "pd.options.mode.chained_assignment = None \n",
    "sns.color_palette(\"Paired\");\n",
    "sns.set_theme();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "root_path = '../../../out/actual_adept/'\n",
    "nets = ['final_savi']\n",
    "net_names = ['m1'] \n",
    "sets = ['voe']\n",
    "\n",
    "# read pickle file\n",
    "tf = pd.DataFrame()\n",
    "sf = pd.DataFrame()\n",
    "af = pd.DataFrame()\n",
    "for set in sets:\n",
    "    for net,name in zip(nets, net_names):\n",
    "        with open(root_path + net + '/' + set + '/statistics/slotframe.csv', 'rb') as f:\n",
    "            sf_temp = pd.read_csv(f, index_col=0)\n",
    "        sf_temp['net'] = name\n",
    "        sf = pd.concat([sf,sf_temp])\n",
    "\n",
    "        with open(root_path + net + '/' + set + '/statistics/accframe.csv', 'rb') as f:\n",
    "            af_temp = pd.read_csv(f, index_col=0)\n",
    "        af_temp['net'] = name\n",
    "        af = pd.concat([af,af_temp])\n",
    "        \n",
    "# cast variables\n",
    "sf['visible'] = sf['visible'].astype(bool)\n",
    "sf['bound'] = sf['bound'].astype(bool)\n",
    "sf['occluder'] = sf['occluder'].astype(bool)\n",
    "sf['inimage'] = sf['inimage'].astype(bool)\n",
    "sf['alpha_pos'] = 1-sf['alpha_pos']\n",
    "sf['alpha_ges'] = 1-sf['alpha_ges']\n",
    "\n",
    "# scale to percentage\n",
    "sf['TE'] = sf['TE'] * 100\n",
    "\n",
    "# add surprise as dummy code\n",
    "sf['control'] = [('control' in set)  for set in sf['set']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# succesfull trackings: In the last visible moment of the target, the slot was less than 5% away from the target\n",
    "# determine last visible frame numeric\n",
    "grouping_factors = ['net','set','evalmode','scene','slot']\n",
    "ff = sf[sf.visible].groupby(grouping_factors).max()\n",
    "ff.rename(columns = {'frame':'last_visible'}, inplace = True)\n",
    "ff = ff[['last_visible']]\n",
    "\n",
    "# add dummy variable to sf\n",
    "sf = sf.merge(ff, on=grouping_factors, how='left')\n",
    "sf['last_visible'] = (sf['last_visible'] == sf['frame'])\n",
    "\n",
    "# same for first bound frame\n",
    "ff = sf[sf.visible & sf.bound & sf.inimage].groupby(grouping_factors).min()\n",
    "ff.rename(columns = {'frame':'first_visible'}, inplace = True)\n",
    "ff = ff[['first_visible']]\n",
    "\n",
    "# add dummy variable to sf\n",
    "sf = sf.merge(ff, on=grouping_factors, how='left')\n",
    "\n",
    "# extract the trials where the target was last visible and threshold the TE\n",
    "ff = sf[sf['last_visible']] \n",
    "ff['tracked_pos'] = (ff['TE'] < 10)\n",
    "ff['tracked_neg'] = (ff['TE'] >= 10)\n",
    "\n",
    "sf = sf.merge(ff[grouping_factors + ['tracked_pos', 'tracked_neg']], on=grouping_factors, how='left')\n",
    "\n",
    "# fill NaN with 0\n",
    "sf['tracked_pos'].fillna(False, inplace=True)\n",
    "sf['tracked_neg'].fillna(False, inplace=True)\n",
    "\n",
    "# check if objects were always visible if in inimage\n",
    "ff2 = sf[sf.inimage & sf.bound].groupby(grouping_factors).all()\n",
    "ff2.rename(columns = {'visible':'always_visible'}, inplace = True)\n",
    "ff2 = ff2[['always_visible']].reset_index()\n",
    "\n",
    "# add dummy variable to sf\n",
    "sf = sf.merge(ff2[grouping_factors + ['always_visible']], on=grouping_factors, how='left')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tracking Error"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Tracking Error in Last visbile moment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "count    35.000000\n",
      "mean     39.957022\n",
      "std      10.626502\n",
      "min      12.883994\n",
      "25%      35.907011\n",
      "50%      44.330632\n",
      "75%      46.388863\n",
      "max      53.448131\n",
      "Name: TE, dtype: float64\n"
     ]
    }
   ],
   "source": [
    "# tracking error of last visible moment\n",
    "temp = sf[sf.inimage & sf.bound & ~sf.occluder & sf.control & sf.last_visible]\n",
    "print(temp['TE'].describe())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/xh/wh529p1d6_q5rmyllt3dc9300000gn/T/ipykernel_55139/2851337353.py:3: FutureWarning: \n",
      "\n",
      "`shade` is now deprecated in favor of `fill`; setting `fill=True`.\n",
      "This will become an error in seaborn v0.14.0; please update your code.\n",
      "\n",
      "  sns.kdeplot(temp['TE'], shade=True, label='createdown_control').set(xlim=(0, 50), ylim=(0, 0.18), yticks=[0, 0.05, 0.1, 0.15])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'Final tracking error (%)')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# density plot of tracking error with a small imsag esize\n",
    "plt.figure(figsize=(4, 3))\n",
    "sns.kdeplot(temp['TE'], shade=True, label='createdown_control').set(xlim=(0, 50), ylim=(0, 0.18), yticks=[0, 0.05, 0.1, 0.15])\n",
    "\n",
    "# x-axis label\n",
    "plt.xlabel('Final tracking error (%)')\n",
    "\n",
    "# save plot as pdf to plots folder with small image size\n",
    "#plt.savefig('../../out/actual_adept/plots/createdown_control_te.pdf', bbox_inches='tight', dpi=300)\n",
    "#plt.savefig('plots/final_te.pdf', bbox_inches='tight')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Tracking Error Overall"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "grouping = (sf.inimage & sf.bound & ~sf.occluder & sf.control)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    1320.000000\n",
       "mean       25.399094\n",
       "std        12.475824\n",
       "min         1.644270\n",
       "25%        15.292900\n",
       "50%        25.306080\n",
       "75%        35.766330\n",
       "max        53.448131\n",
       "Name: TE, dtype: float64"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "temp = sf[grouping]\n",
    "temp['TE'].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    1100.000000\n",
       "mean       26.660324\n",
       "std        12.582855\n",
       "min         1.644270\n",
       "25%        16.359440\n",
       "50%        26.388717\n",
       "75%        37.690097\n",
       "max        53.448131\n",
       "Name: TE, dtype: float64"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# When Visible\n",
    "temp = sf[grouping & sf.visible]\n",
    "temp['TE'].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    220.000000\n",
       "mean      19.092940\n",
       "std        9.744673\n",
       "min        1.698414\n",
       "25%        9.469849\n",
       "50%       21.424258\n",
       "75%       27.371946\n",
       "max       35.643434\n",
       "Name: TE, dtype: float64"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# When Occluded\n",
    "temp = sf[grouping & ~sf.visible]\n",
    "temp['TE'].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/xh/wh529p1d6_q5rmyllt3dc9300000gn/T/ipykernel_55139/765099057.py:3: FutureWarning: The default value of numeric_only in DataFrameGroupBy.sum is deprecated. In a future version, numeric_only will default to False. Either specify numeric_only or select only columns which should be valid for the function.\n",
      "  temp = temp.groupby(['net','set', 'evalmode', 'scene', 'slot']).sum()\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "count    0.0\n",
       "mean     NaN\n",
       "std      NaN\n",
       "min      NaN\n",
       "25%      NaN\n",
       "50%      NaN\n",
       "75%      NaN\n",
       "max      NaN\n",
       "Name: occlusion_time, dtype: float64"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Occlusion time\n",
    "temp = sf[(sf.inimage & sf.bound & ~sf.occluder & sf.control & sf.tracked_pos) & (sf.first_visible < 20)]\n",
    "temp = temp.groupby(['net','set', 'evalmode', 'scene', 'slot']).sum()\n",
    "temp['occlusion_time'] = (temp['bound'] - temp['visible'])/temp['bound']\n",
    "temp['occlusion_time'].describe()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tracking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/xh/wh529p1d6_q5rmyllt3dc9300000gn/T/ipykernel_55139/3891763824.py:2: FutureWarning: The default value of numeric_only in DataFrameGroupBy.sum is deprecated. In a future version, numeric_only will default to False. Either specify numeric_only or select only columns which should be valid for the function.\n",
      "  temp = temp.groupby(['set', 'evalmode']).sum()\n"
     ]
    },
    {
     "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>set</th>\n",
       "      <th>evalmode</th>\n",
       "      <th>tracked_pos</th>\n",
       "      <th>tracked_neg</th>\n",
       "      <th>tracked_pos_pro</th>\n",
       "      <th>tracked_neg_pro</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>control</td>\n",
       "      <td>control</td>\n",
       "      <td>1</td>\n",
       "      <td>30</td>\n",
       "      <td>0.032258</td>\n",
       "      <td>0.967742</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       set evalmode  tracked_pos  tracked_neg  tracked_pos_pro  \\\n",
       "0  control  control            1           30         0.032258   \n",
       "\n",
       "   tracked_neg_pro  \n",
       "0         0.967742  "
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "temp = sf[(sf['frame']== 15) & ~sf.occluder & sf.control & (sf.first_visible < 20)]\n",
    "temp = temp.groupby(['set', 'evalmode']).sum()\n",
    "temp = temp[['tracked_pos', 'tracked_neg']]\n",
    "temp = temp.reset_index()\n",
    "\n",
    "temp['tracked_pos_pro'] = temp['tracked_pos'] / (temp['tracked_pos'] + temp['tracked_neg'])\n",
    "temp['tracked_neg_pro'] = temp['tracked_neg'] / (temp['tracked_pos'] + temp['tracked_neg'])\n",
    "temp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "temp = af[af.index == 'OVERALL']\n",
    "temp['mostly_tracked'] = temp['mostly_tracked'] / temp['num_unique_objects']\n",
    "temp['partially_tracked'] = temp['partially_tracked'] / temp['num_unique_objects']\n",
    "temp['mostly_lost'] = temp['mostly_lost'] / temp['num_unique_objects']\n",
    "g = temp[['mostly_tracked', 'partially_tracked', 'mostly_lost','set']].set_index(['set']).groupby(['set']).mean().plot(kind='bar', stacked=True);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/xh/wh529p1d6_q5rmyllt3dc9300000gn/T/ipykernel_55139/2601603061.py:1: FutureWarning: The default value of numeric_only in DataFrameGroupBy.mean is deprecated. In a future version, numeric_only will default to False. Either specify numeric_only or select only columns which should be valid for the function.\n",
      "  af[af.index == 'OVERALL'].groupby(['set']).mean()\n"
     ]
    },
    {
     "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>idf1</th>\n",
       "      <th>idp</th>\n",
       "      <th>idr</th>\n",
       "      <th>recall</th>\n",
       "      <th>precision</th>\n",
       "      <th>num_unique_objects</th>\n",
       "      <th>mostly_tracked</th>\n",
       "      <th>partially_tracked</th>\n",
       "      <th>mostly_lost</th>\n",
       "      <th>num_false_positives</th>\n",
       "      <th>num_misses</th>\n",
       "      <th>num_switches</th>\n",
       "      <th>num_fragmentations</th>\n",
       "      <th>mota</th>\n",
       "      <th>motp</th>\n",
       "      <th>num_transfer</th>\n",
       "      <th>num_ascend</th>\n",
       "      <th>num_migrate</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>set</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>control</th>\n",
       "      <td>0.462403</td>\n",
       "      <td>0.327823</td>\n",
       "      <td>0.78443</td>\n",
       "      <td>0.867853</td>\n",
       "      <td>0.362687</td>\n",
       "      <td>86.0</td>\n",
       "      <td>54.0</td>\n",
       "      <td>31.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>8482.0</td>\n",
       "      <td>735.0</td>\n",
       "      <td>76.0</td>\n",
       "      <td>21.0</td>\n",
       "      <td>-0.670802</td>\n",
       "      <td>0.082861</td>\n",
       "      <td>16.0</td>\n",
       "      <td>58.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             idf1       idp      idr    recall  precision  num_unique_objects  \\\n",
       "set                                                                             \n",
       "control  0.462403  0.327823  0.78443  0.867853   0.362687                86.0   \n",
       "\n",
       "         mostly_tracked  partially_tracked  mostly_lost  num_false_positives  \\\n",
       "set                                                                            \n",
       "control            54.0               31.0          1.0               8482.0   \n",
       "\n",
       "         num_misses  num_switches  num_fragmentations      mota      motp  \\\n",
       "set                                                                         \n",
       "control       735.0          76.0                21.0 -0.670802  0.082861   \n",
       "\n",
       "         num_transfer  num_ascend  num_migrate  \n",
       "set                                             \n",
       "control          16.0        58.0          0.0  "
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "af[af.index == 'OVERALL'].groupby(['set']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "loci22",
   "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.16"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "d2839d0e9541bab035fef4125947596ea3ae3b82b718279bba50f43b209afc8c"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
