{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "ff62aa8d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import learn2learn as l2l\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import random\n",
    "import torch\n",
    "from torch import nn\n",
    "import pickle\n",
    "import cv2\n",
    "from xmeta.utils.sift import SiftFeature\n",
    "from importlib import reload \n",
    "from xmeta.utils.seed import set_seed\n",
    "from xmeta.utils.visualize import show_task, show_predictions\n",
    "from xmeta.utils.data import mask_image, mix_tasks, mask_image, mask_images, ImpureTasksets, get_tasksets\n",
    "from xmeta.maml.maml import xfast_adapt, explain_test_performance, explan_adaptation, setup_experiment\n",
    "from xmeta.utils.experiment import draw_hist, draw_df_row, plot_score_dist, aggregate_shuffle_scores\n",
    "import pickle\n",
    "from tqdm import tqdm\n",
    "import pandas as pd\n",
    "import dill\n",
    "import os\n",
    "import pandas as pd\n",
    "from torchsummary import summary\n",
    "\n",
    "seed = 42\n",
    "device = torch.device('cuda')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9302df51",
   "metadata": {},
   "source": [
    "# Experimental setup\n",
    "- MiniImagenet dataset \n",
    "- Trained with MAML(Model-Agnostic Meta-Learning): \n",
    " - 5-way 5-shot learning\n",
    " - meta batch size: 32 tasks\n",
    " - 20000 iterations of meta training step (20000 x 32 tasks, 20000 x 32 x 50 images) \n",
    "\n",
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d181f9dc-6a1d-4caf-9313-d5eb7884aa47",
   "metadata": {},
   "source": [
    "# 1024 train tasks"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f651c8d9-ee3d-4ea3-b6c3-3a6a3564a487",
   "metadata": {},
   "source": [
    "# test with train_tasks"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "37b66481-a357-4125-815d-49fc6fe394f0",
   "metadata": {},
   "source": [
    "## hessian elements 1024"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "825f243f-70aa-4681-afdd-2c9e07c2a327",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh1024_expl_opa_nh1024_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8706a660-b45b-4cde-b95d-b8d2a3cfa3f5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks], bins=1024)\n",
    "plt.xlabel('self_rank')\n",
    "plt.ylabel('count')\n",
    "plt.xlim([-1, 50])\n",
    "plt.ylim([0, 130])\n",
    "plt.savefig('self_rank_cnn_1024.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1d2b1458-0134-4c29-914e-f5e3d2c278bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh1024_expl_opa_nh2048_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1d1f3e3f-0385-4ebf-89a7-3f17a1a98264",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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avPee++ZSy65xJxzzjmmqakp3FvvVHfffbeJi4szGzduNN98803wv8bGxuAxd911lxkyZIjZsGGD2bZtm8nIyDAZGRlh3HXnO95c9uzZYxYtWmS2bdtmqqurzZtvvmnOPPNMc+WVV4Z5553voYceMmVlZaa6utp89NFH5qGHHjIul8usX7/eGNPz7hcC5T+sWLHCDBkyxERHR5sxY8aYzZs3h3tLYXfrrbea5ORkEx0dbU4//XRz6623mj179oR7W13u/fffN5La/JeTk2OMOfqjxgUFBSYxMdF4PB4zfvx4U1VVFd5Nd5FjzaaxsdFkZWWZ0047zbjdbjN06FAzc+bMHhH+TjORZFatWhU85rvvvjP33HOPOfXUU01MTIy58cYbzTfffBO+TXeB481l79695sorrzQJCQnG4/GYs88+2zzwwAOmvr4+vBvvAnfeeacZOnSoiY6ONqeddpoZP358ME6M6Xn3i8sYY7ru/RoAAIDj4zMoAADAOgQKAACwDoECAACsQ6AAAADrECgAAMA6BAoAALAOgQIAAKxDoAAAAOsQKAAAwDoECgAAsA6BAgAArEOgAAAA6/w/CSFyAMvz+yAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks/32], bins=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ad0e4d7-d890-4065-9c1a-81dc769d62c4",
   "metadata": {},
   "source": [
    "## hessian elements 2048"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "093c2ef2-085f-409d-a180-d7cb2b8b40ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh2048_expl_opa_nh2048_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "51e40697-83c1-4e5f-93c5-7323f8bd655a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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avPee++ZSy65xJxzzjmmqakp3FvvVHfffbeJi4szGzduNN98803wv8bGxuAxd911lxkyZIjZsGGD2bZtm8nIyDAZGRlh3HXnO95c9uzZYxYtWmS2bdtmqqurzZtvvmnOPPNMc+WVV4Z5553voYceMmVlZaa6utp89NFH5qGHHjIul8usX7/eGNPz7hcC5T+sWLHCDBkyxERHR5sxY8aYzZs3h3tLYXfrrbea5ORkEx0dbU4//XRz6623mj179oR7W13u/fffN5La/JeTk2OMOfqjxgUFBSYxMdF4PB4zfvx4U1VVFd5Nd5FjzaaxsdFkZWWZ0047zbjdbjN06FAzc+bMHhH+TjORZFatWhU85rvvvjP33HOPOfXUU01MTIy58cYbzTfffBO+TXeB481l79695sorrzQJCQnG4/GYs88+2zzwwAOmvr4+vBvvAnfeeacZOnSoiY6ONqeddpoZP358ME6M6Xn3i8sYY7ru/RoAAIDj4zMoAADAOgQKAACwDoECAACsQ6AAAADrECgAAMA6BAoAALAOgQIAAKxDoAAAAOsQKAAAwDoECgAAsA6BAgAArEOgAAAA6/w/CSFyAMvz+yAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks/32], bins=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "03cb10a3-dc36-401e-aa88-105c0f71a3a8",
   "metadata": {},
   "source": [
    "## 512 hessian elements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "3189da0f-0643-4bb6-ae0a-a1c50bc5c334",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh512_expl_opa_nh1024_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "c0a0a103-1d5c-47c2-9f5a-0c73b4c7fa49",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DR06VDt37lSbNm1srBwAAISSZh2IOnTooJUrV2rlypVXPcbhcGjJkiVasmRJ8AoDAAAtSrO+hwgAACAYCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeI0KRMOHD1dlZWW98aqqKg0fPvxmawIAAAiqRgWivXv36vLly/XGL126pHffffemiwIAAAim1t/l4A8++MD3748//lilpaW+7draWu3cuVO33npr4KoDAAAIgu8UiPr16yeHwyGHw9HgS2MRERFavXp1wIoDAAAIhu8UiIqLi2VZlr73ve/p4MGD6ty5s29feHi4unTpolatWgW8SAAAgKb0nQJRt27dJEler7dJigEAALDDdwpE/+jUqVPas2ePysvL6wWkhQsX3nRhAAAAwdKoQPTyyy9r1qxZ6tSpk+Li4uRwOHz7HA4HgQgAAISURgWiZ599Vs8995zmzZsX6HoAAACCrlGfQ3T+/HlNnjw50LUAAADYolGBaPLkydq1a1egawEAALBFo14y+/73v6/s7GwdOHBAvXv3ltPp9Nv/85//PCDFAQAABEOjAtH69evVvn175efnKz8/32+fw+EgEAEAgJDSqEBUXFwc6DoAAABs06h7iAAAAFqSRl0hmjZt2jX3v/LKK40qBgAAwA6NCkTnz5/32/Z4PDp+/LgqKysb/NJXAACA5qxRgWjLli31xrxer2bNmqXbbrvtposCAAAIpoDdQxQWFqasrCy9+OKLgZoSAAAgKAJ6U/Xp06d15cqVQE4JAADQ5Br1kllWVpbftmVZKikp0TvvvKOpU6cGpDAAAIBgaVQgOnr0qN92WFiYOnfurBdeeOG670ADAABobhoViPbs2RPoOgAAAGzTqEBU58svv9TJkyclSbfffrs6d+4ckKIAAACCqVE3VVdXV2vatGmKj4/XPffco3vuuUcJCQmaPn26ampqAl0jAABAk2pUIMrKylJ+fr7efvttVVZWqrKyUm+99Zby8/P1i1/8ItA1AgAANKlGvWT2pz/9SW+++aaGDRvmGxs7dqwiIiL04IMPau3atYGqDwAAoMk16gpRTU2NYmNj64136dKFl8wAAEDIaVQgSklJ0dNPP61Lly75xr755hstXrxYKSkpAStOkv7v//5PP/3pT9WxY0dFRESod+/eOnz4sG+/ZVlauHCh4uPjFRERodTUVJ06dSqgNQAAgJatUS+ZrVy5UqNHj1bXrl3Vt29fSdLf/vY3uVwu7dq1K2DFnT9/XkOGDNG9996rHTt2qHPnzjp16pRuueUW3zHLly/XqlWr9Pvf/17JycnKzs5WWlqaPv74Y7Vp0yZgtQAAgJarUYGod+/eOnXqlDZt2qRPPvlEkvTwww8rPT1dERERASvu+eefV2JiojZs2OAbS05O9v3bsiytXLlSTz31lMaPHy9JevXVVxUbG6utW7dqypQpAasFAAC0XI0KRDk5OYqNjdWMGTP8xl955RV9+eWXmjdvXkCK+8tf/qK0tDRNnjxZ+fn5uvXWWzV79mzf7y0uLlZpaalSU1N950RFRWnQoEEqKCi4aiByu91yu92+7aqqKkmSx+ORx+Np8Jy6cVeYdd26rzYHbl7d2rLG9qEH9qMH9qMHzUMg199hWdb1/4f/J927d9fmzZs1ePBgv/HCwkJNmTJFxcXFASmu7iWvrKwsTZ48WYcOHdLjjz+udevWaerUqXr//fc1ZMgQnT17VvHx8b7zHnzwQTkcDr3++usNzrto0SItXry43vjmzZvVtm3bgNQOAACaVk1Njf793/9dFy5cUGRk5E3N1agrRKWlpX4BpE7nzp1VUlJyUwX9I6/XqwEDBmjp0qWSpH/5l3/R8ePHfYGosRYsWOD3BbVVVVVKTEzUqFGjrrqgHo9Hubm5yj4cJrfXcc35jy9Ka3RtuLa6PowcOVJOp9PucoxED+xHD+xHD5qHioqKgM3VqECUmJio/fv3+93PI0n79+9XQkJCQAqTpPj4eN1xxx1+Y7169dKf/vQnSVJcXJwkqayszC+glZWVqV+/fled1+VyyeVy1Rt3Op3X/cN2ex1y1147EPHkaHo30is0LXpgP3pgP3pgr0CufaMC0YwZM5SZmSmPx6Phw4dLkvLy8vTkk08G9JOqhwwZ4vuutDp///vf1a1bN0nf3mAdFxenvLw8XwCqqqpSYWGhZs2aFbA6AABAy9aoQPTEE0+ooqJCs2fP1uXLlyV9e7/PvHnztGDBgoAVN3fuXA0ePFhLly7Vgw8+qIMHD2r9+vVav369JMnhcCgzM1PPPvusevTo4XvbfUJCgiZMmBCwOgAAQMvWqEDkcDj0/PPPKzs7WydOnFBERIR69OjR4MtQN2PgwIHasmWLFixYoCVLlig5OVkrV65Uenq675gnn3xS1dXVmjlzpiorKzV06FDt3LmTzyACAAA3rFGBqE779u01cODAQNXSoPvvv1/333//Vfc7HA4tWbJES5YsadI6AABAy9Wor+4AAABoSQhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGC+kAtGyZcvkcDiUmZnpG7t06ZIyMjLUsWNHtW/fXpMmTVJZWZl9RQIAgJATMoHo0KFD+s1vfqM+ffr4jc+dO1dvv/223njjDeXn5+vs2bN64IEHbKoSAACEopAIRBcvXlR6erpefvll3XLLLb7xCxcu6He/+51WrFih4cOHq3///tqwYYPef/99HThwwMaKAQBAKAmJQJSRkaH77rtPqampfuNFRUXyeDx+4z179lRSUpIKCgqCXSYAAAhRre0u4Hpee+01HTlyRIcOHaq3r7S0VOHh4YqOjvYbj42NVWlp6VXndLvdcrvdvu2qqipJksfjkcfjafCcunFXmHXdmq82B25e3dqyxvahB/ajB/ajB81DINe/WQeiL774Qo8//rhyc3PVpk2bgM2bk5OjxYsX1xvftWuX2rZte81znxngve7827dvb3RtuDG5ubl2l2A8emA/emA/emCvmpqagM3lsCzr+pc8bLJ161ZNnDhRrVq18o3V1tbK4XAoLCxM//M//6PU1FSdP3/e7ypRt27dlJmZqblz5zY4b0NXiBITE/XVV18pMjKywXM8Ho9yc3OVfThMbq/jmnUfX5T2HR4lvou6PowcOVJOp9PucoxED+xHD+xHD5qHiooKxcfH68KFC1f9//tGNesrRCNG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SND3vvc9paen68yZM5IC24MW88GMTeWrr75SbW1tvU+9jo2N1SeffGJTVeYqLS2VpAb7UbcPgeX1epWZmakhQ4borrvukvRtH8LDw+t9ByB9CKwPP/xQKSkpunTpktq3b68tW7bojjvu0LFjx1j/IHnttdd05MgRHTp0qN4+ngfBMWjQIG3cuFG33367SkpKtHjxYv3bv/2bjh8/HtAeEIgAXFNGRoaOHz/u95o9guP222/XsWPHdOHCBb355puaOnWq8vPz7S7LGF988YUef/xx5ebmqk2bNnaXY6wxY8b4/t2nTx8NGjRI3bp10x//+EdFREQE7Pfwktl1dOrUSa1atap3x3pZWZni4uJsqspcdWtOP4Jjzpw52rZtm/bs2aOuXbv6xuPi4nT58mVVVlb6HU8fAis8PFzf//731b9/f+Xk5Khv37767//+b9Y/SIqKilReXq5//dd/VevWrdW6dWvl5+dr1apVat26tWJjY+mDDaKjo/WDH/xAn376aUCfCwSi6wgPD1f//v2Vl5fnG/N6vcrLy1NKSoqNlZkpOTlZcXFxfv2oqqpSYWEh/Qggy7I0Z84cbdmyRbt371ZycrLf/v79+8vpdPr14eTJkzpz5gx9aEJer1dut5v1D5IRI0boww8/1LFjx3w/AwYMUHp6uu/f9CH4Ll68qNOnTys+Pj6wz4WbuPHbGK+99prlcrmsjRs3Wh9//LE1c+ZMKzo62iotLbW7tBbp66+/to4ePWodPXrUkmStWLHCOnr0qPX5559blmVZy5Yts6Kjo6233nrL+uCDD6zx48dbycnJ1jfffGNz5S3HrFmzrKioKGvv3r1WSUmJ76empsZ3zKOPPmolJSVZu3fvtg4fPmylpKRYKSkpNlbdssyfP9/Kz8+3iouLrQ8++MCaP3++5XA4rF27dlmWxfrb5R/fZWZZ9CEYfvGLX1h79+61iouLrf3791upqalWp06drPLycsuyAtcDAtENWr16tZWUlGSFh4dbd999t3XgwAG7S2qx9uzZY0mq9zN16lTLsr596312drYVGxtruVwua8SIEdbJkyftLbqFaWj9JVkbNmzwHfPNN99Ys2fPtm655Rarbdu21sSJE62SkhL7im5hpk2bZnXr1s0KDw+3OnfubI0YMcIXhiyL9bfLPwci+tD0HnroISs+Pt4KDw+3br31Vuuhhx6yPv30U9/+QPWAb7sHAADG4x4iAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAzd5nn30mh8OhY8eO+cb279+v3r17y+l0asKECc2qNgChp7XdBQBAY2RlZalfv37asWOH2rdvb3c5AEIcV4gAhKTTp09r+PDh6tq1q6Kjo7/TuZZl6cqVK01TGICQRCACEDRvvvmmevfurYiICHXs2FGpqamqrq6WJP32t79Vr1691KZNG/Xs2VMvvfRSg3PUvURVUVGhadOmyeFwaOPGjdf8vXv37pXD4dCOHTvUv39/uVwuvffeezp9+rTGjx+v2NhYtW/fXgMHDtRf//pXv3O7d++upUuXatq0aerQoYOSkpK0fv36q/6u2tpaTZs2TT179tSZM2e+2wIBsA2BCEBQlJSU6OGHH9a0adN04sQJ7d27Vw888IAsy9KmTZu0cOFCPffcczpx4oSWLl2q7Oxs/f73v683T2JiokpKShQZGamVK1eqpKREDz300A3VMH/+fC1btkwnTpxQnz59dPHiRY0dO1Z5eXk6evSoRo8erXHjxtULMi+88IIGDBigo0ePavbs2Zo1a5ZOnjxZb363263Jkyfr2LFjevfdd5WUlNS4xQIQfBYABEFRUZElyfrss8/q7bvtttuszZs3+40988wzVkpKimVZllVcXGxJso4ePerbHxUVZW3YsOGGfveePXssSdbWrVuve+ydd95prV692rfdrVs366c//alv2+v1Wl26dLHWrl3rV9u7775rjRgxwho6dKhVWVl5Q3UBaD64qRpAUPTt21cjRoxQ7969lZaWplGjRuknP/mJwsPDdfr0aU2fPl0zZszwHX/lyhVFRUUFtIYBAwb4bV+8eFGLFi3SO++8o5KSEl25ckXffPNNvStEffr08f3b4XAoLi5O5eXlfsc8/PDD6tq1q3bv3q2IiIiA1g2g6fGSGYCgaNWqlXJzc7Vjxw7dcccdWr16tW6//XYdP35ckvTyyy/r2LFjvp/jx4/rwIEDAa2hXbt2ftv/9V//pS1btmjp0qV69913dezYMfXu3VuXL1/2O87pdPptOxwOeb1ev7GxY8fqgw8+UEFBQUBrBhAcXCECEDQOh0NDhgzRkCFDtHDhQnXr1k379+9XQkKC/vd//1fp6elBrWf//v362c9+pokTJ0r69orRZ5991qi5Zs2apbvuuks//vGP9c477+hHP/pRACsF0NQIRACCorCwUHl5eRo1apS6dOmiwsJCffnll+rVq5cWL16sn//854qKitLo0aPldrt1+PBhnT9/XllZWU1WU48ePfTnP/9Z48aNk8PhUHZ2dr0rP9/FY489ptraWt1///3asWOHhg4dGsBqATQlAhGAoIiMjNS+ffu0cuVKVVVVqVu3bnrhhRc0ZswYSVLbtm31y1/+Uk888YTatWun3r17KzMzs0lrWrFihaZNm6bBgwerU6dOmjdvnqqqqm5qzszMTHm9Xo0dO1Y7d+7U4MGDA1QtgKbksCzLsrsIAAAAO3FTNQAAMB6BCEDIe/TRR9W+ffsGfx599FG7ywMQAnjJDEDIKy8vv+q9P5GRkerSpUuQKwIQaghEAADAeLxkBgAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAY7/8B5oNV/6gskZ0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks], bins=1024)\n",
    "plt.xlabel('self_rank')\n",
    "plt.ylabel('count')\n",
    "plt.xlim([-1, 50])\n",
    "plt.ylim([0, 130])\n",
    "plt.savefig('self_rank_cnn_512.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "9a497ff2-23ad-4a8c-95e0-86a3726e3f27",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh512_expl_opa_nh2048_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "40efa6f9-7114-49f1-ae5e-c4b8544727b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/ZEerUsdPHjQvP/+++b99983ksySJUvM+++/b7744gtjjDEPP/ywSUxMNK+++qr54IMPzOTJk01GRob55ptvIjx5+B1pNwcPHjS//OUvTUVFhampqTFvvfWWOf/8882QIUNMc3NzpEcPq1tuucUkJCSYjRs3mn379gX/NDU1Bc+5+eabzaBBg8yGDRvMtm3bTFZWlsnKyorg1OF3tL3s3r3bLFq0yGzbts3U1NSYV1991Zx22mnmkksuifDk4XfPPfeYTZs2mZqaGvPBBx+Ye+65x7hcLrN+/XpjzIl3vRAo/2H58uVm0KBBJjY21owZM8Zs2bIl0iNF3HXXXWdSU1NNbGys+d73vmeuu+46s3v37kiP1eXefvttI6ndn7y8PGPMt99qXFRUZJKTk43H4zHjx4831dXVkR26ixxpN01NTSYnJ8ecfPLJxu12m8GDB5tZs2adEOHvtBNJZtWqVcFzvvnmG3Prrbeafv36mbi4OHPNNdeYffv2RW7oLnC0vezZs8dccsklJikpyXg8HnPGGWeYO++80zQ0NER28C5w0003mcGDB5vY2Fhz8sknm/HjxwfjxJgT73pxGWNM171fAwAAcHR8DQoAALAOgQIAAKxDoAAAAOsQKAAAwDoECgAAsA6BAgAArEOgAAAA6xAoAADAOgQKAACwDoECAACsQ6AAAADrECgAAMA6/w/bzGZEXa/5LwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks/32], bins=32)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d9663256-10c0-46ec-a3cf-68d42cf98d1e",
   "metadata": {},
   "source": [
    "## 256 hessian elements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "7f502982-72cb-4903-9440-ac6692208965",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh256_expl_opa_nh1024_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "0a172137-89dc-4d23-a2e8-a7356fa48e6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkQAAAGxCAYAAACDV6ltAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAAArNUlEQVR4nO3df3BU5b3H8c8GNkv4kcQA+SUJpJYKaoB7AWmAaxECAZQCUhRvOpcWBq4QrCG9CswYfqkEaUUuFKHYCnUGqtUWrCiUNEBQDAECqaJIkRvFuZBEA0kkkWXJnvuHw95uE34YNnuSPO/XTGY4zznnyTfPNxk+c87ZXYdlWZYAAAAMFmJ3AQAAAHYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjNfW7gKaA6/XqzNnzqhTp05yOBx2lwMAAG6AZVn66quvFB8fr5CQm7vGQyCSdObMGSUkJNhdBgAAaITPP/9c3bp1u6k5CESSOnXqJOmbBQ0PD2/wGI/Ho127dmnUqFFyOp3BLA//gD7Yjx7Yjx7Yjx40D+fOnVNSUpLv//GbQSCSfLfJwsPDrxmI2rdvr/DwcH75bUQf7EcP7EcP7EcPmgePxyNJAXnchYeqAQCA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGM/WQLRv3z6NGzdO8fHxcjgc2rZtm2+fx+PRvHnzlJycrA4dOig+Pl7/8R//oTNnzvjNce7cOaWnpys8PFyRkZGaPn26Lly4EOSfBAAAtGS2BqKamhr17dtXa9eurbevtrZWR44cUXZ2to4cOaI//elPOnHihH74wx/6HZeenq4PP/xQubm52r59u/bt26eZM2cG60cAAACtQFs7v/mYMWM0ZsyYBvdFREQoNzfXb+xXv/qV7r77bp0+fVqJiYk6fvy4du7cqUOHDmnAgAGSpDVr1mjs2LH65S9/qfj4+Cb/GQAAQMtnayD6tqqqquRwOBQZGSlJKigoUGRkpC8MSVJqaqpCQkJUWFioiRMnNjiP2+2W2+32bVdXV0v65jadx+Np8Jwr41fbj+CgD/ajB/ajB/ajB81DINe/xQSiixcvat68eXr44YcVHh4uSSotLVV0dLTfcW3btlVUVJRKS0uvOldOTo6WLFlSb3zXrl1q3779Nev456tWsAd9sB89sB89sB89sFdtbW3A5moRgcjj8ejBBx+UZVlat27dTc+3YMECZWVl+barq6uVkJCgUaNG+cJWQzXk5uZq5MiRcjqdN10DGoc+2I8e2I8e2I8eNA8VFRUBm6vZB6IrYeizzz7T7t27/QJLbGysysvL/Y6/fPmyzp07p9jY2KvO6XK55HK56o07nc7r/mLfyDFoevTBfvTAfvTAfvTAXoFc+2b9PkRXwtDJkyf117/+VZ07d/bbn5KSosrKShUVFfnGdu/eLa/Xq0GDBgW7XAAA0ELZeoXowoUL+uSTT3zbJSUlKi4uVlRUlOLi4vSjH/1IR44c0fbt21VXV+d7LigqKkqhoaHq3bu3Ro8erRkzZmj9+vXyeDyaM2eOpkyZwivMAADADbM1EB0+fFj33nuvb/vKcz1Tp07V4sWL9ec//1mS1K9fP7/z9uzZo2HDhkmSNm/erDlz5mjEiBEKCQnRpEmTtHr16qDUDwAAWgdbA9GwYcNkWdZV919r3xVRUVHasmVLIMsCAACGadbPEAEAAAQDgQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMZra3cBLc1di/8id53jmsd8uvy+IFUDAAACgStEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHi2BqJ9+/Zp3Lhxio+Pl8Ph0LZt2/z2W5alhQsXKi4uTmFhYUpNTdXJkyf9jjl37pzS09MVHh6uyMhITZ8+XRcuXAjiTwEAAFo6WwNRTU2N+vbtq7Vr1za4f8WKFVq9erXWr1+vwsJCdejQQWlpabp48aLvmPT0dH344YfKzc3V9u3btW/fPs2cOTNYPwIAAGgF2tr5zceMGaMxY8Y0uM+yLK1atUpPPvmkxo8fL0l6+eWXFRMTo23btmnKlCk6fvy4du7cqUOHDmnAgAGSpDVr1mjs2LH65S9/qfj4+KD9LAAAoOWyNRBdS0lJiUpLS5Wamuobi4iI0KBBg1RQUKApU6aooKBAkZGRvjAkSampqQoJCVFhYaEmTpzY4Nxut1tut9u3XV1dLUnyeDzyeDwNnnNl3BViXbf2q82Bm3dlbVlj+9AD+9ED+9GD5iGQ699sA1FpaakkKSYmxm88JibGt6+0tFTR0dF++9u2bauoqCjfMQ3JycnRkiVL6o3v2rVL7du3v2ZdTw3wXrf2t99++7rH4Obk5ubaXYLx6IH96IH96IG9amtrAzZXsw1ETWnBggXKysrybVdXVyshIUGjRo1SeHh4g+d4PB7l5uYq+3CI3F7HNec/tjgtoPXi/13pw8iRI+V0Ou0ux0j0wH70wH70oHmoqKgI2FzNNhDFxsZKksrKyhQXF+cbLysrU79+/XzHlJeX+513+fJlnTt3znd+Q1wul1wuV71xp9N53V9st9chd921AxF/HE3vRnqFpkUP7EcP7EcP7BXItW+270OUlJSk2NhY5eXl+caqq6tVWFiolJQUSVJKSooqKytVVFTkO2b37t3yer0aNGhQ0GsGAAAtk61XiC5cuKBPPvnEt11SUqLi4mJFRUUpMTFRmZmZevrpp9WzZ08lJSUpOztb8fHxmjBhgiSpd+/eGj16tGbMmKH169fL4/Fozpw5mjJlCq8wAwAAN8zWQHT48GHde++9vu0rz/VMnTpVmzZt0hNPPKGamhrNnDlTlZWVGjp0qHbu3Kl27dr5ztm8ebPmzJmjESNGKCQkRJMmTdLq1auD/rMAAICWy9ZANGzYMFnW1V/G7nA4tHTpUi1duvSqx0RFRWnLli1NUR4AADBEs32GCAAAIFgIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIzXrANRXV2dsrOzlZSUpLCwMN1222166qmnZFmW7xjLsrRw4ULFxcUpLCxMqampOnnypI1VAwCAlqZZB6Jnn31W69at069+9SsdP35czz77rFasWKE1a9b4jlmxYoVWr16t9evXq7CwUB06dFBaWpouXrxoY+UAAKAlaWt3Adfy3nvvafz48brvvvskST169NDvf/97HTx4UNI3V4dWrVqlJ598UuPHj5ckvfzyy4qJidG2bds0ZcoU22oHAAAtR7MORIMHD9aGDRv097//Xd/73vf0t7/9Te+++65WrlwpSSopKVFpaalSU1N950RERGjQoEEqKCi4aiByu91yu92+7erqakmSx+ORx+Np8Jwr464Qq8H9DR2LwLuytqyxfeiB/eiB/ehB8xDI9W/WgWj+/Pmqrq5Wr1691KZNG9XV1emZZ55Renq6JKm0tFSSFBMT43deTEyMb19DcnJytGTJknrju3btUvv27a9Z01MDvNet++23377uMbg5ubm5dpdgPHpgP3pgP3pgr9ra2oDN1awD0R/+8Adt3rxZW7Zs0Z133qni4mJlZmYqPj5eU6dObfS8CxYsUFZWlm+7urpaCQkJGjVqlMLDwxs8x+PxKDc3V9mHQ+T2Oq45/7HFaY2uDdd2pQ8jR46U0+m0uxwj0QP70QP70YPmoaKiImBzNetA9Pjjj2v+/Pm+W1/Jycn67LPPlJOTo6lTpyo2NlaSVFZWpri4ON95ZWVl6tev31Xndblccrlc9cadTud1f7HdXofcddcORPxxNL0b6RWaFj2wHz2wHz2wVyDXvlm/yqy2tlYhIf4ltmnTRl7vN7etkpKSFBsbq7y8PN/+6upqFRYWKiUlJai1AgCAlqtZXyEaN26cnnnmGSUmJurOO+/U0aNHtXLlSk2bNk2S5HA4lJmZqaefflo9e/ZUUlKSsrOzFR8frwkTJthbPAAAaDGadSBas2aNsrOzNXv2bJWXlys+Pl7/+Z//qYULF/qOeeKJJ1RTU6OZM2eqsrJSQ4cO1c6dO9WuXTsbKwcAAC1Jsw5EnTp10qpVq7Rq1aqrHuNwOLR06VItXbo0eIUBAIBWpVk/QwQAABAMBCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgvEYFouHDh6uysrLeeHV1tYYPH36zNQEAAARVowLR3r17denSpXrjFy9e1DvvvHPTRQEAAART229z8Pvvv+/790cffaTS0lLfdl1dnXbu3Klbb701cNUBAAAEwbcKRP369ZPD4ZDD4Wjw1lhYWJjWrFkTsOIAAACC4VsFopKSElmWpe985zs6ePCgunbt6tsXGhqq6OhotWnTJuBFAgAANKVvFYi6d+8uSfJ6vU1SDAAAgB2+VSD6RydPntSePXtUXl5eLyAtXLjwpgsDAAAIlkYFohdffFGzZs1Sly5dFBsbK4fD4dvncDgIRAAAoEVpVCB6+umn9cwzz2jevHmBrgcAACDoGvU+ROfPn9fkyZMDXQsAAIAtGhWIJk+erF27dgW6FgAAAFs06pbZd7/7XWVnZ+vAgQNKTk6W0+n02/+zn/0sIMUBAAAEQ6MC0YYNG9SxY0fl5+crPz/fb5/D4SAQAQCAFqVRgaikpCTQdQAAANimUc8QAQAAtCaNukI0bdq0a+5/6aWXGlUMAACAHRoViM6fP++37fF4dOzYMVVWVjb4oa8AAADNWaMC0datW+uNeb1ezZo1S7fddttNFwUAABBMAXuGKCQkRFlZWXr++ecDNSUAAEBQBPSh6lOnTuny5cuBnBIAAKDJNeqWWVZWlt+2ZVk6e/as3nrrLU2dOjUghQEAAARLowLR0aNH/bZDQkLUtWtXPffcc9d9BRoAAEBz06hAtGfPnkDXAQAAYJtGBaIrvvjiC504cUKSdPvtt6tr164BKQoAACCYGvVQdU1NjaZNm6a4uDjdc889uueeexQfH6/p06ertrY20DUCAAA0qUYFoqysLOXn5+vNN99UZWWlKisr9cYbbyg/P18///nPA10jAABAk2rULbM//vGPev311zVs2DDf2NixYxUWFqYHH3xQ69atC1R9AAAATa5RV4hqa2sVExNTbzw6OppbZgAAoMVpVCBKSUnRokWLdPHiRd/Y119/rSVLliglJSVgxUnS//7v/+rHP/6xOnfurLCwMCUnJ+vw4cO+/ZZlaeHChYqLi1NYWJhSU1N18uTJgNYAAABat0bdMlu1apVGjx6tbt26qW/fvpKkv/3tb3K5XNq1a1fAijt//ryGDBmie++9Vzt27FDXrl118uRJ3XLLLb5jVqxYodWrV+t3v/udkpKSlJ2drbS0NH300Udq165dwGoBAACtV6MCUXJysk6ePKnNmzfr448/liQ9/PDDSk9PV1hYWMCKe/bZZ5WQkKCNGzf6xpKSknz/tixLq1at0pNPPqnx48dLkl5++WXFxMRo27ZtmjJlSsBqAQAArVejAlFOTo5iYmI0Y8YMv/GXXnpJX3zxhebNmxeQ4v785z8rLS1NkydPVn5+vm699VbNnj3b931LSkpUWlqq1NRU3zkREREaNGiQCgoKrhqI3G633G63b7u6ulqS5PF45PF4GjznyrgrxLpu3VebAzfvytqyxvahB/ajB/ajB81DINffYVnW9f+H/yc9evTQli1bNHjwYL/xwsJCTZkyRSUlJQEp7sotr6ysLE2ePFmHDh3SY489pvXr12vq1Kl67733NGTIEJ05c0ZxcXG+8x588EE5HA69+uqrDc67ePFiLVmypN74li1b1L59+4DUDgAAmlZtba3+/d//XVVVVQoPD7+puRp1hai0tNQvgFzRtWtXnT179qYK+kder1cDBgzQsmXLJEn/8i//omPHjvkCUWMtWLDA7wNqq6urlZCQoFGjRl11QT0ej3Jzc5V9OERur+Oa8x9bnNbo2nBtV/owcuRIOZ1Ou8sxEj2wHz2wHz1oHioqKgI2V6MCUUJCgvbv3+/3PI8k7d+/X/Hx8QEpTJLi4uJ0xx13+I317t1bf/zjHyVJsbGxkqSysjK/gFZWVqZ+/fpddV6XyyWXy1Vv3Ol0XvcX2+11yF137UDEH0fTu5FeoWnRA/vRA/vRA3sFcu0bFYhmzJihzMxMeTweDR8+XJKUl5enJ554IqDvVD1kyBDfZ6Vd8fe//13du3eX9M0D1rGxscrLy/MFoOrqahUWFmrWrFkBqwMAALRujQpEjz/+uCoqKjR79mxdunRJ0jfP+8ybN08LFiwIWHFz587V4MGDtWzZMj344IM6ePCgNmzYoA0bNkiSHA6HMjMz9fTTT6tnz56+l93Hx8drwoQJAasDAAC0bo0KRA6HQ88++6yys7N1/PhxhYWFqWfPng3ehroZAwcO1NatW7VgwQItXbpUSUlJWrVqldLT033HPPHEE6qpqdHMmTNVWVmpoUOHaufOnbwHEQAAuGGNCkRXdOzYUQMHDgxULQ26//77df/99191v8Ph0NKlS7V06dImrQMAALRejfroDgAAgNaEQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxWlQgWr58uRwOhzIzM31jFy9eVEZGhjp37qyOHTtq0qRJKisrs69IAADQ4rSYQHTo0CH9+te/Vp8+ffzG586dqzfffFOvvfaa8vPzdebMGT3wwAM2VQkAAFqiFhGILly4oPT0dL344ou65ZZbfONVVVX67W9/q5UrV2r48OHq37+/Nm7cqPfee08HDhywsWIAANCStIhAlJGRofvuu0+pqal+40VFRfJ4PH7jvXr1UmJiogoKCoJdJgAAaKHa2l3A9bzyyis6cuSIDh06VG9faWmpQkNDFRkZ6TceExOj0tLSq87pdrvldrt929XV1ZIkj8cjj8fT4DlXxl0h1nVrvtocuHlX1pY1tg89sB89sB89aB4Cuf7NOhB9/vnneuyxx5Sbm6t27doFbN6cnBwtWbKk3viuXbvUvn37a5771ADvded/++23G10bbkxubq7dJRiPHtiPHtiPHtirtrY2YHM5LMu6/iUPm2zbtk0TJ05UmzZtfGN1dXVyOBwKCQnRX/7yF6Wmpur8+fN+V4m6d++uzMxMzZ07t8F5G7pClJCQoC+//FLh4eENnuPxeJSbm6vswyFyex3XrPvY4rRv8VPi27jSh5EjR8rpdNpdjpHogf3ogf3oQfNQUVGhuLg4VVVVXfX/7xvVrK8QjRgxQh988IHf2E9/+lP16tVL8+bNU0JCgpxOp/Ly8jRp0iRJ0okTJ3T69GmlpKRcdV6XyyWXy1Vv3Ol0XvcX2+11yF137UDEH0fTu5FeoWnRA/vRA/vRA3sFcu2bdSDq1KmT7rrrLr+xDh06qHPnzr7x6dOnKysrS1FRUQoPD9ejjz6qlJQUff/737ejZAAA0AI160B0I55//nmFhIRo0qRJcrvdSktL0wsvvGB3WQAAoAVpcYFo7969ftvt2rXT2rVrtXbtWnsKAgAALV6LeB8iAACApkQgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYLxmHYhycnI0cOBAderUSdHR0ZowYYJOnDjhd8zFixeVkZGhzp07q2PHjpo0aZLKyspsqhgAALREzToQ5efnKyMjQwcOHFBubq48Ho9GjRqlmpoa3zFz587Vm2++qddee035+fk6c+aMHnjgARurBgAALU1buwu4lp07d/ptb9q0SdHR0SoqKtI999yjqqoq/fa3v9WWLVs0fPhwSdLGjRvVu3dvHThwQN///vftKBsAALQwzfoK0T+rqqqSJEVFRUmSioqK5PF4lJqa6jumV69eSkxMVEFBgS01AgCAlqdZXyH6R16vV5mZmRoyZIjuuusuSVJpaalCQ0MVGRnpd2xMTIxKS0uvOpfb7Zbb7fZtV1dXS5I8Ho88Hk+D51wZd4VY1631anPg5l1ZW9bYPvTAfvTAfvSgeQjk+reYQJSRkaFjx47p3Xffvem5cnJytGTJknrju3btUvv27a957lMDvNed/+233250bbgxubm5dpdgPHpgP3pgP3pgr9ra2oDN1SIC0Zw5c7R9+3bt27dP3bp1843Hxsbq0qVLqqys9LtKVFZWptjY2KvOt2DBAmVlZfm2q6urlZCQoFGjRik8PLzBczwej3Jzc5V9OERur+Oa9R5bnHaDPxm+rSt9GDlypJxOp93lGIke2I8e2I8eNA8VFRUBm6tZByLLsvToo49q69at2rt3r5KSkvz29+/fX06nU3l5eZo0aZIk6cSJEzp9+rRSUlKuOq/L5ZLL5ao37nQ6r/uL7fY65K67diDij6Pp3Uiv0LTogf3ogf3ogb0CufbNOhBlZGRoy5YteuONN9SpUyffc0EREREKCwtTRESEpk+frqysLEVFRSk8PFyPPvqoUlJSeIUZAAC4Yc06EK1bt06SNGzYML/xjRs36ic/+Ykk6fnnn1dISIgmTZokt9uttLQ0vfDCC0GuFAAAtGTNOhBZ1vVf0dWuXTutXbtWa9euDUJFAACgNWpR70MEAADQFAhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPEIRAAAwHgEIgAAYDwCEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRAAAwHoEIAAAYj0AEAACMRyACAADGa2t3ASbrMf+tGzru0+X3NXElAACYjStEAADAeAQiAABgPG6ZNYEbvRUGAACaB64QAQAA43GFqAW4kStOPHgNAEDjcYUIAAAYj0AEAACMRyACAADGIxABAADjEYgAAIDxCEQAAMB4BCIAAGA8AhEAADAegQgAABiv1QSitWvXqkePHmrXrp0GDRqkgwcP2l0SAABoIVpFIHr11VeVlZWlRYsW6ciRI+rbt6/S0tJUXl5ud2kAAKAFaBWfZbZy5UrNmDFDP/3pTyVJ69ev11tvvaWXXnpJ8+fPt7m61utGPmNNaprPWbtr8V/krnME9XsCAFqvFn+F6NKlSyoqKlJqaqpvLCQkRKmpqSooKLCxMgAA0FK0+CtEX375perq6hQTE+M3HhMTo48//rjBc9xut9xut2+7qqpKknTu3Dl5PJ4Gz/F4PKqtrVVbT4jqvFe/MmGXioqKoH/Ptpdrbui4QNZ2o32wYz1McaUHFRUVcjqddpdjJHpgP3rQPJw7d06SZFnWTc/V4gNRY+Tk5GjJkiX1xpOSkmyoJjC6PGd3BVdnR23NeT0AAIFVUVGhiIiIm5qjxQeiLl26qE2bNiorK/MbLysrU2xsbIPnLFiwQFlZWb5tr9erc+fOqXPnznI4Gr7qUF1drYSEBH3++ecKDw8P3A+Ab4U+2I8e2I8e2I8eNA9VVVVKTExUVFTUTc/V4gNRaGio+vfvr7y8PE2YMEHSNwEnLy9Pc+bMafAcl8sll8vlNxYZGXlD3y88PJxf/maAPtiPHtiPHtiPHjQPISE3/0h0iw9EkpSVlaWpU6dqwIABuvvuu7Vq1SrV1NT4XnUGAABwLa0iED300EP64osvtHDhQpWWlqpfv37auXNnvQetAQAAGtIqApEkzZkz56q3yALB5XJp0aJF9W61Ibjog/3ogf3ogf3oQfMQyD44rEC8Vg0AAKAFa/FvzAgAAHCzCEQAAMB4BCIAAGA8AtENWrt2rXr06KF27dpp0KBBOnjwoN0ltVr79u3TuHHjFB8fL4fDoW3btvnttyxLCxcuVFxcnMLCwpSamqqTJ0/aU2wrlZOTo4EDB6pTp06Kjo7WhAkTdOLECb9jLl68qIyMDHXu3FkdO3bUpEmT6r1BKhpv3bp16tOnj+99blJSUrRjxw7fftY/+JYvXy6Hw6HMzEzfGH1oeosXL5bD4fD76tWrl29/oHpAILoBr776qrKysrRo0SIdOXJEffv2VVpamsrLy+0urVWqqalR3759tXbt2gb3r1ixQqtXr9b69etVWFioDh06KC0tTRcvXgxypa1Xfn6+MjIydODAAeXm5srj8WjUqFGqqfn/z6+bO3eu3nzzTb322mvKz8/XmTNn9MADD9hYdevSrVs3LV++XEVFRTp8+LCGDx+u8ePH68MPP5TE+gfboUOH9Otf/1p9+vTxG6cPwXHnnXfq7Nmzvq93333Xty9gPbBwXXfffbeVkZHh266rq7Pi4+OtnJwcG6sygyRr69atvm2v12vFxsZav/jFL3xjlZWVlsvlsn7/+9/bUKEZysvLLUlWfn6+ZVnfrLnT6bRee+013zHHjx+3JFkFBQV2ldnq3XLLLdZvfvMb1j/IvvrqK6tnz55Wbm6u9YMf/MB67LHHLMvi7yBYFi1aZPXt27fBfYHsAVeIruPSpUsqKipSamqqbywkJESpqakqKCiwsTIzlZSUqLS01K8fERERGjRoEP1oQlVVVZLk+7ygoqIieTwevz706tVLiYmJ9KEJ1NXV6ZVXXlFNTY1SUlJY/yDLyMjQfffd57feEn8HwXTy5EnFx8frO9/5jtLT03X69GlJge1Bq3ljxqby5Zdfqq6urt67XsfExOjjjz+2qSpzlZaWSlKD/biyD4Hl9XqVmZmpIUOG6K677pL0TR9CQ0PrfQYgfQisDz74QCkpKbp48aI6duyorVu36o477lBxcTHrHySvvPKKjhw5okOHDtXbx99BcAwaNEibNm3S7bffrrNnz2rJkiX6t3/7Nx07diygPSAQAbimjIwMHTt2zO+ePYLj9ttvV3FxsaqqqvT6669r6tSpys/Pt7ssY3z++ed67LHHlJubq3bt2tldjrHGjBnj+3efPn00aNAgde/eXX/4wx8UFhYWsO/DLbPr6NKli9q0aVPvifWysjLFxsbaVJW5rqw5/QiOOXPmaPv27dqzZ4+6devmG4+NjdWlS5dUWVnpdzx9CKzQ0FB997vfVf/+/ZWTk6O+ffvqv//7v1n/ICkqKlJ5ebn+9V//VW3btlXbtm2Vn5+v1atXq23btoqJiaEPNoiMjNT3vvc9ffLJJwH9WyAQXUdoaKj69++vvLw835jX61VeXp5SUlJsrMxMSUlJio2N9etHdXW1CgsL6UcAWZalOXPmaOvWrdq9e7eSkpL89vfv319Op9OvDydOnNDp06fpQxPyer1yu92sf5CMGDFCH3zwgYqLi31fAwYMUHp6uu/f9CH4Lly4oFOnTikuLi6wfws38eC3MV555RXL5XJZmzZtsj766CNr5syZVmRkpFVaWmp3aa3SV199ZR09etQ6evSoJclauXKldfToUeuzzz6zLMuyli9fbkVGRlpvvPGG9f7771vjx4+3kpKSrK+//trmyluPWbNmWREREdbevXuts2fP+r5qa2t9xzzyyCNWYmKitXv3buvw4cNWSkqKlZKSYmPVrcv8+fOt/Px8q6SkxHr//fet+fPnWw6Hw9q1a5dlWay/Xf7xVWaWRR+C4ec//7m1d+9eq6SkxNq/f7+VmppqdenSxSovL7csK3A9IBDdoDVr1liJiYlWaGiodffdd1sHDhywu6RWa8+ePZakel9Tp061LOubl95nZ2dbMTExlsvlskaMGGGdOHHC3qJbmYbWX5K1ceNG3zFff/21NXv2bOuWW26x2rdvb02cONE6e/asfUW3MtOmTbO6d+9uhYaGWl27drVGjBjhC0OWxfrb5Z8DEX1oeg899JAVFxdnhYaGWrfeeqv10EMPWZ988olvf6B6wKfdAwAA4/EMEQAAMB6BCAAAGI9ABAAAjEcgAgAAxiMQAQAA4xGIAACA8QhEAADAeAQiAABgPAIRgGbv008/lcPhUHFxsW9s//79Sk5OltPp1IQJE5pVbQBanrZ2FwAAjZGVlaV+/fppx44d6tixo93lAGjhuEIEoEU6deqUhg8frm7duikyMvJbnWtZli5fvtw0hQFokQhEAILm9ddfV3JyssLCwtS5c2elpqaqpqZGkvSb3/xGvXv3Vrt27dSrVy+98MILDc5x5RZVRUWFpk2bJofDoU2bNl3z++7du1cOh0M7duxQ//795XK59O677+rUqVMaP368YmJi1LFjRw0cOFB//etf/c7t0aOHli1bpmnTpqlTp05KTEzUhg0brvq96urqNG3aNPXq1UunT5/+dgsEwDYEIgBBcfbsWT388MOaNm2ajh8/rr179+qBBx6QZVnavHmzFi5cqGeeeUbHjx/XsmXLlJ2drd/97nf15klISNDZs2cVHh6uVatW6ezZs3rooYduqIb58+dr+fLlOn78uPr06aMLFy5o7NixysvL09GjRzV69GiNGzeuXpB57rnnNGDAAB09elSzZ8/WrFmzdOLEiXrzu91uTZ48WcXFxXrnnXeUmJjYuMUCEHwWAARBUVGRJcn69NNP6+277bbbrC1btviNPfXUU1ZKSoplWZZVUlJiSbKOHj3q2x8REWFt3Ljxhr73nj17LEnWtm3brnvsnXfeaa1Zs8a33b17d+vHP/6xb9vr9VrR0dHWunXr/Gp75513rBEjRlhDhw61Kisrb6guAM0HD1UDCIq+fftqxIgRSk5OVlpamkaNGqUf/ehHCg0N1alTpzR9+nTNmDHDd/zly5cVERER0BoGDBjgt33hwgUtXrxYb731ls6ePavLly/r66+/rneFqE+fPr5/OxwOxcbGqry83O+Yhx9+WN26ddPu3bsVFhYW0LoBND1umQEIijZt2ig3N1c7duzQHXfcoTVr1uj222/XsWPHJEkvvviiiouLfV/Hjh3TgQMHAlpDhw4d/Lb/67/+S1u3btWyZcv0zjvvqLi4WMnJybp06ZLfcU6n02/b4XDI6/X6jY0dO1bvv/++CgoKAlozgODgChGAoHE4HBoyZIiGDBmihQsXqnv37tq/f7/i4+P1P//zP0pPTw9qPfv379dPfvITTZw4UdI3V4w+/fTTRs01a9Ys3XXXXfrhD3+ot956Sz/4wQ8CWCmApkYgAhAUhYWFysvL06hRoxQdHa3CwkJ98cUX6t27t5YsWaKf/exnioiI0OjRo+V2u3X48GGdP39eWVlZTVZTz5499ac//Unjxo2Tw+FQdnZ2vSs/38ajjz6quro63X///dqxY4eGDh0awGoBNCUCEYCgCA8P1759+7Rq1SpVV1ere/fueu655zRmzBhJUvv27fWLX/xCjz/+uDp06KDk5GRlZmY2aU0rV67UtGnTNHjwYHXp0kXz5s1TdXX1Tc2ZmZkpr9ersWPHaufOnRo8eHCAqgXQlByWZVl2FwEAAGAnHqoGAADGIxABaPEeeeQRdezYscGvRx55xO7yALQA3DID0OKVl5df9dmf8PBwRUdHB7kiAC0NgQgAABiPW2YAAMB4BCIAAGA8AhEAADAegQgAABiPQAQAAIxHIAIAAMYjEAEAAOMRiAAAgPH+D7LxY6pv1+4xAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks], bins=1024)\n",
    "plt.xlabel('self_rank')\n",
    "plt.ylabel('count')\n",
    "plt.xlim([-1, 50])\n",
    "plt.ylim([0, 130])\n",
    "plt.savefig('self_rank_cnn_256.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b9db57fb-5fe4-47ed-823c-609f5cb9ae79",
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_dir = '../examples/maml_l2l/cache/2023-0718-021041/'\n",
    "pkl_path = os.path.join(experiment_dir, 'df_ntest128_ttt_einv_nh256_expl_opa_nh2048_ov_maml_layerNone_tasks1024_mbs32_ways5_shots5_18000.pkl')\n",
    "with open(pkl_path, 'rb') as f:\n",
    "    df_train = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "afadcaa0-1c78-42ae-aca1-be35f613072f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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pEQZGRlBnMw+p0+f1ueff67k5ORgj2KNtLQ0JSUltbp+3G63ysvLuX78+Mc//qETJ06E/TVkjNH8+fO1adMmbdu2TWlpaa3uHz16tJxOZ6vrprKyUocPHw7r6+Zce/Fn//79khT214w/zc3N8ng83fN6CfandG3x6quvGpfLZdavX28+/vhjM2/ePBMfH2+qq6uDPVpQ/fCHPzTbt283VVVV5i9/+YvJzMw0/fv3N8eOHQv2aF3q1KlTZt++fWbfvn1Gklm9erXZt2+f+fvf/26MMWbFihUmPj7evPHGG+aDDz4wU6ZMMWlpaebLL78M8uSd72y7OXXqlPnRj35kysrKTFVVlfnzn/9srrnmGjN06FDT2NgY7NE71YMPPmji4uLM9u3bzdGjR32/GhoafOc88MADZtCgQWbbtm1m7969JiMjw2RkZARx6s53rr0cOnTI5OXlmb1795qqqirzxhtvmEsvvdTceOONQZ688y1atMiUlpaaqqoq88EHH5hFixYZh8Nhtm7daozpftcLgfJf1q5dawYNGmQiIyPN2LFjza5du4I9UtDdc889Jjk52URGRpqLL77Y3HPPPebQoUPBHqvLvfvuu0ZSm1+zZs0yxnz1rca5ubkmMTHRuFwuM378eFNZWRncobvI2XbT0NBgJk6caC666CLjdDrN4MGDzdy5c7tF+PvbiSSzbt063zlffvmleeihh0zfvn1NdHS0ufPOO83Ro0eDN3QXONdeDh8+bG688UaTkJBgXC6Xueyyy8yPf/xjU1dXF9zBu8D9999vBg8ebCIjI81FF11kxo8f74sTY7rf9eIwxpiue78GAADg3PgMCgAAsA6BAgAArEOgAAAA6xAoAADAOgQKAACwDoECAACsQ6AAAADrECgAAMA6BAoAALAOgQIAAKxDoAAAAOsQKAAAwDr/D03UPIYvg/1EAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_tasks=1024\n",
    "df_train['self_rank'] = df_train.apply(lambda row: row['train_task_idx'].index(row['orig_test_task_idx']), axis=1)\n",
    "df_train['self_rank'].hist(range=[0, num_tasks/32], bins=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19a20af6-0691-49cc-9823-82a2242a25f8",
   "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.9.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
