{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "sys.path.append('../..')\n",
    "from utils import *\n",
    "from model import *\n",
    "from data import *\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "path='./LLM/LLM_new/data_complexity_epoch_207_data_90w_warmup_normal_init_34_wrong_43_unseen_diff_ini'\n",
    "\n",
    "random_num_lst=[0,1,5]\n",
    "\n",
    "seed_lst=[4,5,6,7,9]\n",
    "\n",
    "L_lst=[2,3,4]\n",
    "\n",
    "index_all=np.zeros((len(random_num_lst),len(seed_lst),len(L_lst)))\n",
    "\n",
    "for random_num in random_num_lst:\n",
    "    for seed in seed_lst:\n",
    "        for L in L_lst:\n",
    "            path_new='./LLM/LLM_new/data_complexity_epoch_207_data_90w_warmup_normal_init_34_wrong_43_unseen_diff_ini/GPT_normal_init_diff_lr_5e-4_composition_task_34_unseen_43_unseen_random_num_%s_diff_ini_0.3_optim_multiplier_10/composition_random-N_100000-%sL1H_seed%s/loss/train_loss_his.npy'%(random_num,L,seed)\n",
    "            loss=np.load(path_new)\n",
    "            indices = np.where(loss < 5e-2)[0]\n",
    "            if len(indices)>0:\n",
    "                index_all[random_num_lst.index(random_num),seed_lst.index(seed),L_lst.index(L)]=indices[0]\n",
    "            else:\n",
    "                index_all[random_num_lst.index(random_num),seed_lst.index(seed),L_lst.index(L)]=100000\n",
    "\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "condense_step=np.mean(index_all, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "def format_settings(\n",
    "        wspace=0.25, \n",
    "        hspace=0.4, \n",
    "        left=0.12, \n",
    "        right=0.9, \n",
    "        bottom=0.15, \n",
    "        top=0.95,\n",
    "        fs=12,\n",
    "        dpi=300,\n",
    "        lw=1.5,\n",
    "        ms=5,\n",
    "        axlw=1.5,\n",
    "        major_tick_len=5,\n",
    "        ):\n",
    "    # 设置子图线宽\n",
    "    plt.rcParams['lines.linewidth'] = lw\n",
    "    \n",
    "    # 子图点大小\n",
    "    plt.rcParams['lines.markersize'] = ms\n",
    "    \n",
    "    # 子图间距与位置  w:左右 h:上下\n",
    "    plt.subplots_adjust(wspace=wspace, hspace=hspace, left=left, right=right, bottom=bottom, top=top)\n",
    "\n",
    "    # 字体大小\n",
    "    plt.rcParams['font.size'] = fs\n",
    "    plt.rcParams['axes.labelsize'] = fs\n",
    "    plt.rcParams['axes.titlesize'] = fs\n",
    "    plt.rcParams['xtick.labelsize'] =fs\n",
    "    plt.rcParams['ytick.labelsize'] = fs\n",
    "    plt.rcParams['legend.fontsize'] = fs\n",
    "    # 子图坐标轴宽度\n",
    "    plt.rcParams['axes.linewidth'] = axlw\n",
    "    # 子图坐标轴刻度宽度\n",
    "    plt.rcParams['xtick.major.width'] = axlw\n",
    "    plt.rcParams['ytick.major.width'] = axlw\n",
    "    # 子图坐标轴刻度长度\n",
    "    plt.rcParams['xtick.major.size'] = major_tick_len\n",
    "    plt.rcParams['ytick.major.size'] = major_tick_len\n",
    "    # 子图坐标轴刻度长度\n",
    "    plt.rcParams['xtick.minor.size'] = 0\n",
    "    plt.rcParams['ytick.minor.size'] = 0\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['xtick.major.pad'] = major_tick_len\n",
    "    plt.rcParams['ytick.major.pad'] = major_tick_len\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['xtick.minor.pad'] = 5\n",
    "    plt.rcParams['ytick.minor.pad'] = 5\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['xtick.direction'] = 'in'\n",
    "    plt.rcParams['ytick.direction'] = 'in'\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['xtick.top'] = False \n",
    "    plt.rcParams['ytick.right'] = False\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['xtick.minor.visible'] = False\n",
    "    plt.rcParams['ytick.minor.visible'] = False\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['legend.frameon'] = False\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['figure.dpi'] = dpi\n",
    "    # 子图坐标轴刻度标签位置\n",
    "    plt.rcParams['savefig.dpi'] = dpi\n",
    "\n",
    "\n",
    "\n",
    "def get_color_list(n_colors, cmap='viridis', color_min=0.5, color_max=1, invert=False):\n",
    "\n",
    "    colormap = plt.cm.get_cmap(cmap)\n",
    "    if invert:\n",
    "        color_list = [colormap(i) for i in np.linspace(color_max, color_min, n_colors)]\n",
    "    else:\n",
    "        color_list = [colormap(i) for i in np.linspace(color_min, color_max, n_colors)]\n",
    "    return color_list\n",
    "\n",
    "\n",
    "def get_color_groups(n_group, n_colors, cmap_list=None, color_min=0.5, color_max=1, invert=False):\n",
    "\n",
    "    if cmap_list is None:\n",
    "        cmap_list = ['Blues', 'Reds', 'Greens', 'Oranges', 'Greys', 'Purples', 'YlOrBr', 'PuBuGn', 'BuPu']\n",
    "        \n",
    "    color_groups = [get_color_list(n_colors, cmap=cmap_list[i], color_min=color_min, color_max=color_max, invert=invert) for i in range(n_group)]\n",
    "    \n",
    "    return color_groups"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABC4AAALxCAYAAACTl+dmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACLBUlEQVR4nOzdd3xUZcL+/+skhBASQgskQEgQQTrSS+gdAZGugtLEgrqu4rp+lVVZ133UVRFde6MoKggKqIj0XkKV3ktISEIJpJCeOb8/+OUskQCTnAkZhs/79ZoXM/c5932u5HHnwctTDNM0TQEAAAAAALghr+IOAAAAAAAAcDUUFwAAAAAAwG1RXAAAAAAAALdFcQEAAAAAANwWxQUAAAAAAHBbFBcAAAAAAMBtlSjuADeTxMRE7dq1y/rcqFEjlS1bthgTAQAAAADg2SguCmDXrl3q0KGD9XnNmjVq3759MSYCAAAAAMCzcakIAAAAAABwWxQXAAAAAADAbVFcAAAAAAAAt0VxAQAAAAAA3BbFBQAAAAAAcFsUFwAAAAAAwG1RXAAAAAAAALdFcQEAAAAAANwWxQUAAAAAAHBbFBcAAAAAAMBtUVwAAAAAAAC3RXEBAAAAAADcFsUFAAAAAABwWxQXAAAAAADAbVFcAAAAAAAAt0VxAQAAAAAA3BbFBQAAAAAAcFsUFwAAAAAAwG1RXAAAAAAAALdFcQEAAAAAANwWxQUAAAAAAHBbFBcAAAAAAMBtUVwAAAAAAAC3RXEBAAAAAADcFsUFAAAAAABwWxQXAAAAAADAbVFcAAAAAAAAt0VxAQAAAAAA3BbFBQAAAAAAcFsUFwAAAAAAwG2VKO4AAHA1kydP1uTJkws8b8KECZowYUIRJAIAAABwo1FcAHBbSUlJiomJKdQ8AAAAAJ6B4gKA2woMDFS1atWuGI+NjZXD4ZCXl5eqVKmS7zwAAAAAnoHiAoDbutolH6GhoYqJiVGVKlUUHR1dDMkAAAAA3CjcnBMAAAAAALgtigsAAAAAAOC2KC4AAAAAAIDborgAAAAAAABui+ICAAAAAAC4LYoLAAAAAADgtiguAAAAAACA26K4AAAAAAAAboviAgAAAAAAuC2KCwAAAAAA4LYoLgAAAAAAgNuiuAAAAAAAAG6L4gIAAAAAALgtigsAAAAAAOC2KC4AAAAAAIDb8ujiYsOGDXr88cfVrFkzVahQQT4+PgoMDFTt2rU1bNgwffvtt8rIyCjumAAAAAAA4CpKFHeAonDu3Dk99NBDmj9//hXbkpOTlZycrMOHD+uHH37Qyy+/rOnTp6tdu3bFkBQAAAAAAFyLxxUXaWlp6t69u3bs2GGNVapUSU2bNlVoaKjOnDmjPXv26OjRo5KkI0eOqGfPnlq+fLlat25dTKkBAAAAAEB+PK64ePPNN63SwjAM/etf/9KECRPk5+dn7WOapmbNmqXHHntMiYmJSk1N1cMPP6ydO3cWU2oAAAAAAJAfj7vHxbRp06z3Tz31lCZOnJintJAuFRr33XefvvjiC2ts165d2rVr142KCQAAAAAAnOBRxUVSUpJOnDhhfb7//vuvuf+AAQNUunRp6/PBgweLLBsAAAAAACg4jyouUlJS8nwuX778NfcvUaKEAgMDrc8Oh6NIcgEAAAAAgMLxqOKiUqVKKlWqlPV5z54919z/zJkzOn36tPX5zjvvLLJsAAAAAACg4DyquPDx8dFdd91lfX7ttdeUmpp61f2ff/556yyLbt266Y477ijyjAAAAAAAwHke91SR//u//9OSJUuUkpKibdu2qXHjxnrppZfUrl0763GoO3fu1BtvvKG1a9dKkurXr6+pU6cW+FgFfQpJWFiYwsLCCnwcAAAAAABuVYZpmmZxh3C1nTt36u6771ZUVNQ19ytXrpwefPBB/fvf/1aZMmWuu+7atWvVoUOHQud65ZVXNGnSpELPB3BJaGioYmJiVK1aNUVHRxd3HAAAAABFyOPOuJCkxo0b6+DBg/riiy/0/PPP6+LFi/nu16tXL91///1OlRaukJCQoOzsbM2dO9cau+OOO9S0aVMtWLBAaWlpkqQqVaqoY8eOWrlypeLj4yVJAQEB6tu3r7Zu3arDhw9b84cOHarDhw9r+/bt1ljv3r2VlpamVatWWWPt2rVT+fLl9csvv1hjjRo1Uv369fXDDz9Yl8zUqFFDrVu31qJFi5SYmChJqlixorp3765169ZZ/5JYsmRJDRw4ULt27dLevXutNe+55x7FxcVp06ZN1ljXrl3l5eWlpUuXWmMtW7ZU9erV9eOPP1pjderUUZMmTTR//nylp6dLkqpWraoOHTpo+fLlOnPmjCSpTJky6tOnjzZv3qyjR49a8++9914dOHBAO3bssMbuuusupaSkaM2aNdZY+/btFRgYqIULF1pjd955p+rWravZs2crt8u77bbb1KpVK/32229KSkqSJAUFBalbt25au3atYmJiJEm+vr4aMGCAdu7cqX379llrDhgwQKdOnVJkZKQ11q1bN0nSsmXLrLFWrVqpatWqmjdvnjVWr149NW7cWPPmzVNGRoYkqVq1amrfvr2WLVums2fPSpICAwN11113KTIyUseOHZN06XG/w4YN0/79+/XHH39Ya/bp00dJSUnWmUaS1KFDBwUEBOi3336zxpo0aaI6depo1qxZ1ljNmjXVsmVLLVy4UMnJyZIu3VOma9euWrNmjU6dOiVJKlWqlO655x7t2LFDBw4csOYPGjRIJ0+e1ObNm62x7t27y+FwaPny5dZY69atFRISovnz51tj9evXV6NGjfTTTz8pMzNTkqw/MzIyrJxly5ZV7969tWnTJh0/flyS5OXlpaFDh2rv3r15Hnfcr18/nT9/XuvWrbPGOnXqJD8/Py1atMgaa9q0qWrVqqUffvjBGqtVq5aaN2+uX3/91bohcHBwsDp37qzVq1crNjZWkuTn56f+/ftr+/bteZ5YNHjwYJ04cUJbtmyxxnr27KmsrCytWLHCGmvTpo0qV66sBQsWWGMNGjRQw4YN9eOPPyorK0vSpTO52rZtqyVLlighIUHSpRsT9+zZUxs3brSetFSiRAkNHjxYe/bs0e7du6017777bp07d07r16+3xjp37ixfX1/9/vvv1lizZs1Us2ZNzZkzxxqrXbu2mjVrpl9++cX6ng0JCVGnTp20atUqxcXFSZL8/f3Vr18/bdu2TYcOHbLmDxkyREePHtW2bdussV69eikjI0MrV660xiIiIlSxYkX9/PPP1ljDhg3VoEEDzZ07V9nZ2ZKk8PBwtWnTRosXL9b58+clSRUqVFCPHj20YcMGq8z28fHRoEGDtHv37jz3Qurfv79Onz6tjRs3WmNdunSRj4+PFi9ebI21aNFC4eHhfJeL73K+y+19l4eGhqpdu3ZaunSpzp07J4nvcr7L+S7nu5zv8lvxu9zf31/X45FnXJw9e1Z///vf9c033ygrK0shISGKiIhQUFCQLly4oE2bNuV5bOojjzyijz76SN7e3tdclzMuAPfAGRcAAADArcPjzrg4dOiQunbtqujoaPn6+uqDDz7Qo48+qhIl/vejmqap77//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6+DBg9Y+gwcP1okTJ7RlyxZrrGfPnsrKytKKFSussTZt2qhy5cpasGCBNdagQQM1bNhQP/74o/XEprCwMLVt21ZLlixRQkKCJKl8+fLq2bOnNm7cqBMnTkiSSpQoocGDB2vPnj3W96Mk3X333Tp37pzWr19vjXXu3Fm+vr76/fffrbFmzZqpZs2amjNnjjVWu3ZtNWvWTL/88osuXrwoSQoJCVGnTp20atUqxcXFSZL8/f3Vr18/bdu2TYcOHbLmDxkyREePHrWKZEnq1auXMjIytHLlSmssIiJCFStW1M8//2yNNWzYUA0aNNDcuXOtGzuHh4erTZs2Wrx4sc6fPy9JqlChgnr06KENGzYoKipKkuTj46NBgwZp9+7dVrktSf3799fp06e1ceNGa6xLly7y8fHR4sWLrbEWLVooPDz8hn+XS1K7du1Uvnx56xhpaWnau3ev6tevrx9++EEOh0OSVKNGDbVu3VqLFi1SYmKiJKlixYrq3r271q1bp+joaEmXHgk+cOBA7dq1S3v37rWOc8899yguLk6bNm2yxrp27SovLy8tXbrUGmvZsqWqV6+uH3/80RqrU6eOmjRpovnz5ys9PV2SVLVqVXXo0EHLly/XmTNnJEllypRRnz59tHnzZusR5tKlx5gfOHBAO3bssMbuuusupaSkaM2aNdZY+/btFRgYqIULF1pjd955p+rWravZs2dbv6PMzExJ0m+//WZdThoUFKRu3bpp7dq1iomJkST5+vpqwIAB2rlzp/bt22etOWDAAJ06dSrP2ZvdunWTJC1btswaa9WqlapWrZrnP+jUq1dPjRs31rx585SRkSFJqlatmtq3b69ly5bp7NmzkqTAwEDdddddioyMtC69NQxDw4YN0/79+/XHH39Ya/bp00dJSUlau3atNdahQwcFBATot99+s8aaNGmiOnXqWN9JklSzZk21bNlSCxcutH4/ubnWrFmjU6dOSZJKlSqle+65Rzt27NCBAwes+YMGDdLJkyfznOHavXt3ORwOLV++3Bpr3bq1QkJCNH/+fGusfv36atSokX766Sfr/yahoaFq166dli5dat3UvWzZsurdu7c2bdqk48ePS5K8vLw0dOhQ7d2717qfmiT169dP58+f17p166yxTp06yc/PT4sWLbLGmjZtqlq1aumHH36wxmrVqqXmzZvr119/VUpKiiQpODjY+o9Zuf9yxHe5a7/Li+s+eDcLR86l34/D4bC+m9yBu+XB9aWlpWn+/Pk3zXe5v7//dX8mw7T5DeLv76/09HSNHTtWn3/+uZ2lbBs3bpy+/PLLPGM//vijBg4cmO/+GzZsUPv27a2/6H311VcaM2bMVddfu3atOnToUOh8xXXGRWhoqGJiYhRctaLW7J16w4//Zx3qj1H8qXNuk6duhQFyOBwqGxykfy2bWdxx9FK3EUqMP+s2eSTpr43vkulwyLtMkKo9+01xx1HMOw8oJ/ms2+WpVq2a9S+EQFHK/V7nn7mr43d0bfx+UBz4O+m15f6d1PDyUmClCsUdR0lnEmS6UR5JSoy/VPi6298B3S2PJ3632z7jIjQ0VIcPH7Ya4+JUqlSpPJ/btm171dIid/ugQYOs1nnWrFnXLC7+7MMPP1Tjxo2d3p/7WwAAAAC4lsBKFdziP17l/sc0d8kj/e8/puHWY7u46Nixow4dOpTndI/iEhAQkOfztUqLy/fJLS4uP73OGY0bN1b79u0LNAcAAAAAADjPy+4Cjz32mLy8vLRjxw5t3brVFZkKrWLFink+169f/7pz6tWrZ71PTk5WcnKyy3MBAAAAAIDCsX3GRfPmzTVx4kT961//0vDhw7V69WoFBwe7IluB/fkRrH8+AyM/ZcqUyfM5OTn5ijEAAAAAN6evPpinqR/Nv2L8TNx5688O9a+8XHzM4/do7JMDijoeACfYLi4k6Z///Ke8vLz06quvqlGjRpo4caKGDBmiatWquWJ5pzVs2DDP59y7RF/Ln8+wKFu2rEszAQAAACg+Kcmpij917qrbHQ5HvttTklOLMhaAArBdXNSsWdN67+Pjo7Nnz2rChAmaMGGCypYtq7Jly8owjOuuYxiGjhw5YivLbbfdpttuu816lNjevXvVt2/fa865/JFnFSpUcOpRLAAAAABuDgFlSiu4asXr75jPPADuwXZxcfz48TzFRO570zR14cIF6/nx12KaplPlhjMGDRqkd955R5I0b948Pffcc9fc//LnrXfs2NElGQAAAAC4h7FPDuCSD+AmZ/vmnNKl4uHPr2ttu9q+rjB+/Hj5+PhIuvSUkAULFlx138jISP3444/W59GjR7s0CwAAAAAAsMf2GRe5l2W4i9tvv12PP/643nvvPUnS8OHDNWPGDA0aNCjPfqtWrdLQoUOVk5MjSWrTpo369+9/w/MCAAAAAICrs11chIeHuyKHS7355pvatm2b1qxZo4sXL2rw4MGqV6+eWrZsKW9vb+3cuTPPo1urVKmi2bNnu+xyFQAAAAAA4BoueaqIu/H19dXPP/+s8ePH67vvvpN06Sacl9+IM1fr1q31ww8/qHr16jc6JgAAAAAAuA6PLC6kS481/fbbb/XYY49pxowZWrt2rWJiYpSTk6Pg4GC1adNGw4YN04ABAzjTAgBwTS1atFBcXFxxx7DExsZaf4aGhhZzmktOnz6tnJwceXt7q3LlysUdx+1+R/x+nBcSEqItW7YUdwwAgBvx2OIiV8eOHXlaCADAlri4OMXExBR3jCs4HA63y+Vumchzbe6WBwCA/Hh8cQEAgKt4eXmpUkj54o6hM3Hn5XA43CaPJMWfOidJMry8FFipQjGnkZLOJMh0ONwmT2L82UtvDC95BxR/npyUBMl0uE0e6bJMAAD8iVPFRdeuXa33hmFo2bJl+W6z48/rAgDgbiqFlNeavVOLO4Y61B+j+FPn3CaPJNWtMEAOh0OBlSroX8tmFnccvdRthBLjz7pNnr82vkumwyHvgAqq9uw3xR1HMe88oJzks26TR/pfJgAA/syp4mLlypUyDEOmaV5xP4jcbXbkty4AAAAAAIDTl4qYplmobQAAAAAAAIXlVHGxYsWKQm0DAAAAAACww6niolOnToXaBgAAAAAAYIdXcQcAAAAAAAC4GooLAAAAAADgtiguAAAAAACA26K4AAAAAAAAbsvpx6E6KzExUWvXrtWOHTt09uxZJScny+FwXHeeYRj68ssvXR0HAAAAAADcxFxWXJw/f17PP/+8Zs6cqfT09EKtQXEBAAAAAAAu55Li4vjx4+rUqZOio6NlmuZ19zcM44r9DMNwRRQAAAAAAOBBbBcXpmlq4MCBOnnypCSpcePGGjFihBYvXqxly5bJMAx99dVXSk5O1okTJ7R69Wpt3rxZkhQQEKBXXnlFQUFBdmPADX31wTxN/Wj+FeNn4s5bf3aoP+aK7WMev0djnxxQ1PGK3fLpc7Vixo9XjCedSbD+fKnbiCu2dxk5SF1HDS7yfAAAAADgDmwXF3PmzNEff/whwzDUq1cvLViwQCVKlFBUVJSWLVsmSRo1alSeOVu3btUjjzyi7du367333tPixYtVt25du1HgZlKSUxV/6txVtzscjny3pySnFmUst5GekqrE+LNX3W46HPluT0+5NX4/AAAAACC5oLj46aefJF261OPjjz9WiRLXX7J58+Zau3atevToofXr12vYsGGKjIxUqVKl7MaBGwkoU1rBVSsWat6toFRAaZUNLvjZRqUCbo3fDwAAAABILiguIiMjZRiGmjVrpvDwcKfn+fn5adq0aapXr5727Nmjb7/9VmPHjrUbB25k7JMDbolLPgqr66jBXPIBAAAAANfhZXeBM2fOSJLq1auXd2Gv/y19taeM1KpVSxERETJNU99//73dKAAAAAAAwMPYLi5yS4mAgIA845d/TkhIuOr82rVrS5IOHDhgNwoAAAAAAPAwtouLwMBASVJqat4bBlas+L97Gxw+fPiq8xMTEyVJp0+fthsFAAAAAAB4GNvFxe233y5JiouLyzPeoEED6/3y5cvznetwOLRt2zZJUunS3HAQAAAAAADkZbu4aNKkiUzT1N69e/OMt2nTRr6+vpKkTz75JN8zKqZMmaJjx47JMAw1bNjQbhQAAAAAAOBhbBcXnTt3liRFR0fr6NGj1njZsmU1ePBgmaapM2fOqEWLFpo8ebKWLFmi+fPn66GHHtLf//53a//77rvPbhQAAAAAAOBhbD8OtU+fPipZsqSysrI0Z86cPGXEm2++qd9++00XLlxQTEyMnnvuuXzXaNasmcaNG2c3CgAAAAAA8DC2i4vAwEB99913On36tKpVq5ZnW7Vq1bR06VINHjxYx48fz3d+x44dNXv2bPn4+NiNAgAAAAAAPIzt4kKSBg4ceNVtTZs21f79+zV37lwtW7ZMp06dkpeXl2rWrKm7775bPXr0cEUEAAAAAADggVxSXFxPyZIldf/99+v++++/EYcDAAAAAAAewnZxsXPnTut9gwYN5O3tbXdJAAAApyyfPlcrZvx4xXjSmQTrz5e6jbhie5eRg9R11OAiz1fcktbPVfKGn64Yz0lJsP6MeeeBK7aXaTtQgRGe//sBANwcbBcXTZo0kWEYCg8Pz/NUEQAAgKKWnpKqxPizV91uOhz5bk9PSS3KWG7DkZGqnOSr/35kOvLd7si4NX4/AICbg+3iwsfHR9nZ2WrTpo0r8gAAADitVEBplQ0OKtS8W4GXb2l5lyn478fL99b4/QCAMzh7rfjZLi5CQkIUHR2tgIAAV+QBAABwWtdRg2+JSz4KKzBiMH9pBnBNXHJ3fZy9VvxsFxd169bVyZMndeLECVfkAQAAAADcIFxyd32cvVb8bBcXw4YN05IlS7R27VqdO3dOFStWdEUuAAAAAEAR45K76+PsteJnu7gYMWKE3n33Xe3bt09PPPGEvv/+e1fkAgAAAAAUMS65w83Ay+4CpUqV0pw5c1S9enX98MMP6tOnjw4ePOiKbAAAAAAA4BZn+4yLV199VZLUv39/ffLJJ/r9999Vr149NW7cWM2bN1elSpXk5+fn1Fovv/yy3TgAAAAAAMCD2C4uJk2aJMMw8oyZpqmdO3dq586dBVqL4gIAAAAAAFzOdnEhXSoqnBm7lj+XHwAAAAAAALaLi1deecUVOQAAAAAAAK5AcQEAAAAAANyW7aeKAAAAAAAAFBWKCwAAAAAA4LZsXyrStWtXSdLAgQP1l7/8pcDzP/nkE82ePVuGYWjZsmV24wDwIEnr5yp5w09XjOekJFh/xrzzwBXby7QdqMCIwUWeDwAAAEDRs11crFy5UoZhqGHDhoWaf+TIEWsNALicIyNVOclnr76D6ch3uyMjtQhTAQAAALiRXPI4VAAoCl6+peVdJqhQ8wAAAAB4hmIvLhwOhyTJ29u7mJMAcDeBEYO55AMAAAC4xRX7zTljY2MlSQEBAcWcBAAAAAAAuJtiLS6io6O1aNEiGYahmjVrFmcUAAAAAADghgp0qcjYsWOvum3ZsmXX3H65rKwsxcTEaNOmTUpLS5NhGOrSpUtBogAAAAAAgFtAgYqLadOm5fv0D9M0tX//fu3fv79QIcqUKVOoR6kCAAAAAADPVuBLRUzTzPO62rizr4iICC1btkxhYWEu/cEAAAAAAMDNr0BnXEydOjXPZ9M0NXbsWBmGoW7dumnEiBHXXcMwDJUqVUoVK1ZUw4YNFRwcXLDEAAAAAADgllGg4mLUqFFXjOXe16Ju3br5bgcAAAAAACisAhUX+Rk5cqQMw1CbNm1ckQcAAPz/vvpgnqZ+NP+K8TNx560/O9Qfc8X2MY/fo7FPDijqeAAAADeE7eJi2rRpLogBAAD+LCU5VfGnzl11u8PhyHd7SnJqUcYCAAC4oWwXFwAAoGgElCmt4KoVCzUPAADAU1BcAADgpsY+OYBLPgAAwC2vwI9DBQAAAAAAuFEoLgAAAAAAgNuiuAAAAAAAAG6L4gIAAAAAALgtigsAAAAAAOC2KC4AAAAAAIDborgAAAAAAABui+ICAAAAAAC4LYoLAAAAAADgtiguAAAAAACA2yry4uL06dOaNGmS2rZtq4oVK8rX11eVKlVSp06d9PbbbysxMbGoIwAAAAAAgJtUiaJc/JdfftHIkSOtcsI0TUnSuXPntHbtWq1du1bvvfeefvjhB7Vp06YoowAAAAAAgJtQkRUX27Zt05AhQ5SZmSlJqlWrlu644w75+/srOjpaW7duVWZmpmJiYnTXXXfpjz/+UFhYWFHFAQAAAAAAN6Eiu1TkpZdeUmZmpqpXr67Fixfr4MGD+uWXXzRr1iytW7dOx48f14gRIyRJSUlJ+r//+7+iigIAAAAAAG5SRVJcOBwOLVu2TIZhaNq0aerevfsV+4SEhGjGjBlq0KCBTNPUokWLiiIKAAAAAAC4iTldXDz55JNKSkpyat+EhATrEpH27dtfdT/DMBQRESFJiouLczYKAAAAAAC4RThdXHz00UeqW7euZs6ced19AwMDZRiGJOnYsWPX3PfIkSOSpLJlyzobBQAAAAAA3CKcLi7Kly+vuLg4jRw5Ul26dNG+ffuuum/JkiXVvHlzSZfO1EhJScl3v2nTpmn58uV5zrwAAAAAAADI5XRxcfDgQY0ePVqStHr1ajVp0kTPP/+8UlNT893/2WeflWmaWrZsmapXr67x48fr3Xff1aeffqqXXnpJzZo100MPPZRnfwAAAAAAgMs5/TjUihUr6quvvtK4ceP0+OOPa+fOnXr77bf1/fff691339WgQYPy7H/vvfdqy5Yteuedd5SYmKjPPvvsijVN05RhGHr77beveS8MAAAAAABwayrwU0UiIiK0bds2TZ48WWXKlNHJkyc1dOhQ9enTR0ePHs2z71tvvaUFCxaoffv2MgxDpmlaL29vb/Xs2VOrVq3SM88847IfCAAAAAAAeI5CPQ7Vy8tLTz/9tPbv3697771Xpmnq999/V8OGDfXPf/5TGRkZ1r79+vXT6tWrdeHCBW3fvl1r167VH3/8ocTERC1atIgzLQAAAAAAwFUVqrjIFRISou+++05LlixR7dq1lZ6erldffVUNGzbUokWL8uwbEBCgO++8UxEREWrUqJH8/PxsBQcAAAAAAJ7PVnGRq1u3btq1a5dee+01+fn56ciRI+rbt68GDx6skydPuuIQAAAAAADgFuSS4kKSfHx89OKLL2rv3r26++67ZZqm5s2bp/r16+s///mPsrOzXXUoAAAAAABwi3BZcZErLCxM8+fP14IFCxQeHq6LFy/qhRdeUJMmTbRq1SpXHw4AAAAAAHiwQhcX6enp2r17tzZs2KA9e/YoPT09z/Z+/fpp7969mjhxokqWLKm9e/eqa9euevDBBxUfH287OAAAAAAA8HwFLi7WrVun3r17q2zZsrrzzjvVvn17NW7cWGXLllWfPn20fv16a99SpUrpX//6l3bu3Knu3bvLNE19++23qlu3rj744AOZpunSHwYAAAAAAHiWAhUX7733njp37qwlS5YoKytLpmlar6ysLP3+++/q1KmT/vvf/+aZV7t2bS1evFjff/+9qlatqsTERP31r39VixYttGnTJpf+QAAAAAAAwHM4XVysW7dOEyZMUE5OjkzTVLt27fTyyy/r448/1qRJk9SpUyeZpqmcnBw988wzec68yDVs2DDt379fzzzzjLy9vbV9+3a1a9dOjzzyiBISElz6gwEAAAAAgJuf08XF22+/LdM0ZRiGvvnmG61Zs0aTJk3So48+qpdfflkrVqzQnDlzZBiGTNPU22+/ne86/v7+euedd7Rt2za1b99eDodDX375perWreuyHwoAAAAAAHgGp4uL9evXyzAMde/eXcOHD893n0GDBqlnz54yTVPr1q275noNGzbU6tWrNXXqVAUFBencuXMFSw4AAAAAADye08VFYmKiJKlGjRrX3C8sLCzP/tczatQoHThwQI899pizUQAAAAAAwC3C6eIiJCREkrR58+Zr7rdlyxZJUnBwsNMhypUrpw8//NDp/QEAAAAAwK3B6eKiR48eMk1Tf/zxh/76178qOTk5z/aLFy/queee0/bt22UYhnr27OnysAAAAAAA4NZSwtkd//GPf2j27NlKSUnRBx98oBkzZqh58+YKDg5WfHy8tm3bZl0eUrp0ab3wwgtFFhoAAAAAANwanC4uwsPD9fPPP2vYsGE6ffq0EhMTtWLFCmu7aZqSpKCgIH3//feqWbOm69MCAAAAAIBbitPFhSR17NhRe/fu1ccff6xff/1V+/fvV3JyssqUKaN69eqpT58+evTRRxUUFFRUeQEAAAAAwC2kQMWFJFWoUEETJ07UxIkTiyIPAAAAAACAxembcwIAAAAAANxoFBcAAAAAAMBtUVwAAAAAAAC3VeB7XPzZ8ePHtXz5cu3bt0/79+9XQkKCUlJSlJaWJj8/PwUEBKhChQqqW7eu6tWrp65du6pGjRouiA4AAAAAADxdoYoLh8Ohr776Sh9++KF27tzp1JyFCxda7xs1aqQnn3xSY8eOlZcXJ30AAAAAAID8Fbg12Lt3rxo0aKBHH31UO3fulGmaBX7t2rVLjz76qBo2bKh9+/YVxc8FAAAAAAA8QIHOuIiMjFSvXr2UlJQk0zSt8dq1a6tZs2YKCwtTSEiI/Pz85Ovrq4yMDKWlpSkuLk5RUVHatm2bDh06ZM3dv3+/IiIitHjxYrVs2dK1PxkAAAAAALjpOV1cXLx4UcOHD1diYqIkqXz58nr22Wc1evRoVa1a1ekDxsbGatq0aXrnnXeUkJCgxMREjRgxQjt27FDp0qUL/hMAAAAAAACP5fSlIt98842OHj0qwzDUpEkT7dmzRy+++GKBSgtJqlKlil544QXt3r1bTZo0kSQdOXJEX3/9dYHWAQAAAAAAns/p4mL27NmSpBIlSmjevHkKCQmxdeCQkBD99NNP8vHxkSTNmjXL1noAAAAAAMDzOF1cHDx4UIZhqGvXrgoLC3PJwcPDw9W1a1eZpqmDBw+6ZE0AAAAAAOA5nC4uzpw5I0mqXr26SwOEhoZKks6dO+fSdQEAAAAAwM3P6eKiUqVKkqTo6GiXBoiJiZEkVaxY0aXrAgAAAACAm5/TxUXt2rVlmqaWL1+ukydPuuTgUVFRWrZsmQzD0B133OGSNQEAAAAAgOdwurgYOnSoJCkrK0sDBgywLh0prDNnzmjQoEHKysqSJA0bNszWegAAAAAAwPM4XVyMHDlSNWrUkCTt2LFD9erV05tvvqm4uLgCHTA+Pl7/+c9/1KBBA23fvl2GYei2227TyJEjC7QOAAAAAADwfCWc3dHf318zZ85Ur169dPHiRSUkJOjFF1/Uiy++qDvuuEPNmjVTeHi4goOD5efnp5IlSyozM1NpaWmKj4/XiRMntH37dh04cECSZJqmJCkgIEAzZ85U6dKli+YnBAAAAAAANy2niwtJatu2rdasWaPBgwfr6NGjVvlw8OBBpx9nmjtHkm6//XbNnTtXjRs3LkgMAAAAAABwi3D6UpFcd955p/bv368PPvhA9evXl3SpjHD2JUn169fXBx98oH379lFaAAAAAACAqyrQGRfWpBIl9Pjjj+vxxx/XkSNHtHz5cu3bt08HDhzQuXPnlJKSovT0dJUqVUoBAQGqWLGi6tSpo3r16qlLly6qVauWq38OAAAAAADggQpVXFzu9ttv1+233+6KLAAAAAAAAHkU+FIRAAAAAACAG4XiAgAAAAAAuK1brriYMGGCDMOwXjVq1CjuSAAAAAAA4Cps3+NCko4ePap9+/Zp//79SkhIUEpKitLS0uTn56eAgABVqFBBdevWVb169VSzZk1XHLJQIiMj9d577xXb8QEAAAAAQMEUurg4cOCAPvnkE82bN09RUVFOzwsLC9OAAQP06KOPqm7duoU9fIFlZWVp3LhxcjgcN+yYAAAAAADAngJfKpKamqpx48apUaNGev/99xUVFSXTNJ1+RUVF6f3331fjxo318MMP6+LFi0Xxc13hzTff1K5duyRJw4cPvyHHBAAAAAAA9hTojIv4+Hj17t1bO3fulGmaebYFBwcrLCxMISEh8vPzk6+vrzIyMpSWlqa4uDhFRUUpPj7empedna2vvvpKW7du1W+//abg4GDX/VR/sn//fr322muSpBEjRqh79+769ttvi+x4AAAAAADANQpUXDz44IP6448/rM/du3fX6NGj1aVLF1WpUuW682NjY7Vq1SpNmzZNixcvliT98ccfGjlypH7//fcCRneOaZoaN26cMjIyVL58eU2ePFkLFy4skmMBAAAAAADXcvpSkXnz5mnp0qUyDEPly5fXwoULtXjxYg0fPtyp0kKSqlSpovvuu0+LFi3SokWLVKFCBZmmqaVLl2rBggWF/iGu5eOPP9a6deskSW+99ZYqV65cJMcBAAAAAACu53RxMXPmTOv93Llz1bt3b1sH7tmzp2bPnm19/vrrr22tl5+TJ0/q//2//ydJ6tChg8aOHevyYwAAAAAAgKLjdHGxfft2GYahli1bqnPnzi45eJcuXdS6dWuZpqlt27a5ZM3LPf7440pOTlbJkiX16aefyjAMlx8DAAAAAAAUHafvcXHq1ClJUsOGDV0aoH79+tq0aZNiY2Nduu7333+vX375RZL0/PPPq169ei5dX5J27txZoP3DwsIUFhbm8hwAAAAAAHgqp4uLgIAAZWRkKDEx0aUBkpKSrPVd5dy5c3rqqackSXfccYcmTpzosrUv98QTTxRo/1deeUWT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l4oAAAAAAAAUhwKdcZGfV155RZLUqlUr22EAAAAAAAAu57LiAgAAAAAAwNW4VAQAAAAAALgtigsAAAAAAOC2KC4AAAAAAIDborgAAAAAAABui+ICAAAAAAC4LYoLAAAAAADgtiguAAAAAACA26K4AAAAAAAAboviAgAAAAAAuC2KCwAAAAAA4LYoLgAAAAAAgNsqcSMPFhsbq99//13x8fGqXLmyevbsqWrVqt3ICAAAAAAA4CZiu7hITU3VG2+8IUm67bbbNGbMmHz3mzJlil544QVlZmZaY97e3nrhhRf0z3/+024MAAAAAADggWwXF7/++qtee+01GYah999/P9995s+frwkTJlwxnp2drddee00lS5bUxIkT7UYBAAAAAAAexvY9LlasWGG9HzJkSL77PP/885IkwzAUHBysQYMGqWXLlpIk0zT12muv6eTJk3ajAAAAAAAAD2O7uNi+fbskqU6dOgoODr5i+/r163Xw4EEZhqFGjRpp7969mjNnjjZt2qQXXnhBkpSZmakZM2bYjQIAAAAAADyM7eLixIkTMgxD9evXz3f7woULrfcvv/yyypcvb31+8cUXFRAQIElavny53SgAAAAAAMDD2C4uLly4IEmqWLFivttXr14tSfLz81Pfvn3zbPP391dERIRM09S+ffvsRgEAAAAAAB7GdnGRlZV1aSGvK5fKysrSli1bZBiG2rRpI19f3yv2qVKliqT/FSAAAAAAAAC5bBcXZcqUkSSdOXPmim2bNm1Senq6JKldu3b5zvfx8ZEkORwOu1EAAAAAAICHsV1c3HbbbTJNU5GRkVds+/nnn6337du3z3f+2bNnJUmBgYF2owAAAAAAAA9ju7iIiIiQJMXExOibb76xxs+cOaOpU6dKunR/i6sVF7t375ZhGKpRo4bdKAAAAAAAwMPYLi5GjRplvR87dqxGjhypZ599Vq1atdLZs2dlGIaGDh0qPz+/K+bGx8fryJEjkqRGjRrZjQIAAAAAADxMCbsLtGjRQg8//LA+//xz5eTkaObMmXm2BwQE6JVXXsl37k8//STTNGUYhnXmBgAAAAAAQC7bZ1xI0kcffaS//vWv8vb2lmma1qt69er6+eefr3oZyKeffmq979GjhyuiAAAAAAAAD2L7jAtJ8vb21rvvvquXXnpJGzZsUFJSkqpXr642bdqoRIn8D5GQkKABAwZowIABKlOmjMLCwlwRBQAAAAAAeBCXFBe5KlSooL59+zq979UuIQEAAAAAAJBcdKkIAAAAAABAUaC4AAAAAAAAboviAgAAAAAAuC2X3uMiKipKs2bNUmRkpI4fP66kpCRlZWU5NdcwDB05csSVcQAAAAAAwE3OJcVFRkaGJkyYoE8//VSmaRZ4vmmaMgzDFVEAAAAAAIAHcUlxMXDgQP3++++FKi0AAAAAAACuxnZxMXPmTC1atMg6Y6Jly5YaM2aMmjZtqooVK8rHx8d2SAAAAAAAcGuyXVzMmDHDev/cc8/pzTfftLskAAAAAACAJBc8VWTHjh0yDENhYWF6/fXXXZEJAAAAAABAkguKi8TERElShw4d5OXF01UBAAAAAIDr2G4agoODJUmlSpWyHQYAAAAAAOBytouLO++8U6Zp6siRI67IAwAAAAAAYLFdXIwZM0aStH79esXGxtoOBAAAAAAAkMt2cTFw4EDdfffdysjI0COPPCKHw+GKXAAAAAAAAPaLC0n6+uuv1a1bNy1cuFDdunXTH3/84YplAQAAAADALa6EMzuNHTv2uvuEhISoZMmSWr16tZo1a6aaNWuqUaNGKlu2rAzDuO58wzD05ZdfOhMHAAAAAADcIpwqLqZNm+ZU+ZDLNE0dPXpUR48eLVAYigsAAAAAAHA5p4oL6VIZURAF3b8gxQgAAAAAALg1OFVcTJ06tahzAAAAAAAAXMGp4mLUqFFFncOljh8/riVLlmjVqlXatWuXoqKilJKSojJlyig0NFRt27bV8OHD1alTp+KOCgAAAAAArsHpS0VuBtu3b9djjz2myMjIfLefP39e58+f165du/TZZ5+pc+fOmj59usLCwm5wUgAAAAAA4AyPKi4OHDhwRWlxxx13qGHDhgoKCtKFCxe0fv16RUdHS5JWrlyptm3bas2aNapZs2ZxRAYAAAAAANfgUcVFrlq1amncuHF64IEHVK1atTzbHA6Hpk2bpr/85S9KTU3VqVOnNGLECK1fv54bhAIAAAAA4GZcUly8+OKLSk9PV9WqVfW3v/3N6Xlvv/22Tp06pYCAAL366qu2c1SpUkVTp07Vgw8+KG9v73z38fLy0tixY1W+fHkNGjRIkrRx40YtXrxYvXr1sp0BAAAAAAC4jpfdBZYvX6433nhD7733nry8CracYRiaMmWK/v3vf2vdunV2o6hTp04aPXr0VUuLyw0cOFCtWrWyPv/666+2jw8AAAAAAFzLdnGxYMGCSwt5eemBBx4o0NwHHnjAKjt++uknu1EKrF27dtb748eP3/DjAwAAAACAa7NdXGzcuFGS1KBBA1WuXLlAc4ODg9WwYUNJ0oYNG+xGKbDL72mRk5Nzw48PAAAAAACuzXZxcfjwYRmGoQYNGhRqfv369WWapg4fPmw3SoHt2rXLel+9evUbfnwAAAAAAHBttm/OmZSUJEkKDAws1PyyZctKkhITE+1GKZCoqCgtX77c+ty9e/cCr7Fz584C7R8WFqawsLACHwcAAAAAgFuV7eIiICBAiYmJhS4ecuf5+vrajVIgEyZMsC4PCQsL0913313gNZ544okC7f/KK69o0qRJBT4OAAAAAAC3KtvFReXKlXXhwgVt3769UPNz5xX0/hh2TJ8+XXPnzrU+v/766zekOElISFB2dnaeY99xxx1q2rSpFixYoLS0NEmXHuvasWNHrVy5UvHx8ZIuFUR9+/bV1q1b81xWM3ToUB0+fDjP7793795KS0vTqlWrJMlaF0DRyszM1KxZsyRJfn5+6t+/v7Zv366DBw9a+wwePFgnTpzQli1brLGePXsqKytLK1assMbatGmjypUrWzdAli7dS6hhw4b68ccflZWVJelS8dq2bVstWbJECQkJkqTy5curZ8+e2rhxo06cOCFJKlGihAYPHqw9e/Zo9+7d1pp33323zp07p/Xr11tjnTt3lq+vr37//XdrrFmzZqpZs6bmzJljjdWuXVvNmjXTL7/8oosXL0qSQkJC1KlTJ61atUpxcXGSJH9/f/Xr10/btm3ToUOHrPlDhgzR0aNHtW3bNmusV69eysjI0MqVK62xiIgIVaxYUT///LM11rBhQzVo0EBz585Vdna2JCk8PFxt2rTR4sWLdf78eUlShQoV1KNHD23YsEFRUVGSJB8fHw0aNEi7d+/Wnj17rDX79++v06dPW/dukqQuXbrIx8eH71HgBtu0aZN143QvLy8NHTpUe/fuzXOZb79+/XT+/Pk8T6br1KmT/Pz8tGjRImusadOmqlWrln744QdrrFatWmrevLl+/fVXpaSkSLp077XOnTtr9erVio2NlcR3uau/y03TFICil5aWpvnz5+uee+7Rjh07dODAAWvboEGDdPLkSW3evNka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",
      "text/plain": [
       "<Figure size 1200x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(12, 8))\n",
    "format_settings(left=0.12, right=0.94, bottom=0.15, top=0.95, major_tick_len=10, fs=24, lw=6, ms=12.5, axlw=2.5)\n",
    "plt.rcParams['xtick.major.pad'] = 10\n",
    "plt.rcParams['ytick.major.pad'] = 5\n",
    "\n",
    "plt.rcParams['axes.spines.top'] = False\n",
    "plt.rcParams['axes.spines.right'] = False\n",
    "\n",
    "ax = plt.gca()\n",
    "\n",
    "labels = ['inferential complexity=0', 'inferential complexity=1', 'inferential complexity=5']\n",
    "color_list = [(218/255, 240/255, 178/255), (146/255, 212/255, 185/255), (30/255, 128/255, 184/255)]\n",
    "width = 0.15\n",
    "for i, data in enumerate(condense_step):\n",
    "    ax.bar(np.arange(len(data))*0.7-0.7*width+i*width, data, width=width, \n",
    "            label=labels[i], color=color_list[i], \n",
    "            edgecolor='black', linewidth=2, yerr=np.std(index_all, axis=1)[i,:], capsize=5, error_kw=dict(lw=2, capthick=2))\n",
    "\n",
    "ax.set_xticks([0.05,0.75,1.45])\n",
    "ax.set_xticklabels([2,3,4])\n",
    "ax.set_yticks([0,2,4,6,8])\n",
    "# ax.set_yticklabels(['20%', '40%', '60%', '80%', '100%'])\n",
    "ax.yaxis.grid(True, linestyle='--', linewidth=0.7, color='gray', alpha=0.7)\n",
    "ax.set_axisbelow(True)\n",
    "ax.set_xlabel('network depth', labelpad=10)\n",
    "ax.set_ylabel('epochs for 100% training acc')\n",
    "\n",
    "# ax.legend(loc=(0, 1.02), frameon=False, ncol=2)\n",
    "plt.savefig('./LLM/plot_for_neurips/pic/linear_step.png', dpi=300)\n",
    "# plt.savefig(f'{exp_dir}/compare_context.png', dpi=300)\n",
    "# print(f'saved at {exp_dir}/compare_context.png')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch_zzw",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
