{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cf14fbb0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import jax\n",
    "jax.config.update(\"jax_enable_x64\", True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9be2143a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src import data_utils\n",
    "from src.moment_utils import get_dimensionality_avg\n",
    "\n",
    "DATASET_ROOT = './'\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06e248f7",
   "metadata": {},
   "source": [
    "## Brainscore - MajajHong\n",
    "\n",
    "- Compute dimensionality for each (region, subject) pair with all estimators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5130de78",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/home/cchun/miniforge3/envs/brainscore/lib/python3.11/site-packages/brainscore_core/metrics/__init__.py:16: FutureWarning: xarray subclass Score should explicitly define __slots__\n",
      "  class Score(DataAssembly):\n",
      "brainscore-storage/brainio-brainscore/assy_dicarlo_MajajHong2015_public.nc: 100%|██████████| 165M/165M [00:06<00:00, 24.3MB/s] \n",
      "brainscore-storage/brainio-brainscore/stimulus_hvm-public.csv: 100%|██████████| 1.33M/1.33M [00:00<00:00, 3.09MB/s]\n",
      "brainscore-storage/brainio-brainscore/stimulus_hvm-public.zip: 100%|██████████| 132M/132M [00:01<00:00, 73.3MB/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('V4', 'Tito') (148480, 18)\n",
      "(28, 3200, 18)\n",
      "('V4', 'Chabo') (148480, 70)\n",
      "(28, 3200, 70)\n",
      "('IT', 'Tito') (148480, 110)\n",
      "(28, 3200, 110)\n",
      "('IT', 'Chabo') (148480, 58)\n",
      "(28, 3200, 58)\n"
     ]
    }
   ],
   "source": [
    "regions = ['V4', 'IT']\n",
    "subject_names = ['Tito', 'Chabo']\n",
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "\n",
    "# Get a matrix of responses for each trial\n",
    "data_majajhong = {}\n",
    "for region in regions:\n",
    "    for subject in subject_names:\n",
    "\n",
    "        df, _ = data_utils.get_brainscore(region, subject_name=subject, avg_trials=False)\n",
    "        print((region, subject), df.shape)\n",
    "\n",
    "        data_majajhong[(region, subject)] = []\n",
    "        for rep_idx, rep_df in df.groupby('repetition'):\n",
    "            if rep_df.shape[0] in [3200, 135]:\n",
    "                data_majajhong[(region, subject)].append(rep_df.values)\n",
    "\n",
    "        data_majajhong[(region, subject)] = np.array(data_majajhong[(region, subject)])\n",
    "        print(data_majajhong[(region, subject)].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "83cb29fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "V4 Tito (10, 10, 4, 2, 500) (28, 3200, 18)\n",
      "V4 Chabo (10, 10, 4, 2, 500) (28, 3200, 70)\n",
      "IT Tito (10, 10, 4, 2, 500) (28, 3200, 110)\n",
      "IT Chabo (10, 10, 4, 2, 500) (28, 3200, 58)\n"
     ]
    }
   ],
   "source": [
    "regions = ['V4', 'IT']\n",
    "subject_names = ['Tito', 'Chabo']\n",
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "\n",
    "P_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "Q_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "numit = 500\n",
    "\n",
    "filename = f'exp_task_dims_majajhong_P_Q_sweep_numit_{numit}_numpy.npz'\n",
    "filename = os.path.join(\"./data\", filename)\n",
    "\n",
    "if os.path.exists(filename):\n",
    "    data = np.load(filename, allow_pickle=True)\n",
    "    P_sample_ratios = data['P_sample_ratios']\n",
    "    Q_sample_ratios = data['Q_sample_ratios']\n",
    "    dims_majajhong = data['dims'].tolist()\n",
    "    phi_shapes = data['phi_shapes'].tolist()\n",
    "else:\n",
    "    dims_majajhong = {}\n",
    "    phi_shapes = {}\n",
    "    for region in regions:\n",
    "        for subject in subject_names:\n",
    "\n",
    "            Phi = data_majajhong[(region, subject)].astype(np.float64)\n",
    "\n",
    "            dims = []\n",
    "            for P_ratio in P_sample_ratios:\n",
    "                for Q_ratio in Q_sample_ratios:\n",
    "                    print(f\"{region:10} {subject:10} {P_ratio:8.2f} {Q_ratio:8.2f}\", end='\\r', flush=True)\n",
    "                    dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=False))\n",
    "            dims = np.array(dims).reshape(len(P_sample_ratios), len(Q_sample_ratios), len(estimators), 2, numit)\n",
    "\n",
    "            print(region, subject, dims.shape, Phi.shape)\n",
    "            dims_majajhong[(region, subject)] = dims\n",
    "            phi_shapes[(region, subject)] = Phi.shape\n",
    "\n",
    "    np.savez(filename, P_sample_ratios=P_sample_ratios, Q_sample_ratios=Q_sample_ratios, dims=dims_majajhong, phi_shapes=phi_shapes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd91c127",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_majajhong[(region, subject)][-1, :].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(Q_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('Q sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_majajhong[(region, subject)][:, -1].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(P_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('P sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f1b492c",
   "metadata": {},
   "source": [
    "## Brainscore - FreemanZiemba\n",
    "\n",
    "- Compute dimensionality for each region with all estimators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d5fd4b3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/home/cchun/miniforge3/envs/brainscore/lib/python3.11/site-packages/brainscore_core/metrics/__init__.py:16: FutureWarning: xarray subclass Score should explicitly define __slots__\n",
      "  class Score(DataAssembly):\n",
      "brainscore-storage/brainio-brainscore/assy_movshon_FreemanZiemba2013_public.nc: 100%|██████████| 1.33G/1.33G [01:09<00:00, 19.2MB/s]\n",
      "brainscore-storage/brainio-brainscore/stimulus_FreemanZiemba2013_aperture-public.csv: 100%|██████████| 27.9k/27.9k [00:00<00:00, 139kB/s]\n",
      "brainscore-storage/brainio-brainscore/stimulus_FreemanZiemba2013_aperture-public.zip: 100%|██████████| 5.31M/5.31M [00:00<00:00, 7.13MB/s]\n",
      "convert image degrees: 100%|██████████| 135/135 [00:03<00:00, 36.67it/s]\n",
      "/mnt/home/cchun/miniforge3/envs/brainscore/lib/python3.11/site-packages/brainscore_vision/benchmark_helpers/screen.py:72: UserWarning: Pandas doesn't allow columns to be created via a new attribute name - see https://pandas.pydata.org/pandas-docs/stable/indexing.html#attribute-access\n",
      "  converted_stimuli.original_paths = copy.deepcopy(stimulus_set.stimulus_paths)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "V1 (2700, 102)\n",
      "(20, 135, 102)\n",
      "V2 (2700, 103)\n",
      "(20, 135, 103)\n"
     ]
    }
   ],
   "source": [
    "regions = ['V1', 'V2']\n",
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "\n",
    "# Get a matrix of responses for each trial\n",
    "data_freemanziemba = {region: [] for region in regions}\n",
    "for region in regions:\n",
    "\n",
    "    df, _ = data_utils.get_brainscore(region, avg_trials=False)\n",
    "    print(region, df.shape)\n",
    "\n",
    "    for rep_idx, rep_df in df.groupby('repetition'):\n",
    "        if rep_df.shape[0] in [3200, 135]:\n",
    "            data_freemanziemba[region].append(rep_df.values)\n",
    "\n",
    "    data_freemanziemba[region] = np.array(data_freemanziemba[region])\n",
    "    print(data_freemanziemba[region].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48e195e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "19f3650c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(20, 135, 102)\n",
      "V1             0.40     0.20\r"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[4]\u001b[39m\u001b[32m, line 25\u001b[39m\n\u001b[32m     23\u001b[39m     \u001b[38;5;28;01mfor\u001b[39;00m Q_ratio \u001b[38;5;129;01min\u001b[39;00m Q_sample_ratios:\n\u001b[32m     24\u001b[39m         \u001b[38;5;28mprint\u001b[39m(\u001b[33mf\u001b[39m\u001b[33m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mregion\u001b[38;5;132;01m:\u001b[39;00m\u001b[33m10\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mP_ratio\u001b[38;5;132;01m:\u001b[39;00m\u001b[33m8.2f\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mQ_ratio\u001b[38;5;132;01m:\u001b[39;00m\u001b[33m8.2f\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m\"\u001b[39m, end=\u001b[33m'\u001b[39m\u001b[38;5;130;01m\\r\u001b[39;00m\u001b[33m'\u001b[39m, flush=\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[32m---> \u001b[39m\u001b[32m25\u001b[39m         dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=\u001b[38;5;28;01mFalse\u001b[39;00m))\n\u001b[32m     26\u001b[39m dims = np.array(dims).reshape(\u001b[38;5;28mlen\u001b[39m(P_sample_ratios), \u001b[38;5;28mlen\u001b[39m(Q_sample_ratios), \u001b[38;5;28mlen\u001b[39m(estimators), \u001b[32m2\u001b[39m, numit)\n\u001b[32m     28\u001b[39m \u001b[38;5;28mprint\u001b[39m(region, dims.shape, Phi.shape)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/projects/dim_paper/src/moment_utils.py:173\u001b[39m, in \u001b[36mget_dimensionality_avg\u001b[39m\u001b[34m(Phi, P_ratio, Q_ratio, numit, is_jax)\u001b[39m\n\u001b[32m    171\u001b[39m     Phi_a = Phi[idx_T[\u001b[32m0\u001b[39m]][idx_P, :][:, idx_Q]\n\u001b[32m    172\u001b[39m     Phi_b = Phi[idx_T[\u001b[32m1\u001b[39m]][idx_P, :][:, idx_Q]\n\u001b[32m--> \u001b[39m\u001b[32m173\u001b[39m     results = [get_dimensionality(Phi_a, Phi_b, P, Q)]\n\u001b[32m    175\u001b[39m     Ms.append(results)\n\u001b[32m    176\u001b[39m Ms = np.moveaxis(Ms, \u001b[32m0\u001b[39m, -\u001b[32m1\u001b[39m)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/projects/dim_paper/src/moment_utils.py:124\u001b[39m, in \u001b[36mget_dimensionality\u001b[39m\u001b[34m(A, B, P, Q)\u001b[39m\n\u001b[32m    121\u001b[39m \u001b[38;5;28;01massert\u001b[39;00m A.shape == (P, Q), \u001b[33mf\u001b[39m\u001b[33m\"\u001b[39m\u001b[33mA.shape != (P, Q), \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mA.shape\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m != (\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mP\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m, \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mQ\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m)\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m    123\u001b[39m returns = estimate_dimensionality(A, B)\n\u001b[32m--> \u001b[39m\u001b[32m124\u001b[39m returns = np.array(returns)\n\u001b[32m    126\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m returns\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/miniforge3/envs/brainscore/lib/python3.11/site-packages/jax/_src/array.py:442\u001b[39m, in \u001b[36mArrayImpl.__array__\u001b[39m\u001b[34m(self, dtype, context, copy)\u001b[39m\n\u001b[32m    439\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34m__array__\u001b[39m(\u001b[38;5;28mself\u001b[39m, dtype=\u001b[38;5;28;01mNone\u001b[39;00m, context=\u001b[38;5;28;01mNone\u001b[39;00m, copy=\u001b[38;5;28;01mNone\u001b[39;00m):\n\u001b[32m    440\u001b[39m   \u001b[38;5;66;03m# copy argument is supported by np.asarray starting in numpy 2.0\u001b[39;00m\n\u001b[32m    441\u001b[39m   kwds = {} \u001b[38;5;28;01mif\u001b[39;00m copy \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;28;01melse\u001b[39;00m {\u001b[33m'\u001b[39m\u001b[33mcopy\u001b[39m\u001b[33m'\u001b[39m: copy}\n\u001b[32m--> \u001b[39m\u001b[32m442\u001b[39m   \u001b[38;5;28;01mreturn\u001b[39;00m np.asarray(\u001b[38;5;28mself\u001b[39m._value, dtype=dtype, **kwds)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/miniforge3/envs/brainscore/lib/python3.11/site-packages/jax/_src/profiler.py:334\u001b[39m, in \u001b[36mannotate_function.<locals>.wrapper\u001b[39m\u001b[34m(*args, **kwargs)\u001b[39m\n\u001b[32m    331\u001b[39m \u001b[38;5;129m@wraps\u001b[39m(func)\n\u001b[32m    332\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mwrapper\u001b[39m(*args, **kwargs):\n\u001b[32m    333\u001b[39m   \u001b[38;5;28;01mwith\u001b[39;00m TraceAnnotation(name, **decorator_kwargs):\n\u001b[32m--> \u001b[39m\u001b[32m334\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m func(*args, **kwargs)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/miniforge3/envs/brainscore/lib/python3.11/site-packages/jax/_src/array.py:641\u001b[39m, in \u001b[36mArrayImpl._value\u001b[39m\u001b[34m(self)\u001b[39m\n\u001b[32m    639\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m._npy_value \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[32m    640\u001b[39m   \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m.is_fully_replicated:\n\u001b[32m--> \u001b[39m\u001b[32m641\u001b[39m     npy_value, did_copy = \u001b[38;5;28mself\u001b[39m._single_device_array_to_np_array_did_copy()\n\u001b[32m    642\u001b[39m     npy_value.flags.writeable = \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[32m    643\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m did_copy:\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    }
   ],
   "source": [
    "P_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "Q_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "numit = 1000\n",
    "\n",
    "filename = f'exp_task_dims_freemanziemba_P_Q_sweep_numit_{numit}_numpy.npz'\n",
    "filename = os.path.join(\"./data\", filename)\n",
    "\n",
    "if os.path.exists(filename):\n",
    "    data = np.load(filename, allow_pickle=True)\n",
    "    P_sample_ratios = data['P_sample_ratios']\n",
    "    Q_sample_ratios = data['Q_sample_ratios']\n",
    "    dims_freemanziemba = data['dims'].tolist()\n",
    "    phi_shapes = data['phi_shapes'].tolist()\n",
    "else:\n",
    "    dims_freemanziemba = {}\n",
    "    phi_shapes = {}\n",
    "    for region in regions:\n",
    "\n",
    "        Phi = data_freemanziemba[region].astype(np.float64)\n",
    "        print(Phi.shape)\n",
    "        dims = []\n",
    "        for P_ratio in P_sample_ratios:\n",
    "            for Q_ratio in Q_sample_ratios:\n",
    "                print(f\"{region:10} {P_ratio:8.2f} {Q_ratio:8.2f}\", end='\\r', flush=True)\n",
    "                dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=False))\n",
    "        dims = np.array(dims).reshape(len(P_sample_ratios), len(Q_sample_ratios), len(estimators), 2, numit)\n",
    "\n",
    "        print(region, dims.shape, Phi.shape)\n",
    "        dims_freemanziemba[region] = dims\n",
    "        phi_shapes[region] = Phi.shape\n",
    "\n",
    "    np.savez(filename, P_sample_ratios=P_sample_ratios, Q_sample_ratios=Q_sample_ratios, dims=dims_freemanziemba, phi_shapes=phi_shapes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da3edf92",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "\n",
    "        dims = dims_freemanziemba[region][-1, :].mean(-1)\n",
    "        dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "        axs[k].plot(Q_sample_ratios, dims, label=f\"{region}\")\n",
    "\n",
    "    axs[k].set_xlabel('Q sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "\n",
    "        dims = dims_freemanziemba[region][:, -1].mean(-1)\n",
    "        dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "        axs[k].plot(P_sample_ratios, dims, label=f\"{region}\")\n",
    "\n",
    "    axs[k].set_xlabel('P sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "272a2531",
   "metadata": {},
   "source": [
    "## TVSD\n",
    "\n",
    "- Compute dimensionality for each region with all estimators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7476e07d",
   "metadata": {},
   "outputs": [],
   "source": [
    "regions = ['V1', 'V4', 'IT']\n",
    "subject_names = ['F', 'N']\n",
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "\n",
    "monkey_name = 'F'\n",
    "region = 'IT'\n",
    "\n",
    "df, df_img = data_utils.get_tvsd(DATASET_ROOT, monkey_name, region, get_stimuli=True)\n",
    "print(df.shape, df_img.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "710b5721",
   "metadata": {},
   "outputs": [],
   "source": [
    "P_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "Q_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "numit = 250\n",
    "\n",
    "filename = f'exp_task_dims_tvsd_P_Q_sweep_numit_{numit}_numpy.npz'\n",
    "filename = os.path.join(\"./data\", filename)\n",
    "\n",
    "if os.path.exists(filename):\n",
    "    data = np.load(filename, allow_pickle=True)\n",
    "    P_sample_ratios = data['P_sample_ratios']\n",
    "    Q_sample_ratios = data['Q_sample_ratios']\n",
    "    dims_tvsd = data['dims'].tolist()\n",
    "    phi_shapes = data['phi_shapes'].tolist()\n",
    "else:\n",
    "    dims_tvsd = {}\n",
    "    phi_shapes = {}\n",
    "    for region in regions:\n",
    "        for subject in subject_names:\n",
    "\n",
    "            df, df_img = data_utils.get_tvsd(DATASET_ROOT, subject, region, get_stimuli=False)\n",
    "            Phi = df.values.astype(np.float64)\n",
    "\n",
    "            dims = []\n",
    "            for P_ratio in P_sample_ratios:\n",
    "                for Q_ratio in Q_sample_ratios:\n",
    "                    print(f\"{region:10} {subject:10} {P_ratio:8.2f} {Q_ratio:8.2f}\", end='\\r', flush=True)\n",
    "                    dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=False))\n",
    "            dims = np.array(dims).reshape(len(P_sample_ratios), len(Q_sample_ratios), len(estimators), 2, numit)\n",
    "\n",
    "            print(region, subject, dims.shape, Phi.shape)\n",
    "            dims_tvsd[(region, subject)] = dims\n",
    "            phi_shapes[(region, subject)] = Phi.shape\n",
    "\n",
    "    np.savez(filename, P_sample_ratios=P_sample_ratios, Q_sample_ratios=Q_sample_ratios, dims=dims_tvsd, phi_shapes=phi_shapes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6a903f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_tvsd[(region, subject)][-1, :].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(Q_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('Q sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_tvsd[(region, subject)][:, -1].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(P_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('P sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cbfd313",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "355e1cd7",
   "metadata": {},
   "source": [
    "## THINGS fMRI\n",
    "\n",
    "- Compute dimensionality for each region with all estimators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "991c2c52",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_rois = ['V1', 'V2', 'V3',\n",
    "            'hV4', 'VO1', 'VO2', 'TO1',\n",
    "            'lFFA', 'rFFA',\n",
    "            'lPPA', 'rPPA',\n",
    "            'lEBA', 'rEBA',\n",
    "            'IT',  'glasser-FEF']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00dd467b",
   "metadata": {},
   "outputs": [],
   "source": [
    "regions = ['V1', 'V2', 'V3', 'hV4', 'VO1', 'glasser-FEF', 'IT']\n",
    "subject_names = ['01', '02', '03']\n",
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "\n",
    "subject_name = '01'\n",
    "roi = 'V1'\n",
    "\n",
    "df, df_img = data_utils.get_things(DATASET_ROOT, subject_name, roi, get_stimuli=False)\n",
    "print(df.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aff44ef4",
   "metadata": {},
   "outputs": [],
   "source": [
    "P_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "Q_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "numit = 50\n",
    "\n",
    "filename = f'exp_task_dims_thingsfmri_P_Q_sweep_numit_{numit}3.npz'\n",
    "filename = os.path.join(\"./data\", filename)\n",
    "\n",
    "if os.path.exists(filename):\n",
    "    data = np.load(filename, allow_pickle=True)\n",
    "    P_sample_ratios = data['P_sample_ratios']\n",
    "    Q_sample_ratios = data['Q_sample_ratios']\n",
    "    dims_thingsfmri = data['dims'].tolist()\n",
    "    phi_shapes = data['phi_shapes'].tolist()\n",
    "else:\n",
    "    dims_thingsfmri = {}\n",
    "    phi_shapes = {}\n",
    "    for region in regions:\n",
    "        for subject in subject_names:\n",
    "\n",
    "            df, df_img = data_utils.get_things(DATASET_ROOT, subject, region, get_stimuli=False)\n",
    "            Phi = df.values.astype(np.float64)\n",
    "\n",
    "            dims = []\n",
    "            for P_ratio in P_sample_ratios:\n",
    "                for Q_ratio in Q_sample_ratios:\n",
    "                    print(f\"{region:10} {subject:10} {P_ratio:8.2f} {Q_ratio:8.2f}\", end='\\r', flush=True)\n",
    "                    dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=False))\n",
    "            dims = np.array(dims).reshape(len(P_sample_ratios), len(Q_sample_ratios), len(estimators), 2, numit)\n",
    "\n",
    "            print(region, subject, dims.shape, Phi.shape)\n",
    "            dims_thingsfmri[(region, subject)] = dims\n",
    "            phi_shapes[(region, subject)] = Phi.shape\n",
    "\n",
    "        np.savez(filename, P_sample_ratios=P_sample_ratios, Q_sample_ratios=Q_sample_ratios, dims=dims_thingsfmri, phi_shapes=phi_shapes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7736286a",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_thingsfmri[(region, subject)][-1, :].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(Q_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('Q sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        for j, subject in enumerate(subject_names):\n",
    "\n",
    "            dims = dims_thingsfmri[(region, subject)][:, -1].mean(-1)\n",
    "            dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "\n",
    "            axs[k].plot(P_sample_ratios, dims, label=f\"{region} {subject}\")\n",
    "\n",
    "    axs[k].set_xlabel('P sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25067994",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "1dd5ce4d",
   "metadata": {},
   "source": [
    "# Stringer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "60837fdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing data...\n",
      "Images shape:  torch.Size([5600, 1, 68, 90]) (5600,)\n",
      "(2, 2800, 9040)\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></th>\n",
       "      <th>class</th>\n",
       "      <th>Neuron_0</th>\n",
       "      <th>Neuron_1</th>\n",
       "      <th>Neuron_2</th>\n",
       "      <th>Neuron_3</th>\n",
       "      <th>Neuron_4</th>\n",
       "      <th>Neuron_5</th>\n",
       "      <th>Neuron_6</th>\n",
       "      <th>Neuron_7</th>\n",
       "      <th>Neuron_8</th>\n",
       "      <th>...</th>\n",
       "      <th>Neuron_9029</th>\n",
       "      <th>Neuron_9030</th>\n",
       "      <th>Neuron_9031</th>\n",
       "      <th>Neuron_9032</th>\n",
       "      <th>Neuron_9033</th>\n",
       "      <th>Neuron_9034</th>\n",
       "      <th>Neuron_9035</th>\n",
       "      <th>Neuron_9036</th>\n",
       "      <th>Neuron_9037</th>\n",
       "      <th>Neuron_9038</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>class_name</th>\n",
       "      <th>istim</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",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">birds</th>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>4.473313</td>\n",
       "      <td>-3.058414</td>\n",
       "      <td>72.024742</td>\n",
       "      <td>-0.830405</td>\n",
       "      <td>44.707890</td>\n",
       "      <td>-1.117409</td>\n",
       "      <td>-1.048477</td>\n",
       "      <td>2.722799</td>\n",
       "      <td>-1.991595</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.452953</td>\n",
       "      <td>-0.696070</td>\n",
       "      <td>0.891554</td>\n",
       "      <td>8.091687</td>\n",
       "      <td>-1.527367</td>\n",
       "      <td>0.242964</td>\n",
       "      <td>-0.876710</td>\n",
       "      <td>-1.288454</td>\n",
       "      <td>-1.099203</td>\n",
       "      <td>-2.061875</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>-0.276598</td>\n",
       "      <td>-0.215595</td>\n",
       "      <td>2.960756</td>\n",
       "      <td>0.226218</td>\n",
       "      <td>-0.256640</td>\n",
       "      <td>-0.569137</td>\n",
       "      <td>-1.404725</td>\n",
       "      <td>-6.804087</td>\n",
       "      <td>-0.340757</td>\n",
       "      <td>...</td>\n",
       "      <td>0.692665</td>\n",
       "      <td>0.563431</td>\n",
       "      <td>0.824883</td>\n",
       "      <td>-1.051004</td>\n",
       "      <td>-1.039018</td>\n",
       "      <td>-0.951922</td>\n",
       "      <td>-0.558642</td>\n",
       "      <td>-0.129140</td>\n",
       "      <td>-0.597678</td>\n",
       "      <td>-0.162253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>-0.098581</td>\n",
       "      <td>-0.103600</td>\n",
       "      <td>0.673397</td>\n",
       "      <td>-0.315297</td>\n",
       "      <td>-0.505239</td>\n",
       "      <td>0.607203</td>\n",
       "      <td>-0.792163</td>\n",
       "      <td>-6.004974</td>\n",
       "      <td>-0.697170</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.718969</td>\n",
       "      <td>-0.301823</td>\n",
       "      <td>-0.131305</td>\n",
       "      <td>-1.754750</td>\n",
       "      <td>-0.841046</td>\n",
       "      <td>-0.287741</td>\n",
       "      <td>0.950040</td>\n",
       "      <td>4.809392</td>\n",
       "      <td>0.315243</td>\n",
       "      <td>-0.163709</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>-0.538623</td>\n",
       "      <td>-0.114522</td>\n",
       "      <td>-1.460214</td>\n",
       "      <td>-0.096393</td>\n",
       "      <td>-0.220895</td>\n",
       "      <td>-1.052131</td>\n",
       "      <td>-0.729469</td>\n",
       "      <td>-6.173316</td>\n",
       "      <td>-0.394232</td>\n",
       "      <td>...</td>\n",
       "      <td>0.026364</td>\n",
       "      <td>0.408272</td>\n",
       "      <td>0.198617</td>\n",
       "      <td>-1.531281</td>\n",
       "      <td>0.104333</td>\n",
       "      <td>-1.163556</td>\n",
       "      <td>-0.528647</td>\n",
       "      <td>-0.140481</td>\n",
       "      <td>-0.338863</td>\n",
       "      <td>-0.182495</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>-3.543672</td>\n",
       "      <td>-0.979925</td>\n",
       "      <td>-3.640491</td>\n",
       "      <td>0.294014</td>\n",
       "      <td>-0.577987</td>\n",
       "      <td>-0.995598</td>\n",
       "      <td>1.066492</td>\n",
       "      <td>39.271297</td>\n",
       "      <td>5.929708</td>\n",
       "      <td>...</td>\n",
       "      <td>0.262410</td>\n",
       "      <td>3.894692</td>\n",
       "      <td>-1.689966</td>\n",
       "      <td>0.762375</td>\n",
       "      <td>-2.322163</td>\n",
       "      <td>2.045996</td>\n",
       "      <td>-0.221801</td>\n",
       "      <td>1.310931</td>\n",
       "      <td>-0.088829</td>\n",
       "      <td>-4.951119</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 9040 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                  class  Neuron_0  Neuron_1   Neuron_2  Neuron_3   Neuron_4  \\\n",
       "class_name istim                                                              \n",
       "birds      0          1  4.473313 -3.058414  72.024742 -0.830405  44.707890   \n",
       "           0          1 -0.276598 -0.215595   2.960756  0.226218  -0.256640   \n",
       "           1          1 -0.098581 -0.103600   0.673397 -0.315297  -0.505239   \n",
       "           1          1 -0.538623 -0.114522  -1.460214 -0.096393  -0.220895   \n",
       "           2          1 -3.543672 -0.979925  -3.640491  0.294014  -0.577987   \n",
       "\n",
       "                  Neuron_5  Neuron_6   Neuron_7  Neuron_8  ...  Neuron_9029  \\\n",
       "class_name istim                                           ...                \n",
       "birds      0     -1.117409 -1.048477   2.722799 -1.991595  ...    -0.452953   \n",
       "           0     -0.569137 -1.404725  -6.804087 -0.340757  ...     0.692665   \n",
       "           1      0.607203 -0.792163  -6.004974 -0.697170  ...    -0.718969   \n",
       "           1     -1.052131 -0.729469  -6.173316 -0.394232  ...     0.026364   \n",
       "           2     -0.995598  1.066492  39.271297  5.929708  ...     0.262410   \n",
       "\n",
       "                  Neuron_9030  Neuron_9031  Neuron_9032  Neuron_9033  \\\n",
       "class_name istim                                                       \n",
       "birds      0        -0.696070     0.891554     8.091687    -1.527367   \n",
       "           0         0.563431     0.824883    -1.051004    -1.039018   \n",
       "           1        -0.301823    -0.131305    -1.754750    -0.841046   \n",
       "           1         0.408272     0.198617    -1.531281     0.104333   \n",
       "           2         3.894692    -1.689966     0.762375    -2.322163   \n",
       "\n",
       "                  Neuron_9034  Neuron_9035  Neuron_9036  Neuron_9037  \\\n",
       "class_name istim                                                       \n",
       "birds      0         0.242964    -0.876710    -1.288454    -1.099203   \n",
       "           0        -0.951922    -0.558642    -0.129140    -0.597678   \n",
       "           1        -0.287741     0.950040     4.809392     0.315243   \n",
       "           1        -1.163556    -0.528647    -0.140481    -0.338863   \n",
       "           2         2.045996    -0.221801     1.310931    -0.088829   \n",
       "\n",
       "                  Neuron_9038  \n",
       "class_name istim               \n",
       "birds      0        -2.061875  \n",
       "           0        -0.162253  \n",
       "           1        -0.163709  \n",
       "           1        -0.182495  \n",
       "           2        -4.951119  \n",
       "\n",
       "[5 rows x 9040 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df, df_img = data_utils.get_stringer(DATASET_ROOT, avg_trials=False)\n",
    "\n",
    "data_stringer = []\n",
    "for rep_idx, rep_df in df.groupby('istim'):\n",
    "    data_stringer.append(rep_df.values)\n",
    "data_stringer = np.array(data_stringer).swapaxes(0, 1)\n",
    "print(data_stringer.shape)\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5399566e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "V1 (10, 10, 4, 2, 200) (2, 2800, 9040)\n"
     ]
    }
   ],
   "source": [
    "estimators = ['naive', 'row_exp', 'col_exp', 'double_exp']\n",
    "regions = ['V1']\n",
    "\n",
    "P_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "Q_sample_ratios = np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "numit = 200\n",
    "\n",
    "filename = f'exp_task_dims_stringer_P_Q_sweep_numit_{numit}_numpy3.npz'\n",
    "filename = os.path.join(\"./data\", filename)\n",
    "\n",
    "if os.path.exists(filename):\n",
    "    data = np.load(filename, allow_pickle=True)\n",
    "    P_sample_ratios = data['P_sample_ratios']\n",
    "    Q_sample_ratios = data['Q_sample_ratios']\n",
    "    dims_stringer = data['dims'].tolist()\n",
    "    phi_shapes = data['phi_shapes'].tolist()\n",
    "else:\n",
    "    dims_stringer = {}\n",
    "    phi_shapes = {}\n",
    "    for region in regions:\n",
    "\n",
    "        Phi = data_stringer.astype(np.float64)\n",
    "\n",
    "        dims = []\n",
    "        for P_ratio in P_sample_ratios:\n",
    "            for Q_ratio in Q_sample_ratios:\n",
    "                print(f\"{region:10} {P_ratio:8.2f} {Q_ratio:8.2f}\", end='\\r', flush=True)\n",
    "                dims.append(get_dimensionality_avg(Phi, P_ratio, Q_ratio, numit, is_jax=True))\n",
    "        dims = np.array(dims).reshape(len(P_sample_ratios), len(Q_sample_ratios), len(estimators), 2, numit)\n",
    "\n",
    "        print(region, dims.shape, Phi.shape)\n",
    "        dims_stringer[region] = dims\n",
    "        phi_shapes[region] = Phi.shape\n",
    "\n",
    "    np.savez(filename, P_sample_ratios=P_sample_ratios, Q_sample_ratios=Q_sample_ratios, dims=dims_stringer, phi_shapes=phi_shapes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c4d67ca5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_4045129/1358590934.py:13: UserWarning: No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n",
      "  plt.legend()\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/QAAAE6CAYAAAC4WBmPAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAYkZJREFUeJzt3XlcVPX+x/HXsIMC7iyKiPteioVLpS1qaqZZWZmaZv302k3NyvJ6S2yR8pZ5W7Rr1zRTS0vtWplKi5aZuZtbaklCBiKKgIIsM+f3x8joCCiMwMDwfj4e82Dme77nnM9h+Fifc77ne0yGYRiIiIiIiIiISKXi5uwARERERERERKTkVNCLiIiIiIiIVEIq6EVEREREREQqIRX0IiIiIiIiIpWQCnoRERERERGRSkgFvYiIiIiIiEglpIJeREREREREpBJSQS8iIiIiIiJSCamgFxEREREREamEVNC7qOjoaEwmU5ltf8GCBZhMJrZt23bFviNGjKBRo0ZlFouIiIiIiEhVpIJeREREREREpBJSQS8iIiIiIiJSCamgdwFffvkl1157Ld7e3kRERPDaa68V6HPu3DkmT55MREQEXl5e1K9fn8cee4zTp0/b9TOZTERHRxdYv1GjRowYMaJAe2pqKiNHjqRWrVpUq1aN/v37c+TIkSvGbBgGs2fP5tprr8XX15eaNWtyzz33FGvdSyUlJTF69GgaNGiAl5cXERERTJs2jby8PNu++vbtS+3atYmPj7etl5mZSZs2bWjVqhVnz54FLtyqsHPnTgYNGkRAQACBgYEMHTqUEydOlDg2ERERERGRsqKCvpL75ptvGDBgAP7+/nz88cf861//YtmyZcyfP9/WxzAMBg4cyGuvvcawYcP48ssvmThxIh988AG33HIL2dnZDu9/1KhRuLm5sWTJEmbNmsWWLVvo0aNHgRMFlxo9ejQTJkzgtttu47PPPmP27Nns27ePrl27cvz48WLvPykpieuvv561a9fy/PPP89VXXzFq1ChiYmJ49NFHAetJig8//BA/Pz8GDx5Mbm4uAGPHjiUuLo5ly5ZRrVo1u+3eddddNG3alE8//ZTo6Gg+++wzevfubVtXRERERETE6Qyp1KKioozQ0FAjKyvL1paenm7UqlXLyP9616xZYwDGjBkz7NZdunSpARhz5861tQHG1KlTC+wnPDzceOihh2yf58+fbwDGXXfdZdfvxx9/NADjpZdesrU99NBDRnh4uO3zTz/9ZADG66+/brduQkKC4evra0yaNKnYxz969GijevXqxtGjR+3aX3vtNQMw9u3bZ2vbuHGj4eHhYUyYMMF4//33DcD473//a7fe1KlTDcB44okn7NoXL15sAMaiRYuKHZuIiIiIiEhZ0hX6Suzs2bNs3bqVQYMG4ePjY2v39/enf//+ts/ffvstQIEh8/feey/VqlXjm2++cTiGBx980O5z165dCQ8P57vvvitynS+++AKTycTQoUPJy8uzvYKDg7nmmmtYv359sff/xRdfcPPNNxMaGmq3rT59+gCwYcMGW99u3brx8ssvM2vWLP72t78xdOhQRo0aVazjGjx4MB4eHpc9LhERERERkfLk4ewAxHGpqalYLBaCg4MLLLu47eTJk3h4eFC3bl27PiaTieDgYE6ePOlwDEXt+3LbPH78OIZhEBQUVOjyxo0bF3v/x48f5/PPP8fT07PQ5SkpKXafH3zwQZ577jmys7N5+umni9zupcfl4eFB7dq1r+p3JSIiIiIiUppU0FdiNWvWxGQykZSUVGDZxW21a9cmLy+PEydO2BX1hmGQlJTEddddZ2vz9vYu9J76ogrZovbdtGnTIuOuU6cOJpOJH374AW9v7wLLC2u73Lbat2/Pyy+/XOjy0NBQ23uz2cyDDz5IzZo18fb2ZtSoUfz44494eXkVegz169e3fc7Ly+PkyZPUrl272LGJiIiIiIiUJQ25r8SqVavG9ddfz4oVKzh37pytPSMjg88//9z2+dZbbwVg0aJFdusvX76cs2fP2paDdTb7X375xa7ft99+y5kzZwqNYfHixXafN23axNGjR+nRo0eRcd9xxx0YhsGxY8fo1KlTgVe7du0uf+CXbGvv3r00adKk0G1dXNBPnTqVH374gcWLF7N06VJ2795d5FX6S49r2bJl5OXlXfa4REREREREypOu0FdyL774Irfffjs9e/bkySefxGw28+qrr1KtWjVOnToFQM+ePenduzfPPPMM6enpdOvWjV9++YWpU6fSoUMHhg0bZtvesGHDeO6553j++efp3r07+/fv5+233yYwMLDQ/W/bto1HHnmEe++9l4SEBKZMmUL9+vUZO3ZskTF369aN//u//2PkyJFs27aNm266iWrVqpGYmMjGjRtp164df/vb34p1/C+88AKxsbF07dqVcePG0aJFC86dO8cff/zB6tWreffdd2nQoAGxsbHExMTw3HPP2U5gxMTE8NRTT9GjRw/uuusuu+2uWLECDw8Pevbsyb59+3juuee45pprGDx4cLHiEhERERERKXNOnpRPSsGqVauM9u3bG15eXkbDhg2NV155xTZbe76srCzjmWeeMcLDww1PT08jJCTE+Nvf/makpqbabSs7O9uYNGmSERYWZvj6+hrdu3c3du3aVeQs9+vWrTOGDRtm1KhRw/D19TX69u1rHD582G6bl85yn+/99983oqKijGrVqhm+vr5GkyZNjOHDhxvbtm0r0fGfOHHCGDdunBEREWF4enoatWrVMiIjI40pU6YYZ86cMf766y+jXr16xi233GKYzWbbehaLxejfv79Ro0YNIy4uzjCMC7Pcb9++3ejfv79RvXp1w9/f33jggQeM48ePlyguERERERGRsmQyDMNw8jkFkQojOjqaadOmceLECerUqePscERERERERIqke+hFREREREREKiHdQy8VkmEYmM3my/Zxd3fHZDKVU0QiIiIiIiIVi4bcS4W0YMECRo4cedk+3333nWadFxERERGRKktD7qVC6t+/P1u3br3sKzIy0tlhVknff/89/fv3JzQ0FJPJxGeffXbFdTZs2EBkZCQ+Pj40btyYd999t+wDFZHLUi6LuAblskjVpiH3UiHVrl2b2rVrOzsMKcTZs2e55pprGDlyJHffffcV+8fFxdG3b18effRRFi1axI8//sjYsWOpW7dusdYXkbKhXBZxDcplkapNQ+5FxGEmk4mVK1cycODAIvs888wzrFq1igMHDtjaxowZw+7du/npp5/KIUoRuRLlsohrUC6LVD0uf4XeYrHw119/4e/vrwnURIpgGAYZGRmEhobi5la6d+L89NNP9OrVy66td+/ezJs3j9zcXDw9PQtdLzs7m+zsbNtni8XCqVOnqF27tnJZpAgVLZeVxyIlV5Z5DMplkfJS1rmcz+UL+r/++ouwsDBnhyFSKSQkJNCgQYNS3WZSUhJBQUF2bUFBQeTl5ZGSkkJISEih68XExDBt2rRSjUWkqqgouaw8FnFcWeQxKJdFyltZ5XI+ly/o/f39AesvMiAgwMnRiFRM6enphIWF2fKltF169j7/Tp/LndWfPHkyEydO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tm1bPvjgAzIzM1myZIkTIxYRERERERFxPqcX9I899hj9+vXjtttus2uPi4sjKSmJXr162dq8vb3p3r07mzZtKnJ72dnZpKen271EREREREREXI1Tp3T/+OOP2bFjB1u3bi2wLCnJOlFdUFCQXXtQUBBHjx4tcpsxMTFMmzatdAMVERERERERqWCcdoU+ISGB8ePHs2jRInx8fIrsd+l97YZhXPZe98mTJ5OWlmZ7JSQklFrMIiIiIiIiIhWF0wr67du3k5ycTGRkJB4eHnh4eLBhwwbefPNNPDw8bFfm86/U50tOTi5w1f5i3t7eBAQE2L1EpPTNnj2biIgIfHx8iIyM5Icffrhs/w0bNhAZGYmPjw+NGzfm3XffLadIRaQoymMR16BcFqm6nFbQ33rrrezZs4ddu3bZXp06deLBBx9k165dNG7cmODgYGJjY23r5OTksGHDBrp27eqssEUEWLp0KRMmTGDKlCns3LmTG2+8kT59+hAfH19o/7i4OPr27cuNN97Izp07+cc//sG4ceNYvnx5OUcuIvmUxyKuQbksUrWZDMMwnB1Evh49enDttdcya9YsAF599VViYmKYP38+zZo1Y/r06axfv56DBw/i7+9frG2mp6cTGBhIWlqartaLFKGkeRIVFUXHjh2ZM2eOra1Vq1YMHDiQmJiYAv2feeYZVq1axYEDB2xtY8aMYffu3fz0009lEqNIVVSSPFEei1RM+m+yiGsorzxx6qR4VzJp0iSysrIYO3YsqampREVFsW7dumIX82C95x7QbPcil5GfH8U5v5eTk8P27dt59tln7dp79epV5BMofvrpJ7snVgD07t2befPmkZubi6enZ4F1srOzyc7Otn1OS0uzi1VECipuLiuPRSou/TdZxDWUJJevRoUq6NevX2/32WQyER0dTXR0tMPbzMjIACAsLOwqIhOpGjIyMggMDLxsn5SUFMxmc6FPoLh0zot8SUlJhfbPy8sjJSWFkJCQAusU9cQK5bLIlZ08efKyuaw8Fqn4rpTHoFwWqQyKk8tXo0IV9GUhNDSUhIQE/P39Lzs7vrOkp6cTFhZGQkJCpR+ypGOpmIpzLIZhkJGRQWhoaLG3W9InUBTWv7D2fJMnT2bixIm2z6dPnyY8PJz4+Pgy/UexrFW1v63KwFWOA6xXzRo2bEitWrWK1V957DhX+btxleMA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Pnz99dccO3aMKVOmFLnu7t27ufnmm/H39ycgIIDIyEi2bdsGwMmTJ3nggQdo0KABfn5+tGvXjo8++shu/R49evD4448zYcIEatasSVBQEHPnzuXs2bOMHDkSf39/mjRpwldffWVbJ/8K+Jdffsk111yDj48PUVFR7Nmz57LH+fnnnxMZGYmPjw+NGzdm2rRp5OXlFdl/xIgRDBw4kJiYGEJDQ2nevDkAixYtolOnTvj7+xMcHMyQIUNITk4G4I8//uDmm28GoGbNmphMJkaMGGE71ouH3KempjJ8+HBq1qyJn58fffr04fDhw5c9BhERERERkbKkgr4SOXXqFGvXrmXs2LH4+vraLQsODubBBx9k6dKlGIZR6PoPPvggDRo0YOvWrWzfvp1nn30WT09PAM6dO0dkZCRffPEFe/fu5f/+7/8YNmwYP//8s902PvjgA+rUqcOWLVt4/PHH+dvf/sa9995L165d2bFjB71792bYsGFkZmbarff000/z2muvsXXrVurVq8edd95Jbm5uoXGuXbuWoUOHMm7cOPbv389//vMfFixYwMsvv3zZ388333zDgQMHiI2N5YsvvgCsV+pffPFFdu/ezWeffUZcXJytaA8LC2P58uUAHDx4kMTERP79738Xuu0RI0awbds2Vq1axU8//YRhGPTt27fIYxARERERESlzhlQamzdvNgBj5cqVhS6fOXOmARjHjx8vdLm/v7+xYMGCYu+vb9++xpNPPmn73L17d+OGG26wfc7LyzOqVatmDBs2zNaWmJhoAMZPP/1kGIZhfPfddwZgfPzxx7Y+J0+eNHx9fY2lS5cahmEY8+fPNwIDA23Lb7zxRmP69Ol2sXz44YdGSEhIkbE+9NBDRlBQkJGdnX3ZY9qyZYsBGBkZGXbxpaam2vXr3r27MX78eMMwDOPQoUMGYPz444+25SkpKYavr6+xbNmyy+5PRERERESkrHg48VyClDLj/JV5Ly+vQpdPnDiRRx55hA8//JDbbruNe++9lyZNmgBgNpt55ZVXWLp0KceOHSM7O5vs7GyqVatmt4327dvb3ru7u1O7dm3atWtnawsKCgKwDWvP16VLF9v7WrVq0aJFCw4cOFBonNu3b2fr1q12V+TNZjPnzp0jMzMTPz+/Qtdr165dgWPfuXMn0dHR7Nq1i1OnTmGxWACIj4+ndevWhW7nUgcOHMDDw4OoqChbW+3atS97DCIiIiIiImVNQ+4rkaZNm2Iymdi/f3+hy3/99Vfq1q1b5CPgoqOj2bdvH/369ePbb7+ldevWrFy5EoDXX3+dN954g0mTJvHtt9+ya9cuevfuXWByufwh+vlMJpNdm8lkArAVzpeT3/dSFouFadOmsWvXLttrz549HD58GB8fnyK3d+nJh7Nnz9KrVy+qV6/OokWL2Lp1q+14SzJpnlHELQyGYRR5DCIiIiIiImVNBX0lUrt2bXr27Mns2bPJysqyW5aUlMTixYtt94cXpXnz5jzxxBOsW7eOQYMGMX/+fAB++OEHBgwYwNChQ7nmmmto3LhxqU76tnnzZtv71NRUDh06RMuWLQvt27FjRw4ePEjTpk0LvNzciv8n++uvv5KSksIrr7zCjTfeSMuWLQuMHMi/om82m4vcTuvWrcnLy7ObT+DkyZMcOnSIVq1aFTseERERERGR0qSCvpJ5++23yc7Opnfv3nz//fckJCSwZs0aevbsSfPmzXn++ecLXS8rK4u///3vrF+/nqNHj/Ljjz+ydetWW0HatGlTYmNj2bRpEwcOHGD06NEkJSWVWtwvvPAC33zzDXv37mXEiBHUqVOHgQMHFtr3+eefZ+HChbYRBQcOHGDp0qX885//LNE+GzZsiJeXF2+99RZHjhxh1apVBZ4tHx4ejslk4osvvuDEiROcOXOmwHaaNWvGgAEDePTRR9m4cSO7d+9m6NCh1K9fnwEDBpQoJhERERERkdKigr6SadasGVu3bqVx48YMHjyY8PBw+vTpQ/Pmzfnxxx+pXr16oeu5u7tz8uRJhg8fTvPmzRk8eDB9+vRh2rRpADz33HN07NiR3r1706NHD4KDg4ssuB3xyiuvMH78eCIjI0lMTGTVqlVF3uvfu3dvvvjiC2JjY7nuuuvo3LkzM2fOJDw8vET7rFu3LgsWLOCTTz6hdevWvPLKK7z22mt2ferXr8+0adN49tlnCQoK4u9//3uh25o/fz6RkZHccccddOnSBcMwWL16dYFbEERERERERMqLySjqBmGpNKZOncrMmTNZt26d3eRzFcH69eu5+eabSU1NLfLefhERERERESk5zXLvAqZNm0ajRo34+eefiYqKKtF95iIiIiIiIlI5qaB3ESNHjnR2CCIiIiIiIlKONOReREREREREpBLS2GwRERERERGRSkgFvYiIiIiIiEglpIJeREREREREpBJSQS8iIiIiIiJSCamgFxEREREREamEVNCLiIiIiIiIVEIq6EVEREREREQqIRX0IiIiIiIiIpXQ/wOVEJKcmJ+qRQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_4045129/1358590934.py:29: UserWarning: No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n",
      "  plt.legend()\n"
     ]
    },
    {
     "data": {
      "image/png": "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zMyLvjaHRGEOM3NzSMyf6le4vbBdLn9SbMpKKDiLtEtksvxtcvNi7RKZDJDLS71rJBERERERUW3Hgh5A4pdfIufuXYjMrCcFepGfIjOzyke2JVZWMCt8WFs/eV70taVFfvFrLi/4WVBAmxc8N5drXpsV2/bU68LCWyqt0vMiIiIiIiKiqsGCHkD6wQhk37hRvs4yWUFxban1U2JlCTMr6yftVpbFi/OC5xKt19b5hToLayIiIiIiIqoAFvQAHMeNgzo9XVOESywLivOihXlh4W7ANQaJiIiIiIio6hWuZFXZPlWNBT0Ah6FDDB0CERERERERGZhcLgcAZGZmwtLSssy+mZmZWvsYAgt6IiIiIiIiIgBSqRQODg5ITEwEAFhZWRW7UbcQApmZmUhMTISDgwOkBrx8mgU9ERERERERUQFXV1cA0BT1pXFwcND0NRQW9EREREREREQFJBIJ3NzcUK9ePeSWstqZXC436Mh8IRb0RERERERERE+RSqU1omgvi5mhAyAiIiIiIiKiimNBT0RERERERGSEWNATERERERERGSEW9ERERERERERGiAU9ERERERERkRFiQU9ERERERERkhFjQExERERERERkhFvRERERERERERogFPREREREREZERMmhBn5aWhqCgIHh6esLS0hIBAQE4efKkZrsQAiEhIXB3d4elpSW6d++OS5cuGTBiIiIiIiIioprBoAX9xIkTER4ejh9//BEXLlxAYGAgevXqhbi4OADAF198gcWLF+O7777DyZMn4erqit69eyMtLc2QYRMREREREREZnMEK+qysLGzfvh1ffPEFunbtiqZNmyIkJAReXl5Yvnw5hBBYsmQJZs+ejaFDh6JNmzZYv349MjMzsWnTJkOFTURERERERFQjGKygz8vLg0qlgoWFhVa7paUljhw5gqioKCQkJCAwMFCzTaFQoFu3bjh27Fipx83OzoZSqdR6EBEREREREZkagxX0tra28Pf3x7///W/cu3cPKpUKP/30E/755x/Ex8cjISEBAODi4qK1n4uLi2ZbSUJDQ2Fvb695eHh4VOl5EBERERERERmCQa+h//HHHyGEQP369aFQKPDNN99gxIgRkEqlmj4SiURrHyFEsbaiZs2ahdTUVM0jNja2yuInIiIiIiIiMhSDFvRNmjRBREQE0tPTERsbixMnTiA3Nxde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YMAA2NrawtPTE+3bt9dsf/XVV7X6r169GvXq1cPly5e1riWfMWMG+vTpAwB4//338eabb2Lfvn3o3LkzAGDChAlYt26d1rHMzc2xZs0aWFlZwdvbGwsWLMCHH36If//731pfFgDArVu3sHnzZty9exfu7u6a99yzZw/Wrl2LhQsXlvo7GDFiBMaPH6/VNn/+fM1zLy8vHDt2DNu2bcOwYcNgY2MDS0tLZGdnlznFftmyZfDw8MB3330HiUSCli1b4t69e/joo48wd+7cYudARERERERUXViNGKnff/8dNjY2sLCwgL+/P7p27Ypvv/22xL69e/eGp6cnGjdujFGjRmHjxo3IzMzUbL916xZGjBiBxo0bw87ODl5eXgDyvwgoysfHR/PcxcUFANC2bVuttsTERK192rVrBysrK81rf39/pKenIzY2tlicZ86cgRACzZs3h42NjeYRERGhdQlASTp06FCsbcWKFejQoQPq1q0LGxsbrFq1qtg5PcuVK1fg7+8PiUSiaevcuTPS09Nx9+7dCh2LiIiIiIhInzhCb6R69OiB5cuXQy6Xw93dvcybwNna2uLMmTM4ePAgwsLCMHfuXISEhODkyZNwcHDAwIED4eHhgVWrVsHd3R1qtRpt2rQpdq170fcoLHCfblOr1eWKv2iBXEitVkMqleL06dOQSqVa22xsbMo8nrW1tdbrbdu2Yfr06fjyyy/h7+8PW1tb/Pe//8U///xTrvgKCSGKxSqEKPUciIiIiIiIqgsLeiNlbW2Npk2blru/TCZDr1690KtXL8ybNw8ODg7Yv38/unXrhitXruD7779Hly5dAABHjhzRW5znzp1DVlYWLC0tAQB///03bGxs0KBBg2J927dvD5VKhcTERE0sujp8+DACAgIwdepUTdvTo/zm5uZQqVRlHqd169bYvn27VmF/7Ngx2Nraon79+pWKkYiIiIiIqDI45b4W+P333/HNN9/g7NmziI6OxoYNG6BWq9GiRQvUqVMHTk5OWLlyJW7evIn9+/cjODhYb++dk5ODCRMm4PLly/jzzz8xb948vPvuuyVee968eXOMHDkSo0ePxo4dOxAVFYWTJ09i0aJF2L17d4Xet2nTpjh16hT27t2L69evY86cOTh58qRWn0aNGuH8+fO4du0akpKSSryp4NSpUxEbG4v33nsPV69exf/93/9h3rx5CA4O5vXzRERERERkUKxIagEHBwfs2LEDL730Elq1aoUVK1Zg8+bN8Pb2hpmZGbZs2YLTp0+jTZs2mD59Ov773//q7b179uyJZs2aoWvXrhg2bBgGDhxY5t3h165di9GjR+ODDz5AixYt8Morr+Cff/6Bh4dHhd53ypQpGDp0KIYPHw4/Pz8kJydrjdYDwKRJk9CiRQvNdfZHjx4tdpz69etj9+7dOHHiBNq1a4cpU6ZgwoQJ+PTTTysUDxERERERkb5JROEFwUR6NnbsWDx69Ai7du0ydChEREREREQmhyP0REREREREREaIBT0RERERERGREeKUeyIiIiIiIiIjxBF6IiIiIiIiIiPEgp6IiIiIiIjICLGgJyIiIiIiIjJCLOiJiIiIiIiIjBALeiIiIiIiIiIjxIKeiIiIiIiIyAixoCciIiIiIiIyQizoiYiIiIiIiIzQ/wPAhqTfdRhVNQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "\n",
    "        dims = dims_stringer[region][-1, :].mean(-1)\n",
    "        dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "        k=0\n",
    "        axs[k].plot(Q_sample_ratios, dims, label=f\"{region}\")\n",
    "    \n",
    "    axs[k].set_xlabel('Q sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, len(estimators), figsize=(12, 3))\n",
    "for k, estimator in enumerate(estimators):\n",
    "    for i, region in enumerate(regions):\n",
    "        dims = dims_stringer[region][:, -1].mean(-1)\n",
    "        \n",
    "        dims = dims[:, k, 0] / dims[:, k, 1]\n",
    "        k=0\n",
    "        axs[k].plot(P_sample_ratios, dims, label=f\"{region}\")\n",
    "\n",
    "    axs[k].set_xlabel('P sample ratio')\n",
    "    axs[k].set_ylabel('Dimensionality')\n",
    "    axs[k].set_title(estimator)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a379adc7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10, 10, 4, 2, 200)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.shape(dims_stringer[region])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a2b294c",
   "metadata": {},
   "outputs": [],
   "source": [
    "IT Chabo (10, 10, 4, 2, 500) (28, 3200, 58)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "brainscore",
   "language": "python",
   "name": "brainscore"
  },
  "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.11.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
