{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Analysis of Intrinsic Dimension in Data in Rats (Tafazoli et al., 2017)\n",
    "\n",
    "The data analyzed here are published in:  *“Emergence of transformation tolerant representations of visual objects in rat lateral extrastriate cortex”* by Sina Tafazoli, Houman Safaai, Gioia De Franceschi, Federica Bianca Rosselli, Walter Vanzella, Margherita Riggi, Federica Buffolo, Stefano Panzeri and Davide Zoccolan, **ELife 6-e22794 (2017)**."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Relevant Imports and Path Directories\n",
    "\n",
    "Here we import the needed libraries and the relevant paths to both stimuli and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from os import listdir\n",
    "from tqdm import tqdm\n",
    "from scipy.io import loadmat\n",
    "from matplotlib import rc\n",
    "from utils.intrinsic import IntrinsicDim\n",
    "\n",
    "data_path = 'path_to_data/processed/'\n",
    "\n",
    "data_V1 = 'X_0.mat'\n",
    "data_LM = 'X_1.mat'\n",
    "data_LI = 'X_2.mat'\n",
    "data_LL = 'X_3.mat'\n",
    "\n",
    "ID = IntrinsicDim()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                         \r"
     ]
    }
   ],
   "source": [
    "V1 = loadmat(data_path + data_V1)['X'].T\n",
    "LM = loadmat(data_path + data_LM)['X'].T\n",
    "LI = loadmat(data_path + data_LI)['X'].T\n",
    "LL = loadmat(data_path + data_LL)['X'].T\n",
    "\n",
    "def sampler(S, size, rep): \n",
    "    return (np.random.choice (S, size = size, replace = False) for _ in range(rep))\n",
    "\n",
    "def scanN (X, bins, rep):\n",
    "    return np.array ([[ID(X[:, pop])[0] for pop in sampler(X.shape[1], s, rep)] \n",
    "                      for s in tqdm(bins, desc = \"Scan N\", leave = False)])\n",
    "def scanI (X, bins, rep):\n",
    "    return np.array ([[ID(X[imgs, :])[0] for imgs in sampler(X.shape[0], s, rep)] \n",
    "                      for s in tqdm(bins, desc = \"Scan I\", leave = False)])\n",
    "\n",
    "rep = 25\n",
    "ID_V1 = scanN (V1, np.arange (5, V1.shape[1]), rep), scanI (V1, np.arange(5, V1.shape[0]), rep)\n",
    "ID_LM = scanN (LM, np.arange (5, LM.shape[1]), rep), scanI (LM, np.arange(5, LM.shape[0]), rep)\n",
    "ID_LI = scanN (LI, np.arange (5, LI.shape[1]), rep), scanI (LI, np.arange(5, LI.shape[0]), rep)\n",
    "ID_LL = scanN (LL, np.arange (5, LL.shape[1]), rep), scanI (LL, np.arange(5, LL.shape[0]), rep)\n",
    "\n",
    "# Here we save the computed trends\n",
    "data = {'ID_V1' : ID_V1, 'ID_LM' : ID_LM, 'ID_LI' : ID_LI, 'ID_LL' : ID_LL}\n",
    "savefile = 'path_to_savefile/*.pkl'\n",
    "\n",
    "with open (savefile, 'wb') as f:\n",
    "    pickle.dump (data, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "<hr>\n",
    "\n",
    "# Power Law Fit on Data\n",
    "\n",
    "In this section we fit a power-law on the computed ID trends on the data to extract an asymptotic value of the *intrinsic dimension*: $\\mathrm{ID}_\\infty$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "from scipy.optimize import curve_fit\n",
    "\n",
    "def power_law (x, IDinf, A, n): return IDinf - A / (x**n)\n",
    "\n",
    "loadfile = 'path_to_data/*.pkl'\n",
    "with open (loadfile, 'rb') as f:\n",
    "    data = pickle.load (f)\n",
    "    \n",
    "# Extract data and compute average trends with errors\n",
    "ID_V1, ID_LM = data['ID_V1'], data['ID_LM']\n",
    "ID_LI, ID_LL = data['ID_LI'], data['ID_LL']\n",
    "\n",
    "\n",
    "ID_V1_N, ID_V1_Nerr = np.mean (ID_V1[0], axis = 1), np.std(ID_V1[0], axis = 1)\n",
    "ID_LM_N, ID_LM_Nerr = np.mean (ID_LM[0], axis = 1), np.std(ID_LM[0], axis = 1)\n",
    "ID_LI_N, ID_LI_Nerr = np.mean (ID_LI[0], axis = 1), np.std(ID_LI[0], axis = 1)\n",
    "ID_LL_N, ID_LL_Nerr = np.mean (ID_LL[0], axis = 1), np.std(ID_LL[0], axis = 1)\n",
    "\n",
    "ID_V1_I, ID_V1_Ierr = np.mean (ID_V1[1], axis = 1), np.std(ID_V1[1], axis = 1)\n",
    "ID_LM_I, ID_LM_Ierr = np.mean (ID_LM[1], axis = 1), np.std(ID_LM[1], axis = 1)\n",
    "ID_LI_I, ID_LI_Ierr = np.mean (ID_LI[1], axis = 1), np.std(ID_LI[1], axis = 1)\n",
    "ID_LL_I, ID_LL_Ierr = np.mean (ID_LL[1], axis = 1), np.std(ID_LL[1], axis = 1)\n",
    "\n",
    "# Compute fit for the four rat visual areas\n",
    "ID_fit = {}; ID_fit_err = {}\n",
    "\n",
    "bounds = ((0, 0, 0.2), (np.inf, np.inf, np.inf))\n",
    "x, y, err = np.arange (5, np.size(ID_V1_N) + 5), ID_V1_N, ID_V1_Nerr\n",
    "ID_fit['V1'], ID_fit_err['V1'] = curve_fit (power_law, x, y, sigma = err, bounds = bounds, max_nfev = 5000)\n",
    "\n",
    "x, y, err = np.arange (5, np.size(ID_LM_N) + 5), ID_LM_N, ID_LM_Nerr\n",
    "ID_fit['LM'], ID_fit_err['LM'] = curve_fit (power_law, x, y, sigma = err, bounds = bounds, max_nfev = 5000)\n",
    "\n",
    "x, y, err = np.arange (5, np.size(ID_LI_N) + 5), ID_LI_N, ID_LI_Nerr\n",
    "ID_fit['LI'], ID_fit_err['LI'] = curve_fit (power_law, x, y, sigma = err, bounds = bounds, max_nfev = 5000)\n",
    "\n",
    "x, y, err = np.arange (5, np.size(ID_LL_N) + 5), ID_LL_N, ID_LL_Nerr\n",
    "ID_fit['LL'], ID_fit_err['LL'] = curve_fit (power_law, x, y, sigma = err, bounds = bounds, max_nfev = 5000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[array([16.75916739, 25.21899102,  0.41679408]), array([19.07335992, 26.23401669,  0.35117903]), array([32.99562301, 40.8014113 ,  0.2       ]), array([30.00241264, 36.33887741,  0.2       ])]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.colors as mc\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib import rc\n",
    "import colorsys\n",
    "\n",
    "rc('font', size = 14)\n",
    "\n",
    "def shade(color, amount=0.5):\n",
    "    try:\n",
    "        c = mc.cnames[color]\n",
    "    except:\n",
    "        c = color\n",
    "    c = colorsys.rgb_to_hls(*mc.to_rgb(c))\n",
    "    return colorsys.hls_to_rgb(c[0], 1 - amount * (1 - c[1]), c[2])\n",
    "\n",
    "areas = ('V1', 'LM', 'LI', 'LL')\n",
    "X = {'V1' : 0, 'LM' : 1, 'LI' : 2, 'LL' : 3}\n",
    "C = {'V1' : '#00b400', 'LM' : '#00b4ff', 'LI' : '#b400ff', 'LL' : '#ff0000'}\n",
    "off = {'Sina'     : np.random.uniform (-.15, .15, size = 4),\n",
    "       'Sina-Bld' : np.random.uniform (-.15, .15, size = 4),\n",
    "       'Sina-Fit' : np.random.uniform (-.15, .15, size = 4)}\n",
    "\n",
    "top = 1000\n",
    "x_V1, y_V1, err_V1 = np.arange(5, np.size(ID_V1_N) + 5), ID_V1_N, ID_V1_Nerr\n",
    "xf_V1, yf_V1 = np.arange(5, top), power_law (np.arange(5, top), *ID_fit['V1'])\n",
    "\n",
    "x_LM, y_LM, err_LM = np.arange(5, np.size(ID_LM_N) + 5), ID_LM_N, ID_LM_Nerr\n",
    "xf_LM, yf_LM = np.arange(5, top), power_law (np.arange(5, top), *ID_fit['LM'])\n",
    "\n",
    "x_LI, y_LI, err_LI = np.arange(5, np.size(ID_LI_N) + 5), ID_LI_N, ID_LI_Nerr\n",
    "xf_LI, yf_LI = np.arange(5, top), power_law (np.arange(5, top), *ID_fit['LI'])\n",
    "\n",
    "x_LL, y_LL, err_LL = np.arange(5, np.size(ID_LL_N) + 5), ID_LL_N, ID_LL_Nerr\n",
    "xf_LL, yf_LL = np.arange(5, top), power_law (np.arange(5, top), *ID_fit['LL'])\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots (ncols = 2, figsize = (12, 5));\n",
    "\n",
    "ax[0].fill_between (x_V1, y_V1 + err_V1, y_V1 - err_V1, color = C['V1'], alpha = 0.2)\n",
    "l1, = ax[0].plot (x_V1, y_V1, c = C['V1'], lw = 2)\n",
    "ax[0].plot (xf_V1, yf_V1, c = C['V1'], lw = 2, ls = '--')\n",
    "\n",
    "ax[0].fill_between (x_LM, y_LM + err_LM, y_LM - err_LM, color = C['LM'], alpha = 0.2)\n",
    "l2, = ax[0].plot (x_LM, y_LM, c = C['LM'], lw = 2)\n",
    "ax[0].plot (xf_LM, yf_LM, c = C['LM'], lw = 2, ls = '--')\n",
    "\n",
    "ax[0].fill_between (x_LI, y_LI + err_LI, y_LI - err_LI, color = C['LI'], alpha = 0.2)\n",
    "l3, = ax[0].plot (x_LI, y_LI, c = C['LI'], lw = 2)\n",
    "ax[0].plot (xf_LI, yf_LI, c = C['LI'], lw = 2, ls = '--')\n",
    "\n",
    "ax[0].fill_between (x_LL, y_LL + err_LL, y_LL - err_LL, color = C['LL'], alpha = 0.2)\n",
    "l4, = ax[0].plot (x_LL, y_LL, c = C['LL'], lw = 2)\n",
    "ax[0].plot (xf_LL, yf_LL, c = C['LL'], lw = 2, ls = '--')\n",
    "\n",
    "# ======== SCATTER PLOT ==========\n",
    "Sina_X    = dict(zip(areas, [x_V1, x_LM, x_LI, x_LL]))\n",
    "Sina_ID   = dict(zip(areas, [y_V1, y_LM, y_LI, y_LL]))\n",
    "Sina_IDe  = dict(zip(areas, [err_V1, err_LM, err_LI, err_LL]))\n",
    "Sina_Fit  = {area : ID_fit[area][0] for area in areas}\n",
    "Sina_Fite = {area : ID_fit_err[area][0][0] for area in areas}\n",
    "max_x = np.min ([Sina_X[area][-1] for area in Sina_X])\n",
    "xn_max = np.arange (5, max_x).size\n",
    "\n",
    "for i, (a1, a2) in enumerate(zip(areas, areas[1:])):\n",
    "    ax[1].plot ([X[a1] + off['Sina'][i], X[a2] + off['Sina'][i+1]],\n",
    "                 [Sina_ID[a1][-1], Sina_ID[a2][-1]], c = shade('k', 0.8), ls = '-')\n",
    "    \n",
    "    ax[1].plot ([X[a1] + off['Sina-Bld'][i], X[a2] + off['Sina-Bld'][i+1]],\n",
    "             [Sina_ID[a1][xn_max], Sina_ID[a2][xn_max]], c = shade('k', .8), ls = '--')\n",
    "    \n",
    "    ax[1].plot ([X[a1] + off['Sina-Fit'][i], X[a2] + off['Sina-Fit'][i+1]],\n",
    "             [Sina_Fit[a1], Sina_Fit[a2]], c = shade('k', .8), ls = '-.')\n",
    "\n",
    "for i, area in enumerate (areas):\n",
    "    full_c = shade (C[area], 0.8)\n",
    "    blnd_c = shade (C[area], 1.0)\n",
    "    fitt_c = shade (C[area], 1.2)\n",
    "    \n",
    "    dn, errn = Sina_ID[area], Sina_IDe[area]\n",
    "    ax[1].errorbar (X[area] + off['Sina'][i], dn[-1], errn[-10], color = full_c, fmt = 's', \n",
    "                 capsize = 5, ms = 12, mec = 'w')\n",
    "        \n",
    "    dn, errn = Sina_ID[area], Sina_IDe[area]\n",
    "    ax[1].errorbar (X[area] + off['Sina-Bld'][i], dn[xn_max], errn[xn_max], color = blnd_c, fmt = 'p', \n",
    "                 capsize = 5, ms = 14, mec = 'w')\n",
    "    \n",
    "    dn, err = Sina_Fit[area], Sina_Fite[area]\n",
    "    ax[1].errorbar (X[area] + off['Sina-Fit'][i], dn, np.sqrt(err), color = fitt_c, fmt = 'h',\n",
    "                   capsize = 5, ms = 13, mec = 'w')\n",
    "\n",
    "print ([ID_fit[area] for area in areas])\n",
    "    \n",
    "[a.spines['top'].set_visible(False) for a in ax]\n",
    "[a.spines['right'].set_visible(False) for a in ax]\n",
    "[a.set_ylabel ('ID') for a in ax]\n",
    "\n",
    "ax[0].spines['left'].set_bounds (2.5, 22.5)\n",
    "ax[1].spines['left'].set_bounds (10, 40)\n",
    "ax[0].spines['bottom'].set_bounds (0, 1000)\n",
    "ax[1].spines['bottom'].set_bounds (0, 3)\n",
    "\n",
    "#ax[0].set_ylim (-1, 22)\n",
    "ax[1].set_ylim (10, 40)\n",
    "ax[1].set_xlim (-0.3, 3.3)\n",
    "ax[1].set_xticks ([0, 1, 2, 3])\n",
    "ax[1].set_xticklabels(areas)\n",
    "ax[0].set_xlabel ('N units');\n",
    "#ax[1].set_xlabel ('N images');\n",
    "\n",
    "ax[0].legend ((l1, l2, l3, l4), areas, frameon = False)\n",
    "\n",
    "sina_n = ax[1].errorbar ([-1], [50], mfc = 'w', mec = 'k', fmt = 's', ms = 12)\n",
    "sina_m = ax[1].errorbar ([-1], [50], mfc = 'w', mec = 'k', fmt = 'p', ms = 15)\n",
    "sina_f = ax[1].errorbar ([-1], [50], mfc = 'w', mec = 'k', fmt = 'h', ms = 14)\n",
    "\n",
    "sina_lgd = ax[1].legend ((sina_n, sina_m, sina_f), ('full', 'matched', 'fit'), frameon = False, loc = 6)\n",
    "\n",
    "lsd = Line2D ([0], [0], color = 'k', ls = '-')\n",
    "lsdd = Line2D ([0], [0], color = 'k', ls = '--')\n",
    "lsddd = Line2D ([0], [0], color = 'k', ls = '-.')\n",
    "ax[1].legend ((lsd, lsdd, lsddd), ('full', 'matched', 'fit'), frameon = False, loc = 2)\n",
    "ax[1].add_artist (sina_lgd)\n",
    "\n",
    "fig.tight_layout ()\n",
    "fig.savefig ('savepath/name.png', dpi = 300)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
