{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1c94c6bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.10/site-packages/torch/cuda/__init__.py:52: FutureWarning: The pynvml package is deprecated. Please install nvidia-ml-py instead. If you did not install pynvml directly, please report this to the maintainers of the package that installed pynvml for you.\n",
      "  import pynvml  # type: ignore[import]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Embedding initialized with mean: 0.0, std: 0.004118575409116954\n"
     ]
    }
   ],
   "source": [
    "##################### model load #####################\n",
    "import torch, pickle\n",
    "import torch.nn as nn\n",
    "import sys, os, torch\n",
    "sys.path.append('./src')\n",
    "sys.path.append('..')\n",
    "from utils import *\n",
    "from model import *\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from model.GPT_onehot_for_binary import attn_mask\n",
    "# working_dir = '/mnt/h_public/cza/transformer_condensation/result/seed_experiment_LTP_prenorm_tanh_nh_1_nl_1_std_1.1_lr_5e-06/GPT_specific_test_for_resnet_seed1984_embedding_mean0_2025-09-28_16-23-47-similar-N_900000'\n",
    "# \n",
    "working_dir = '/mnt/h_public/cza/transformer_condensation/result/seed_experiment_LTP_prenorm_tanh_nh_1_nl_1_std_0.85_lr_1e-05/GPT_specific_test_for_resnet_seed1984_embedding_mean0.0_2025-10-01_16-31-29-similar-N_900000'\n",
    "device = torch.device('cuda:1' if torch.cuda.is_available() else 'cpu')\n",
    "args = load_args(f'{working_dir}/config.json')\n",
    "model = get_model(args, device)\n",
    "\n",
    "# grad_norm = f'{working_dir}/norms/grad_norms.npz'\n",
    "# grad_norm = np.load(grad_norm)\n",
    "# fig, ax = plt.subplots(1,1)\n",
    "# for key in grad_norm.files:\n",
    "#     ax.plot(grad_norm[key], label=key)\n",
    "# ax.set_yscale('log')\n",
    "# ax.legend() "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1a83c90a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LxxyjstX0mTrzhxxkp3fBI44ERG1NnYtR2DLxo0bsXz5cnz//feS0FRcXIxx48YhIyOj3hIEhw8fxp133okqmV3siZri3EXpMgHeXl6ICg91WhsMTkREBDgYnLZv3w5BEHDPPfdIjq1cuRLZ2dkAgL/+9a/48ssv8eijjwIATp8+jQ8++MCRpokA1Cx8mZaZLam3axsDtVrZieHw8oYmMtppbRARUfPnUHC6dOkSAKBfv36SY59++ikEQcD48ePx2muv4a677sKKFStw3333QRRFfP755440TQQAOH76vGy9U/t4p7YjF5y0UdEQnPjWHhERNX8OBaecnJpXwKOiourVi4qKcPjwYQDAzJkz6x2bNGkSAODYsWOONE2EUlMZdv8sv+luYoLz5tCJFjMq069K6ho+piMianUcCk5GoxEAYDab69V//vlnWCwWeHl5Yfjw4fWO1S6emZ8vv0UGkb12/PgLysorJPXoyDAEBvg5rZ3KrEyIMnPyOL+JiKj1cSg41U4IT09Pr1ffvXs3AKBXr17w9fWVvVan0znSNLVy6Zk5OHTslOyx24be7NS2bE8M55uhREStjUPBqWvXrgCATZs2WWtms9k6v+n60SYASEureXU8IiLCkaapldt74Ajktonu3LEdOsQ7d8Pd8ovnZOsccSIian0cmtl67733Ys+ePVi7di0iIiIwZMgQrF27FqmpqRAEAffff7/kmuTkmjkp1+93R9QYl6+mS2re3l4Yc+tgp7dlOisd2VL5+EITGSVzNhERtWQOjTg9/PDD6Ny5M0RRxPLly3HPPfdgw4YNAIC77rpL9m27TZs2QRAE3Hyzcx+nUOthKitHSalJUu/d7SYEBfg7tS1LZaXsiJO+400QVF5ObYuIiJo/h4KTVqvFjh07MH78eHh7e0MURajVakybNg1r166VnP/DDz/g1Kmaf72PHj3akaapFcvOlX+xwJkLXtYqv3QeYnW1pO5zU1ent0VERM2fw4vQREZGYsOGDaioqEB+fj5CQkKg0Whkz23Tpg127doFALjlllscbZpaqRwbwSksNNjpbZnOyU9A9+nUxeltERFR8+e01fu0Wq1kPafrtWvXDu3atXNWk9RKZecVyNbDFQhOFakpkprg7Q1dQkent0VERM2fQ4/qiNwhKydPUvM3+EKv0zq9rYpr0n3wNDFtoLIxqkpERC0bgxN5nByZESclHtOJ1dWoSE+T1LUxXIaAiKi1sutR3axZswAAgiDgvffek9Sb4vp7Edmj1FSGUlOZpK7EY7rKrAzALJ0YzvWbiIhaL7uCU1JSEgRBAIB6YaduvTFEUWRwoiax9UZdeGiQ09uyvWI4gxMRUWtlV3CKi4uTDUi26kRKsR2cFJgYflU6vwlgcCIias3sCk4pKSmNqhMpxVZwCgtxfnAqT70kqQlqDdTh3C6IiKi14uRw8ihywSnAzwCd1rlvuVmqqlB64pikro2N44rhREStGIMTeQxRFGWDU3iYAgtfnj4OsaJcUvft3tvpbRERkedwKDi1a9cO7du3x4ULF+y+5sqVK0hISED79u0daZpaoVJTGcrKKyT1cAUe05UcSZatG/r0d3pbRETkORxaOTw1NRWCIKCystLua6qqqpCSksJJ5dRo+YXFsvXQkECnt2U6fVxS8zL4Qd8h0eltERGR5+CjOvIYBTaCU3BggFPbEUWxZg2n6/h07cH5TURErZzLg1NRUREAwMfHx9VNk4crKJIPTkGB/k5tx1xcCLFC+khQExXj1HaIiMjzuDw4ffjhhwCAtm3burpp8nBywclLpYK/wdep7VRmZcnWNeGRTm2HiIg8T6PmON16662y9QceeAC+vg3/5VVRUYFLly4hOzsbgiDg9ttvb0zTRLKP6gL8/aBSOTf/V2VnytbVDE5ERK1eo4LT7t27IQgCRFG01kRRxMGDBxvVaEJCAv7+97836hoiuREnZz+mA4CqHBsjTmFc+JKIqLVrVHAaOnRovbfh9uzZA0EQ0Ldv3wZHnARBgE6nQ1RUFH73u99h0qRJNxyhIqqr2mxGcXGJpB4U4Of0tirlRpy8vOAdEuL0toiIyLM0esSprtpHJElJSejSpYvTOkV0vaLiEogy9SAnv1EHyI84qUPD+UYdERE5to7T9OnTIQgCgoKcvzM9UV15BYWy9WAFHtXJjThpuD8dERHBweCUlJTkpG4QNczW5r4hQc4dcbJUVqA6L1dSV3N+ExERgQtgkofIyS2Q1FSCgJDgQKe2U5l+DRClDwU1UbFObYeIiDyTQyNOcsxmMwoKClBWVlbv7Ts5cXFxzm6eWii5EafgoACovZ37R7ji2hXZujaWf1aJiMhJwSk3NxdvvPEGvvjiC5w6dQoWi+WG1wiCgOrqamc0Ty2cRRSRkycNTuGhzt/cl8GJiIga4nBw+vnnnzF+/Hjk5OTccISJqCmKioyorJKG7LAQBYLT1VRJTaX3gXcwlyIgIiIHg1NeXh7uuece5OXlwWAw4P/+7/8QGBiIxYsXQxAEvPvuu8jPz0dycjI2b96M8vJyDB48GLNnz3ZW/6kVyMzJk62Hhzr/bU65ESdtbFy99cuIiKj1cig4rVixAnl5edBqtdi3bx+6du2KkydPYvHixQBqtmKplZGRgT/+8Y/44YcfMGjQILz44osOdZxaj+OnzsnWnf2ozlJeLruGEx/TERFRLYfeqtu6dSsEQcCsWbPQtWvXBs+NiorCN998g/bt22P58uXYuXOnI01TK1FqKsPp85cldYOvD8JCnDviVHbpvGydwYmIiGo5FJwuXLgAALjtttustbqPNMxmc73z9Xo9HnvsMYiiiLffftuRpqmV2HvgKMwyLxv07tbJ6Zv7lp09JVvXtU90ajtEROS5HPqbp7i4ZtPVtm3bWms6nc76tdFolFzTr18/AMAvv/ziSNPUCuTmFWBf8jHZY317OH+LH9OZk5KaoNZA166D09siIiLP5FBwMhgMAFBvWYHg4N/mnaSkpEiuKS8vBwBkZ2c70jS1cKIo4pude2VHmzq0i0Owk1cMF81mlJ0/I6nr23eESq12altEROS5HApOHTrU/Ev8ypXf3kQKDAxEZGQkAGDXrl2Sa3766ScAgK+vryNNUwt37mIqLlyWvuGmEgSMHj7I6e2Vp16CpbxMUtd34ubVRET0G4eC08CBAwEABw8erFcfM2YMRFHESy+9hPPnf5twu3//frz88ssQBAH9+/d3pGlq4fYePCpbH9CnOyLCnL+mUsnRZNm6D4MTERHV4VBwGj16NERRxMaNG+vVH3/8cXh7eyM7Oxtdu3ZF//790aVLFwwZMgSFhYUAgLlz5zrSNLVgprJypF7LkNR9ffQYMViZwF1yRBqcBLUaPjd1U6Q9IiLyTA4Hp+nTp+Pmm2/G5cu/vTLerVs3/Pe//4WXlxeqq6tx6NAhnDlzxvqW3eLFizFmzBjHek4t1oXLV2RXof9d/17Q67ROb6+6qADlF6VrRfl06Q5VnZcdiIiIHFoAU61WIykpSfbY7NmzccsttyApKQknT55EdXU1OnbsiGnTplnfrCOSc+6idNsTAOjcIV6R9kpPyL+5Z+g9QJH2iIjIczl3a/nrdOrUCcuWLVOyCWphLKKICylXJfXgQH+EBAcq0mZFmrQ9ADD07KtIe0RE5Lmcu4IgkYNy8wpgKiuX1BPbt1Vsv7jKjDRJTdDqoA6PUKQ9IiLyXIoHp7y8POTn5yvdDLUQV2QmhQNAu7gYxdqszEyX1DRR0dzYl4iIJBQJTllZWXjooYcQGhqK8PBwhIWFISgoCDNnzqy35hPR9eTepgOAuJgoRdoTLRbZ4KSNVC6oERGR57I7OF27dg3R0dGIjo7Gf//7X5vnXbp0CX379sV7772H/Px8iKIIURRRVFSEtWvXonfv3jh69Kgz+k4tUGqaNDiFBgfC10evSHvVBfkQKyokdU1UtCLtERGRZ7M7OH377bfIzMxEfn4+7r//fpvnTZo0Cenp6dbXydu0aYOBAwfCz88PoiiioKAAkydPrrdNCxEAGEtKUVgk3d+wbaxyIUZutAkANFEccSIiIim7g9O+ffsAACNGjEBIiPzKzV999RWSk5MhCAKCg4Px7bffIjU1Ffv27UNmZiYeeOABAMC5c+fw+eefO6H71JKkZ+XI1uNiIhVrszJTOjEcADSRHHEiIiIpu4PT8ePHIQgCRo0aZfOcjz76yPr1v//9b9x+++3W3+v1erz77rvo3r07AODLL79sSn+pBUvPlA9O0ZFhirVZcVV+zh2DExERybE7OKWkpAAAevbsafOc3bt3AwACAgLwxz/+UXJcEATMmjULoiji2DH5RQep9crIypXU1N7eCA0JUqxN09lTkppXYBC8DH6KtUlERJ7L7uBUXFwMAAgNDZU9npKSgqysLAiCgKFDh0KtVsue17t3bwBAerr83BJqvdKzsiW1iPAQeKmUWTXDbCpFxZUUSd0nkRv7EhGRPLv/Rqpd06ayslL2+IEDB6xfN7SlSmBgIACgtLTU3qapFSgpNaHYKP0zER2h3GO6svNnANEiqfvcxOBERETy7A5OtRPCz52TboYKAD///LP16/79be9gbzTWvDWl4+apVIet9ZuUDE5yj+kAQN+JwYmInGfmzJkQBAEzZ85s1DFn3J+cz+7gVDu3Se5tOFEUsXnzZgCAt7c3Bg8ebPM+qak1G7hGRHA7C/qNrY19Y6OV+3NSevyopKbS66GLa6dYm0Rkm9lsxqefforp06cjMTERgYGB0Gg0CA8Pxy233IK///3vOHHihLu76TJJSUlYvHixdf5wS2MymbB161YsXboU48ePR9u2NVtrCYKAxYsXu7t7Ntm9ye/dd9+NrVu34ssvv8TatWsxbdo067Hly5cjJSUFgiDgtttug8FgsHmf2mUNOnXq5EC3qSUxWyw4cuKMpB7o74cwhSaGVxcVoPyidPRUn9gFgpeXIm0SkW379+/HjBkz6j3VUKvV8PPzQ15eHvbu3Yu9e/fihRdewPjx47Fu3TpoNBo39tg5oqKi0KlTJ0RFSXdHSEpKwp49ewAAw4cPb9I9mrMDBw7gjjvucHc3Gs3uEadp06ahTZs2AGqGBQcOHIgpU6agT58+eOqpp6znPf744zbvIYoivvjiCwiCgJtvvtmBblNLIYoi1m3aKntMyY19S44ekq0bett+zExEytiyZQuGDx+Oc+fOISQkBMuWLcO5c+dQWVmJvLw8VFZW4uDBg3jqqafg7++PjRs3wmQyubvbTrFs2TKcOXMGy5Ytc+s93CUoKAgjR47EggULsG7dOkRGKrdun7PYPeLk4+OD9evXY8yYMTAajUhOTkZycjIAWFcJnzVrFkaOHGnzHt988w3S0tKsI1NEh46dsvmYLrF9W8XaLTmSLFs39Lb9YgMROd/58+cxdepUVFRUoEuXLvjuu+8QGxtb7xwvLy/069cP/fr1w4IFCzBr1iw39ZacaciQIcjPz69XqzsQ01w16j3vQYMGITk5GRMmTIBOp7PuQ9e2bVssX74cK1eubPD65557DgAQGRnJESeCqawc3//4i+yxAH8D2sUpt+1J2bnTkpo2Ng6aMM69I3KlZ555BsXFxdDpdNi0aZMkNF0vODgYX3zxBQICAiTHdu/ejfvuuw8xMTHQarUIDQ3FyJEjsXr1apjNZtn7DR8+3DqnRhRFrFq1CgMHDoS/vz/8/PwwaNAgfPjhhzf8Pj766CMMHjwYfn5+CAgIwMCBA7Fy5UrrwIItchO7k5KSIAiC9THdkiVLrHN/an/Vrq1o6x7N6Wdji5eHTouwe8SpVseOHfHZZ5/BYrEgJycHGo0GQUH2zUPZsWNHTaPejW6WWqBfDh+HqaxcUlepVLhnzAioFfpzUlWQj+rCfEndp2sPRdqj1iVj1RuouCo/iurptG3aIurBvzjtfllZWdiwYQMAYMqUKUhMTLT72usf4z/++ON49dVXrccCAgJQWFiInTt3YufOnfjwww/xxRdfwM9PfnFbs9mMe++9F19++SW8vb3h4+MDo9GI/fv3Y//+/Th//jyWLFkiuU4URcyePRurV6+2th0YGIjk5GQcOHAAu3btglartfv7Amp22oiIiEB+fj6qqqrg6+srmTvcmNDhrp9NS9Xkv5lUKlWj34zz9fVtanPUAp06d1G2Pv6OW9Ehvo1i7ZanyLera9dBsTap9ai4moqyC2fd3Q2PsGvXLlgsNWup3XvvvU2+z4oVK6zB4KGHHsKSJUsQGRmJ0tJSrFq1CgsWLMDOnTvx4IMPYv369bL3ePPNN2GxWJCUlIT7778fer0e165dw6OPPootW7Zg6dKlmDp1Kjp27FjvujfeeMMamubMmYNFixYhNDQURUVFeO2117BkyRLZ0bGGTJw4ERMnTsTw4cOxZ88ezJ8/v8lvmbnzZ9NSKbMkM9ENFBYZkZUjHfVpH98GPbrY/6/Opii/zOBE1BycPHnS+nXtrhKNVVZWhkWLFgEAJk+ejHfeecc6wdjX1xfz5s3DK6+8AgD45JNPcOiQ/IshBQUF2LRpE2bMmAG9Xg8AiI2NxWeffYbo6GhYLBZ8+umn9a4pLy+3jrRMmzYNb7zxhnV3jYCAACxatAh/+9vfUFhY2KTvzVHu/Nm0ZAxO5BbnLsk/yuh+k/LhpfzyBUlNUGugjW54bgUROVdeXp716+Dg4CbdY/v27dYJxrZGZR599FHrq/off/yx7DmDBw/GiBEjJHWtVovRo0cDAH799dd6x7Zt22Zte+HChbL3feqpp9y24LM7fzYtGYMTuYWtN+k6Jij3Jh1QMx9BLjhp27bj+k1EHqj27e42bdrYnCPl5eWFW2+9td751xs4cKDNNqKjowFA8gZY3bY7dJD/R19AQAD69u3bwHegHHf+bFoyztIml7NYLLJbrMREhsPP4KNo25VpV1Gdnyep6+ITFG2XWg9tG2XDvzs5+3ur3coLqPmLt/Yv4cbIzq7ZHDwmpuG3cGvf1qs9/3q2JkYDv73QVFVV5VDbrubOn01LxuBELpeVk48Kmc2iE+KV/59LyZGDsnXfLt0Vb5taB2e+ddbSde3a1fr1kSNHmhSciFyNj+rI5a6kyW/o2zZW+e0CZIOTlxd8e/RRvG0iqm/EiBFQqWr+Gtq0aVOT7hEeHg4AuHbtWoPn1R6vPd8Zau+VlpbW4Hk3Oq4Ud/5sWjIGJ3K5lKvpkpoAoE20skvtm00mmGQWvvTp1BVePlwqg8jVIiIiMGHCBAA1E5Pr7lN3I7ULS/brV7Pa/7Vr12xebzabsWvXLgBA//7O21aptu2rV6/i4kX5t3WLi4ttvq12I7Wh8kaLaN6of+742bRkDE7kUsYSE85eSJHUI8JDoNc1bpG4xqq4mgL8b82Yugy93DNxk4iApUuXwmAwoKysDOPHj7/h6ExBQQEmTJiAoqIiAMCoUaOsc6VsvTn2zjvvID295h9skydPdlrfR40aZV0AunZnjOu99NJLKCsra9L9/f39AaDJyxm482fTkjE4kUt9/+N+VMss7x8Xo/xjuoprV2Tr+vbKrhtFRLYlJiZi7dq10Gg0OHnyJHr16oUXX3wRFy789var2WzGkSNHsHDhQiQkJGDjxo3WY3q93hoK1q1bh0ceeQRZWVkAAJPJhP/85z+YN28egJqFJZ35hpter8ezzz4LAPjggw8wb9486xILxcXFeO655/D8888jMDCwSffv1q0bgN/2eW1K/9z1s7FXQUEBcnNzrb9qF0Q1mUz16iUlJS7vmy0MTuQyxcYSHD0hv6Jyr26dFG/fVnDSxMYp3jYR2TZu3Djs3LkTHTp0QG5uLp566il07NgRWq0WISEh0Gg06NOnD5577jkUFRVh8uTJ9XaimDNnDh577DEANSMoUVFRCA4ORkBAAObOnYuqqiqMGDECq1atcnrf586di2nTpgEAXn/9dYSHhyM4OBjBwcFYuHAhJk6ciHvuuadJ954xYwZ0Oh0uXLiAuLg4REZGIj4+HvHx8Tect1TLnT8be/Tu3RthYWHWX1evXgUAvPzyy/Xqc+bMcUv/5DA4kcscPn5G9ll9984dERul/Oa6csHJKyAQ3n7+irdNRA0bPHgwzpw5g3Xr1mHKlCno0KEDdDodjEYjgoODccstt+Dpp5/G6dOn8fHHH0OtVte7/pVXXsHOnTsxYcIEREREoKSkBH5+fhgxYgTef/99bN++vcHX6ptKpVJhzZo1WLNmDW6++Wbo9XpUV1ejT58+ePvtt20uKmmPjh07YteuXbj77rsRFhaGvLw8pKamIjU1FdXV1Xbfx10/m5ZKEJs664ycKjY2FmlpaYiJibH7XxKeJCevAG+8t05SFwQBjz08FYH+yn9ozz06HebCgno1n6490PbpfyneNhERtQwccSLFVVZW4eONW2WPdUyIc0loqjYWS0ITAGhjW+5ihURE5HwMTqS4w8dPI6+gUPZYvx5dXNKHsjMnZetazm8iIqJGYHAiRR0/fR7f7PhJ9lh8m2gktnfNiE/h7u2ydV3bdi5pn4iIWgYGJ1LMpdRr+GyLfGDRajSYeM9o6wJvSqrKyUbJUekCdOrQcOgSOirePhERtRwMTqSYfcm/2jx25223wNdH75J+ZK9LAkTpwpcBw0dBcEFwIyKiloN/a5AiqqqqcSlV/u1AnVaDLp3au6QfZefPoHj/j9IDggqBw25zSR+IiKjlYHAih5nNZutqr7UuX01DlY11RkYNvRma69ZgUUrhDztl6wHDRkIdEuqSPhARUcvh7e4OkOcSRRF79h3CzwePoqq6Gt07d8Sdtw2FVqPGuYupsteMHDIA/Xt3c1n/So4clNRVeh+ET5zmkj4QEVHLwhEnarLkoyex86cDKK+ohNlswdETZ/HDvmSIoigbnHx99Bhys+v2Qqq4koLq/FxJ3W/gYHgHBLmsH0RE1HIwOFGTlJrKsP2HXyT1w8fPICsnD4XFRsmxjglxUAmCK7oHACg5ckC2bujd32V9ICKiloXBiZpkz75DKK+okNRLTWV4K+lT2Ws6tY9XuFf1mU6fkBa9vOHbradL+0FERC0HgxM1WmVVFY6eONOoa1QqFdrHxyrUIylRFFF++aKk7pN4E7z0Pi7rBxERtSwMTtRoB46cQHlFZaOuaRsbBZ1Wq1CPpKrzcmAukT4u1CV0cFkfiIio5WFwokZJuZqObbv3Nfq67je5NrDIjTYBgC7eNetHERFRy8TgRHYTRRGbvpFfF6kh7eNj0bv7TQr0yLYyW8GpHUeciIio6biOE9mtoKgYBUXFjbqmXVwMpt13l0vfpgOA8hRpcFLp9NBERru0H0RE1LJwxInsduLMhUad7+3thXvH3ury0AQAFdek60hp27bj3nREROQQ/i1Cdvl25158L7NuEwCMuXUw5KLR728bisAAP2U7JsNSWYHq3BxJXRvb1uV9ISKaOXMmBEHAzJkzG3XMGfcn5+OjOrKp1FSGy1fSkHI1HQeOyKyJ9D99e3SBwUePTd/shNliQWCAH8aMGIwuiQku7O1vKrMyZeuaKD6mI2rOzGYzPv/8c3z11VfYv38/srOzYTKZEBgYiMTERAwZMgRTpkxBt26u2bbJ3ZKSkpCSkoLhw4dj+PDh7u6O0+Xl5WHz5s3YsWMHDh8+jNTUVFRXVyMsLAz9+vXDjBkzcO+997q7mxIMTiQrr6AISZ98iaLikgbP8zP4QqtRo0eXRHRJbI+CoiKEBAVC5cZHYpUZabJ1zm8iar7279+PGTNm4Ny5c9aaWq2Gn58f8vLysHfvXuzduxcvvPACxo8fj3Xr1kGj0bixx84RFRWFTp06ISoqSnIsKSkJe/bsAYAGg1ND92jOIiMjUV1nM3idTge1Wo20tDSkpaXhyy+/xNixY7Fhwwb4+DSf9ff4qI4kLKKIDVu23zA0AUBIUID1a29vL4SFBLs1NAFAZaaN4BQV4+KeEJE9tmzZguHDh+PcuXMICQnBsmXLcO7cOVRWViIvLw+VlZU4ePAgnnrqKfj7+2Pjxo0wmUzu7rZTLFu2DGfOnMGyZcvceg93qK6uxoABA/DWW2/h4sWLKCsrQ0lJCS5fvozZs2cDALZu3YqHH37YzT2tjyNOJHH0xBmkZWbbdW7d4NRcVGakS4sqFTRhEa7vDBE16Pz585g6dSoqKirQpUsXfPfdd4iNrb/LgJeXF/r164d+/fphwYIFmDVrlpt6S860c+dOjBgxQlKPj4/Hu+++C29vb7zzzjv48MMP8fzzz6NNmzZu6KUUR5yoHlEU8dMvR+w+39e3+Qyf1pJ7VKcJj4TgzX8nEDU3zzzzDIqLi6HT6bBp0yZJaLpecHAwvvjiCwQESP/Rtnv3btx3332IiYmBVqtFaGgoRo4cidWrV8NsNsveb/jw4RAEAYsXL4Yoili1ahUGDhwIf39/+Pn5YdCgQfjwww9v+H189NFHGDx4MPz8/BAQEICBAwdi5cqVEEWxwevkJnYnJSVBEATrY7olS5ZAEIR6v1JSUhq8R3P62dgiF5rqqh11AoDk5OQmt+Ns/JuE6snLL0RufqHd58dFRyrXmSaqzJSOOKk5v4lc5MtvdyErN9/d3VBERGgw7hnT8F92jZGVlYUNGzYAAKZMmYLExES7rxWuW+bk8ccfx6uvvmo9FhAQgMLCQuzcuRM7d+7Ehx9+iC+++AJ+fvJv+prNZtx777348ssv4e3tDR8fHxiNRuzfvx/79+/H+fPnsWTJEsl1oihi9uzZWL16tbXtwMBAJCcn48CBA9i1axe0jdxuSq/XIyIiAvn5+aiqqoKvry8MBkO9c7y8vOy+n7t+No7S6XT1+tBcMDiRlcViwUcbv7H7fH8/X5du3GuP6uIimIuLJHUt36gjF8nKzce19Cx3d8Mj7Nq1CxaLBQAcentqxYoV1mDw0EMPYcmSJYiMjERpaSlWrVqFBQsWYOfOnXjwwQexfv162Xu8+eabsFgsSEpKwv333w+9Xo9r167h0UcfxZYtW7B06VJMnToVHTt2rHfdG2+8YQ1Nc+bMwaJFixAaGoqioiK89tprWLJkiezoWEMmTpyIiRMnYvjw4dizZw/mz5+PxYsXN/4HA/f+bBy1e/du69fdu3d36r0dwUd1ZLXpm53IK5CGjuv56HWIi43C9PvuatS/elyhIu2KbF0TE+finhDRjZw8edL6de/evZt0j7KyMixatAgAMHnyZLzzzjuIjKwZCff19cW8efPwyiuvAAA++eQTHDp0SPY+BQUF2LRpE2bMmAG9Xg8AiI2NxWeffYbo6GhYLBZ8+umn9a4pLy+3jrRMmzYNb7zxBkJDQwEAAQEBWLRoEf72t7+hsLCwSd+bo9z5s3FUYWGhdbL7kCFD0KlTJ6fe3xEMTgQAyC8swrFT52weDwkKxLBB/bBkwZ/w1F9m4f/+eC/CQ4Nd2EP7VFyTD05c/JKo+cnLy7N+HRzctP+fbN++Hfn5NY9GbY3KPProo9ZX9T/++GPZcwYPHiw750ar1WL06NEAgF9//bXesW3btlnbXrhwoex9n3rqqXqPnFzJnT8bR1gsFkybNg0ZGRnQ6XRYsWKF0+7tDAxOBAC4lm77LbpRwwZh7oN/xMghAyTzCpqbSpvBqXm8jUFEzlU7abhNmzY250h5eXnh1ltvrXf+9QYOHGizjejomkf9tSFEru0OHeQ3EA8ICEDfvn0b+A6U486fjSPmzp2Lr776CkDNY8IePXo47d7OwDlOBADIzrP9h75P95tc2BPHyI04eQeHwsvH1w29odYoohmOxDqLs7+3kJAQ69f5+fnWv4QbIzu75h99MTENr9NW+7Ze7fnXszUxGgC8//dGblVVlUNtu5o7fzZNNX/+fOsI06uvvtosl55gcCIAQI6Nt4D+/MBE+ProXdybppMLTtpYzm8i13HmW2ctXdeuXa1fHzlypEnBiVqOJ598Ev/+978BAMuXL8e8efPc2yEb+KiOAADZMsEpJiocEWEhMmc3T1V5OTAbiyV1bRsGJ6LmaMSIEdadBjZt2tSke4SHhwMArl271uB5tcdrz3eG2nulpcnvVlDrRseV4s6fTWMtWLAAL7/8MgDgpZdewhNPPOG2vtwIgxOhqqoa+YXSwNEcJ383pOSo/PN5bZt2Lu4JEdkjIiICEyZMAFAzMbnuPnU3UruwZL9+/QDU/OVv63qz2Yxdu3YBAPr37+9Il+upbfvq1au4ePGi7DnFxcU231a7kdpQeaNFNG/UP3f8bBpj/vz5WL58OYCa0LRgwQK39MNeDE6EjOxc2Q+mxwWnI/LBybd7Txf3hIjstXTpUhgMBpSVlWH8+PE3HJ0pKCjAhAkTUFRUs3TKqFGjrHOlbL059s477yA9vWZh3MmTJzut76NGjUJQUBAA4LnnnpM956WXXkJZWVmT7u/v7w8ATV7OwJ0/G3vNnz+/3uO55h6aAAYnApB87KRs3ZOCk6W8HKUnjkrquvj2UAd5zuNGotYmMTERa9euhUajwcmTJ9GrVy+8+OKLuHDhgvUcs9mMI0eOYOHChUhISMDGjRutx/R6vTUUrFu3Do888giysmoWIDWZTPjPf/5jnSszceJEp77hptfr8eyzzwIAPvjgA8ybN8+6xEJxcTGee+45PP/88wgMDGzS/bt16wYA+Oabb5r0uM+dPxt71J3T9MorrzTrx3N1MTi1cjl5+Th24qykLggCoiPC3NCjpsndtB5iZaWkbujdzw29IaLGGDduHHbu3IkOHTogNzcXTz31FDp27AitVouQkBBoNBr06dMHzz33HIqKijB58mT4+v72puycOXPw2GOPAagZQYmKikJwcDACAgIwd+5cVFVVYcSIEVi1apXT+z537lxMmzYNAPD6668jPDwcwcHBCA4OxsKFCzFx4kTcc889Tbr3jBkzoNPpcOHCBcTFxSEyMhLx8fGIj4+/4bylWu782TTkypUr1jlNKpUKL774IiIjI23+qn2U1xwwOLVyp89fhtzT866JCR7zNl3Bjm+Rt+Vz2WOGvrbXHyGi5mPw4ME4c+YM1q1bhylTpqBDhw7Q6XQwGo0IDg7GLbfcgqeffhqnT5/Gxx9/DLVaXe/6V155BTt37sSECRMQERGBkpIS+Pn5YcSIEXj//fexffv2Bl+rbyqVSoU1a9ZgzZo1uPnmm6HX61FdXY0+ffrg7bfftrmopD06duyIXbt24e6770ZYWBjy8vKQmpqK1NRUVFdX230fd/1sGlK71U7t11lZWQ3+KikpcWn/GiKITZ11Rk4VGxuLtLQ0xMTE2P0vCWf48ttdOPTraUn98YenITDAtR8ke5lLjMhaswrFv/wEsYG1Q3xu6oq4Z5c1+0U7iYjIc3j8iJPRaMTixYvRvXt3GAwGBAQEoH///vj3v/+NSplHN/ZYvHgxBEG44a+6z+A9lbHEJKn5G3ybbWgCgOxP1qLop10NhiYIKkTMeJihiYiInMqjF8BMTU3F8OHDkZKSAgDw8fFBRUUFkpOTkZycjI8++gg7duywvvXQWGq1usH9k2pXTPVkxpJSSc3Pr3musi1WV6Mi7SoKd2y94bmh4ydB15bLEBARkXN57IhTdXU17rrrLqSkpCAqKgrbt29HaWkpTCYT1q9fDz8/Pxw5cgRTp05tchu/+93vkJmZafNXfHy8874hNzGWSkec/HybX3Aq+mkXzj30R1z++19veK42PgGh4ye5oFdERNTaeGxw+uCDD3D8+HEAwOeff47bbrsNQM1EvYkTJ+Kdd94BUPMa544dO9zWz+bMYrGg1CRdX8TP4OOG3thWmZWJ9Hf+A0u5fWuhhI2fzEd0RESkCI8OTkDNkv2DBg2SHJ80aRLatat5VLNmzRqX9s1TlJrKZBe+9DM0rxGnor27ALN9b5AI3t7w7cYFL4mISBkeGZxMJhP27t0LABg7dqzsOYIgYMyYMQCAbdu2uaxvSjOXGFF2/gyqCwscvpfcxHAA8PN1/4iTpbICpjMnYTxyELkb7H+d17d7b6h0nrGMAhEReR6PnN18+vRp6xoQtSuryqk9lpmZifz8/AYness5efIkunXrhkuXLkGlUiEmJgZDhw7Fo48+it69ezf9G2iAWFWJ6sICeAdKJ7QXfL8V2etWw1JWBkGtRsg99yF03EQIKhXKr6aiMuMaIAKCSgVtfAI0YRENtiU3MRwADG5+VGc6cxJpK5ajOj+3cRcKAuc2ERGRojwyONXuqwMAMTExNs+reyw9Pb3RwSk3Nxf5+fkIDAxEcXExzp07h3PnzuG9997DP/7xDyxdurTxnf+fiooKVFRUWH9f+8jMbDTi/KPT4du9FwJuGQEIArwMfjAm70fhzu9+O7+qCrkbPkb+N19CpdejOk8aMnTx7RE05i4IKhVUvgb4du4GY2U10lJS4V+Yi+ycfNm++bvpUV1ldibyt25GwXdbmnR94PBR0LdPdHKviIiIfuORwcloNFq/9vGxPTpS91jda26kY8eOeOmll3DPPfegXbt2UKvVqKysxO7du/GPf/wDhw4dwr/+9S8EBQU1eW+dZcuWYcmSJTaPlx4/itLjR294H4upFBaT/MhRecpFZLz9mvX3qTGJ2B+WAAsanjhtcOFbdaLFAtPJX5Gz4SOUnT/T5Pv43NQVEdP+z4k9IyIikvLIlcM//vhjTJkyBQBw/vx5dOjQQfa87du34/bbbwcA/Pzzz7KTyBurvLwcQ4cOxcGDB2EwGHDt2jUEBAQ0+j7Xjzh17twZ6enpiNDrsGvcbQ73s5YFQLYhBOVqLfa1vfGkaQHAX3rEQqXygjYmFj5detj1hpooiqhIvYSyC+cgmqsBQQVtbBx8OneTvd5cZoLxwM/IeOf1Rn9P2vgERPxxFryDgmEpKwNUAnTtOvBNOiIiUpxHjjjV3VPHZJKf4Hz9MWftw6PT6fD8889j1KhRKCkpwY4dOzB+/PhG30er1UKr1Vp/r8Rf+mZBhR0dBiLPN9Dua3SV5chZ89tmj4Jag+A77oE2Jg6+PXrD2/+3kGguM6Hk0C+ASgXT6ZOyC1P69uyLmDnz4eVrsNbKr6QgdfGTdi8vUJc6LAIxjz4ObWzbRl9LRETkKI8MTtHR0dav09LS0KNHD9nz0tLSZK9xVN2Rq0uXLjntvs52MqJ9o0ITAISV1n9bT6yqRN6XnwEAvPwDEDphMixlZSg7ewolRw7e8H6lxw7h8tOPIXjs3bCYTBDUamR/vNru/qj0PoiZ9xQEQQWVjy90cW0heKtvfCEREZECPDI4de7cGSqVChaLBSdOnLC5JMGJEycAAJGRkY2eGO42Nxh58goMAqqrYS6RztnyDg2DoWc/GA/sRZXRiIshbRrdfLt82xsMm4uLkLX67Ubfsyo7E1kfrGz0dYJWi3Yv/OeGbwcSERG5ikcGJx8fHwwePBg//vgjvv32WyxYsEByjiiK+O67mrfQauc5Ocv+/futX9cusuks3kHBSHhpBSxVVTVvzm36BKUnjgHmavj26IOo//szVD4GpP3nRZQePwKVVgefbj0RPmkGNFExEAQBkTMfxo7tu1H+69lGte1TWYZIYyOXAFCIV2AQYuf9g6GJiIiaFY8MTgAwY8YM/Pjjj9i1axd++eUXDBw4sN7xzz77zPoYbfr06XbfVxTFBucbVVRU4OmnnwYA+Pr6YuTIkU3ofcPqzt+J+9timE0miOZqePv5/1Z/agksFeWAKEoWfDx3+Sp+aGRoAoAuWZfcviKqT9ceiJr1Z6gjozjZm4iImh13/z3ZZDNmzED37t0hiiImTJhg3Y/OYrHgs88+w4MPPgigZmXx68PN4sWLIQgCBEFASkpKvWM//PADbrvtNqxduxbXrv322Kqqqgo7duzAkCFD8MsvvwAAFi5ciMDAQOW+yf/x8vGpF5pqqbQ62VWyd/z0i133VXt7Q6tRQ6tRY1C3RIx++hm0f3UV2i58AfoOnRzosDe8Q0IbfVnk/81B26f/BU1UNEMTERE1Sx474uTt7Y3NmzdjxIgRSElJwW233QYfHx9YLBaUl5cDAHr37o2PPvqoUfcVRRE7duywBjG9Xg9fX18UFRWhqqoKQM1Gwk899RSefPJJ535TTlBeUYHM7Dy7zn1o2gSEhQbDYrbA29vLWtdERCL+n8thKS9DydFkpP3nJbvuJ6jV8O3ZF9GPPAaxugqXnvwzzMVFdl0b+ocpCLp1tF3nEhERuYvHBicAiI+Px6+//orly5dj48aNuHz5MtRqNbp27YrJkyfjL3/5CzQaTaPu2b17dyxfvhz79u3D8ePHkZubi8LCQvj4+KBLly4YMmQIHnroIXTv3l2h78oxGVn2zVGKiQpHeGgwBEGAqk5oqkul08P/5iEQvLyR/elaVKZdBVQq6BM6InzKLGhj4qDy9QVEseaNOa0WKvVvb7xFTH8Q6SuWN9iPoNF3IWLabAgq+T4QERE1Jx65AGZLFBsbi7S0NMTExNR7RAgARcVG7D14DLn5hQBEqAQVoiPDMKhfT+h12nrn7j14FN/t+lly/ztvG4LjZy4gOycfcTGRuHv0MPj7GSTnNcRSVQVBpYLgZX/IKdj5HfK/+QLmEqNk9Mk7NAwJy/5Tb40nIiKi5syjR5xag0upaVj/xbcor7PKOACcu5SKX0+dw5QJdyIs5LcNgTMycyT3UAkC+nTvjIF9HBslqzuaZK+gW0dbH8FVZmciZ/0amM6ehC4+AZEP/ImhiYiIPAqDUzOWkZWLDz//CtXVZtnj+YXF+HjjN/jj+Dvwy+HjKCwy4tylVMl5oSFBUKvd/59aEx6JmL82v3lhRERE9nL/36YkyyKK2Lxtt83QVCuvoAhvvLeuwXOiI8Oc2TUiIqJWi8GpmSkpNeH1VR8jr6DQafeMjeIikkRERM7gses4tVQWi+jU0KRRq9G1U3un3Y+IiKg1Y3DyIEEB/hg2qF+jrhn+u37w9ZEukklERESNx+DkIQRBwF2jh6HbTfaPHoUGB+Lmfj0U7BUREVHrwjlOHkDt7Y3xd45Eh/g2EEURgQF+KCwy3vC6sSNvgXcj1lwiIiKihjE4NTPe3l7omBBn/X1QgD9u7tMdof9bq0kQBAzq2wNbd+5t8D4DendDx3ZxDZ5DREREjcPg1Mz46HWY9offN3jOgN7dkHzsFHLyCiTH+vfqijYxkejZJVGpLhIREbVaDE4eyMvLCxPuHIkPPt2CsvKaFcV1Wg0emXEfggMD3Nw7IiKilovByUNFR4bjoakTcPr8ZZgtZvTs2gmB/n7u7hYREVGLxuDkwUKCA3HLwN7u7gYREVGrweUIiIiIiOzE4ERERERkJwYnIiIiIjsxOBERERHZicGJiIiIyE6CKIqiuztBgEajQVVVFVQqFaKiotzdHSIiomYnMjISycnJbu0DlyNoJsxmMwDAYrEgLS3Nzb0hIiIiOQxOzYRWq0VZWRnUajXCw8Pd3R2iVk8URaSnpyM6OhqCILi7O0StWu3nMSwszN1d4aO65qK4uBgBAQEoKiqCv7+/u7tD1OrxM0nUfDSnzyMnhxMRERHZicGJiIiIyE4MTs2EVqvFokWLoNVq3d0VIgI/k0TNSXP6PHKOExEREZGdOOJEREREZCcGJyIiIiI7MTgRERER2YnBiYiIiMhODE5EREREdmJwIiIiIrITgxMRERGRnRiciIiIiOzE4ERERERkJwYnIiIiIjsxOBERERHZicHJzYxGIxYvXozu3bvDYDAgICAA/fv3x7///W9UVla6u3tEHiMvLw+rV6/G1KlT0aVLF/j6+kKr1SI2Nhbjxo3Dpk2bbngPRz+PWVlZeOKJJ9CpUyfo9XoEBwdjyJAhePfdd8FtQYmAF154AYIgWH81pNl+HkVym5SUFDE+Pl4EIAIQfXx8RK1Wa/197969xfz8fHd3k8gjeHt7Wz87AESdTif6+vrWq40dO1YsLS2Vvd7Rz2NycrIYEhJiPd9gMNTr0+jRo8WKigqlvn2iZu/MmTOiTqer95m0pTl/Hhmc3KSqqkrs3r27CECMiooSt2/fLoqiKJrNZnH9+vWin5+fCEC844473NxTIs8AQBwwYID41ltviRcvXrTWL1++LM6ePdv6P8ypU6dKrnX081hYWChGRkaKAMSbbrpJPHjwoCiKolhRUSGuWLFCVKvVIgDxT3/6kwLfOVHzZzabxd/97nciAHHQoEENBqfm/nlkcHKTd9991/oH5+eff5Yc//jjj63Hv//+ezf0kMiz7Ny5s8HjDz/8sPUzdeXKlXrHHP08PvPMMyIAUa/Xi5cuXZIcf/7550UAopeXl3j27NlGfmdEnu+1114TAYhTpkwRFy1a1GBwau6fRwYnNxkyZIgIQBwxYoTscYvFIrZr104EIE6fPt3FvSNqeQ4cOGD9n+3GjRvrHXP08xgXFycCEB944AHZ641Go2gwGEQA4sKFCx3/Zog8yKVLl0RfX18xJCREzM7OvmFwau6fR04OdwOTyYS9e/cCAMaOHSt7jiAIGDNmDABg27ZtLusbUUul0+msX5vNZuvXjn4ez549iytXrjR4vcFgwJAhQ2SvJ2rpHnzwQZSWluKVV15BWFhYg+d6wueRwckNTp8+DYvFAgDo1q2bzfNqj2VmZiI/P98lfSNqqXbv3m39unv37tavHf08njhxQnJOQ9efOnWqcR0n8mCrVq3Cjh07cNttt2H69Ok3PN8TPo8MTm6Qnp5u/TomJsbmeXWP1b2GiBqnsLAQy5YtAwAMGTIEnTp1sh5z9PPY2OuLi4tRUlLSiN4Teaa0tDQsWLAAer0e77zzjl3XeMLnkcHJDYxGo/VrHx8fm+fVPVb3GiKyn8ViwbRp05CRkQGdTocVK1bUO+7o55GfZyJ5Dz/8MIqKirB48WIkJCTYdY0nfB4ZnIioRZs7dy6++uorAMCbb76JHj16uLlHRC3fhx9+iK+//hq9evXC448/7u7uOBWDkxv4+flZvzaZTDbPq3us7jVEZJ/58+dbR5heffVVzJo1S3KOo59Hfp6J6svKysK8efPg5eWFVatWwdvb2+5rPeHzyODkBtHR0dav09LSbJ5X91jda4joxp588kn8+9//BgAsX74c8+bNkz3P0c9jY6/39/eHwWBouPNEHuypp55CXl4eHnroIdx0000oKSmp96vudinX1zzh88jg5AadO3eGSlXzo6/7BsD1ao9FRkYiODjYJX0jagkWLFiAl19+GQDw0ksv4YknnrB5rqOfx7pv7thzfZcuXez4Dog81+XLlwEA//3vf+Hn5yf5VfuiBgBr7cknnwTgGZ9HBic38PHxweDBgwEA3377rew5oijiu+++AwDcfvvtLusbkaebP38+li9fDqAmNC1YsKDB8x39PCYmJiIuLq7B60tLS/Hjjz/KXk9Ev/GIz2Ojl8wkp6hdUl4QBHH//v2S45988gm3XCFqpCeeeML6uVm+fLnd1zn6eazd4sHHx0e8fPmy5PiLL77ILVeI/sfeLVea6+eRwclN6m5iGBMTY/2PbzabxU8//VT09/e37uZORDe2YMEC6/9MX3nllUZd6+jnse6mol26dBGTk5NFUazZVPStt94SNRoNN/kl+p8bBafm/nlkcHKjy5cvi/Hx8dY/QD4+PqJOp7P+vnfv3mJ+fr67u0nU7KWmplo/NyqVSoyIiGjw18svvyy5h6Ofx+TkZDEkJMR6vp+fn3UXdgDi7bffLpaXlyv5YyDyCDcKTqLYvD+PnOPkRvHx8fj111+xcOFCdOvWDYIgQK1Wo2/fvli+fDn279+PoKAgd3eTqNmr3aKh9uusrKwGf8mtFOzo57Fv3744efIkHnvsMXTs2BFVVVXw9fXFLbfcglWrVmHr1q3QarWKfP9ELU1z/jwKoiiKTf3GiIiIiFoTjjgRERER2YnBiYiIiMhODE5EREREdmJwIiIiIrITgxMRERGRnRiciIiIiOzE4ERERERkJwYnIiIiIjsxOBERERHZicGJiIiIyE4MTkRERER28nZ3B4iIGqO0tBRr167F5s2bcezYMeTl5UEURfj7+yM+Ph7du3fHoEGDMGbMGLRp08bd3SWiFoab/BKRx9i3bx8mTZqEK1eu3PDciIgIZGZm1qsNHz4ce/bswbBhw7B7926FeklELRlHnIjII5w7dw6jR4+G0WgEANx99934wx/+gMTERGg0GuTm5uLYsWPYvn07du3a5ebeElFLxeBERB7h6aeftoam1atXY+bMmZJzRo0ahfnz5yMnJweffvqpi3tIRK0BJ4cTUbNnNpvx9ddfAwD69esnG5rqCgsLw5///GcX9IyIWhsGJyJq9nJyclBWVgYA6NChQ6OvnzlzJgRBwJ49ewAAe/bsgSAI9X7Fx8fLXltUVIRly5Zh8ODBCAsLg0ajQVRUFO666y5s2LABDU0Trb334sWLAQDff/897r77bkRFRUGn0yEhIQFz5sxBWlpao78nInIPTg4nomYvPz8fISEhAICePXvi6NGjjbp+5syZ+OCDDxo8p23btkhJSalX27FjByZOnIi8vDyb191xxx345JNPYDAYJMcEQQAALFq0qF6Aul5AQAC2bNmCIUOGNPyNEJHbMTgRkUeIj49HamoqAOCFF17AggULoFLZN2ielpaGgoICPPDAA0hOTka/fv2wevXqeudoNBokJiZaf793716MGDECVVVViIiIwF/+8hf07NkT0dHRSE9PxyeffIIPP/wQADB+/Hh8/vnnknZrg1O/fv2QnJyMTp064cknn0SPHj1QVFSEzz77DKtWrYLFYoG/vz9OnDjBJRSImjuRiMgDLF++XARg/RUfHy/+9a9/FdevXy9eunTJrnsMGzZMBCAOGzaswfMqKyvF+Ph4EYA4ZswYsbS0VPa8lStXWvuzbds2yfG6/e3Tp49oNBol56xZs8Z6zn333WfX90FE7sM5TkTkER577DHMmjXL+vuUlBT85z//waRJk5CQkIDIyEhMmjQJW7ZsaXDekT3Wr1+PlJQU6HQ6rFmzBj4+PrLnPfjggxgwYAAAICkpqcF7rly5UvZx3rRp0zB27FgAwKZNmyRrTxFR88LgREQeQaVS4b333sO2bdswZswYeHvXX00lKysLn3zyCe6++24MGDAAFy9ebHJbmzdvBgAMGzYMYWFhDZ47dOhQADWLc9rSvXt39O3b1+bx2kBYXV3NhTmJmjmu40REHmXUqFEYNWoUiouLsXfvXhw8eBDJycn44YcfUFRUBABITk7GkCFDcOjQIURFRTW6jeTkZADAd999Z52ndCMNjRT179+/wWtrR60A4Pjx45g0aZJdbRKR63HEiYg8kr+/P8aOHYuFCxdi8+bNyMrKwvvvv4+goCAAQEZGBp599tkm3Ts7O7vR19QulyAnPDy8wWsjIiKsX+fn5ze6bSJyHY44EVGLoNVq8cADDyA6OhpjxowBAGzcuBErV660++27WmazGQAwduxYvPTSSw73zd5RKyJq/hiciKhFGT16NNq0aYOrV6+ioKAAeXl5N5yndL2QkBCkp6ejsrIS3bp1c7hPWVlZdh8PDg52uD0iUg4f1RFRixMdHW39uu5oj70jP7179wZQM9epsrLS4f4cPHjQ7uPOCGpEpBwGJyJqUUwmE06dOgWgZh5U7YrjAKDT6QAAFRUVDd7j7rvvBlCz3cr1C2U2xfHjx3HkyBGbx99//30AgJeXF4YPH+5we0SkHAYnImr2SkpKMHDgQHz11VewWCw2z7NYLPjLX/4Co9EIoCYA1R1lqn3D7tKlSw2u9TRjxgzrCt7z58/HDz/80GD/fvrpJ+s+eLY89NBDKC0tldQ//vhjfPPNNwCAcePGNektQCJyHW65QkTNXklJCfz8/AAAMTExGDduHAYNGoS2bdvCz88PhYWFOHLkCN5//30cP34cQM3+b0ePHq23ee+7776LBx98EAAwb948TJ06FQEBAQAAtVqNtm3bWs/dv38/hg8fjoqKCnh5eWHSpEkYN24c2rVrB4vFgoyMDBw6dAibNm3C8ePH8cYbb2DOnDn1+n39lis33XQT/va3v6F79+4oKirChg0b8M4778BiscDPzw+//vqrzc2Giah5YHAiomavvLwc7dq1s3tV7Y4dO2LdunWSRSdLSkrQs2dPXLp0SXKN3Ca/+/fvx/3334+rV6/esM0PPvgA06dPr1eru8kvACxZskT2Wn9/f2zevBnDhg27YTtE5F58q46Imj2dToe0tDTs378f33//Pfbv34+zZ88iKysL5eXl8PX1RXR0NHr27Il77rkHEyZMgEajkdzHYDDg559/xrJly7Bt2zakpqbCZDLZbPfmm2/G+fPnkZSUhC1btuDIkSPIzc2FSqVCWFgYOnfujGHDhmHChAno1KlTg9/D4sWLMWjQILzxxhtITk5GQUEBoqOjcccdd+Dvf/87YmNjHf45EZHyOOJERKSQuiNOixcvdm9niMgpODmciIiIyE4MTkRERER2YnAiIiIishODExEREZGdGJyIiIiI7MTlCIiIFMKXlolaHo44EREREdmJwYmIiIjITgxORERERHZicCIiIiKyE4MTERERkZ0YnIiIiIjsxOBEREREZCcGJyIiIiI7/T8WjM5rb7Ii7QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# --- 1. 数据加载和处理 ---\n",
    "# (这部分与您的代码相同)\n",
    "condense_cond_num1_array = np.load(f'{working_dir}/condense_num_step/condense_cond_num1_0.npz', allow_pickle=True) # type: ignore\n",
    "condense_cond_num2_array = np.load(f'{working_dir}/condense_num_step/condense_cond_num2_0.npz', allow_pickle=True) # pyright: ignore[reportUndefinedVariable]\n",
    "\n",
    "\n",
    "# 假设只绘制第0层\n",
    "layer_to_plot = 0\n",
    "condense_cond_num1 = condense_cond_num1_array[str(layer_to_plot)]\n",
    "condense_cond_num2 = condense_cond_num2_array[str(layer_to_plot)]\n",
    "\n",
    "# 归一化\n",
    "condense_cond_num1 = np.array(condense_cond_num1) / args.d_model\n",
    "condense_cond_num2 = np.array(condense_cond_num2) / args.d_model\n",
    "\n",
    "# --- 2. 绘图与美化 ---\n",
    "# 创建 Figure 和 Axes\n",
    "fig, axes = plt.subplots(1, 1, figsize=(6, 5))\n",
    "\n",
    "ax = axes  # 只使用第一个子图\n",
    "# 定义颜色和样式以保持一致性\n",
    "color1 = '#D6594C'  # 深灰蓝色 (Stage 1 颜色)\n",
    "color2 = '#7d8995'  # 浅灰蓝色 (Stage 2 颜色)\n",
    "\n",
    "# 绘制平滑后的曲线以获得更清晰的趋势\n",
    "# 使用 np.convolve 进行移动平均平滑\n",
    "window_size = 1\n",
    "smoothed_cond1 = np.convolve(condense_cond_num1, np.ones(window_size)/window_size, mode='valid')\n",
    "smoothed_cond2 = np.convolve(condense_cond_num2, np.ones(window_size)/window_size, mode='valid')\n",
    "# 平滑后 x 轴也需要对应调整\n",
    "steps = np.arange(len(smoothed_cond1))\n",
    "\n",
    "# 绘制线条\n",
    "# ax.plot(steps, smoothed_cond1, label=r'Condense Condition $\\mathcal{C}_1$', color=color1, linewidth=3)\n",
    "# ax.plot(steps, smoothed_cond2, label=r'Condense Condition $\\mathcal{C}_2$', color=color2, linewidth=3)\n",
    "\n",
    "ax.plot(steps, smoothed_cond1, label=r'Condition $1$', color=color1, linewidth=4)\n",
    "ax.plot(steps, smoothed_cond2, label=r'Condition $2$', color=color2, linewidth=4)\n",
    "# --- 3. 美化坐标轴和标题 ---\n",
    "# 设置标题和标签，并增大字号\n",
    "ax.set_xlabel('Step', fontsize=20)\n",
    "ax.set_ylabel('Satisfied Rate', fontsize=20)\n",
    "# ax.set_title('Evolution of Condense Conditions', fontsize=18, pad=15)\n",
    "\n",
    "# 设置坐标轴刻度标签的字号\n",
    "ax.tick_params(axis='both', which='major', labelsize=14, pad=8)\n",
    "\n",
    "# 使用对数坐标轴更好地观察动态\n",
    "# ax.set_xscale('log')\n",
    "\n",
    "# 设置Y轴范围，使其更美观\n",
    "ax.set_ylim(0.45, 1.05)\n",
    "ax.set_xlim(0, 400) # 对数坐标轴从1开始\n",
    "\n",
    "# --- 4. 美化边框和网格 ---\n",
    "# 隐藏顶部和右部的边框\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "# 加粗左部和底部的边框\n",
    "ax.spines['left'].set_linewidth(2)\n",
    "ax.spines['bottom'].set_linewidth(2)\n",
    "\n",
    "# 添加更柔和的网格\n",
    "# ax.grid(True, which='both', linestyle='--', alpha=0.4)\n",
    "\n",
    "# --- 5. 自定义图例 ---\n",
    "# 将图例放置在图表的右上角，并且不带边框\n",
    "# legend = ax.legend(frameon=False, fontsize=16)\n",
    "# 将图例的“右下角”(lower right) 精确地放在 (x=0.95, y=0.1) 的位置\n",
    "# (x=0.95 表示距离右边缘5%的地方，y=0.1 表示距离底边缘10%的地方)\n",
    "legend = ax.legend(\n",
    "    loc='upper right',\n",
    "    bbox_to_anchor=(1.05, 0.32),\n",
    "    frameon=False,\n",
    "    fontsize=18\n",
    ")\n",
    "\n",
    "# yticklabel 只有 0.5 和 1\n",
    "ax.set_yticks([0.5, 1.0])\n",
    "ax.set_yticklabels(['0.5', '1.0'], fontsize=18)\n",
    "ax.set_xticks([0, 200, 400 ])\n",
    "ax.set_xticklabels(['0', '200', '400'], fontsize=18)\n",
    "\n",
    "# 调整布局以防止标签被裁剪\n",
    "# fig.tight_layout()\n",
    "\n",
    "# 显示图片\n",
    "# plt.show()\n",
    "\n",
    "# 保存图片\n",
    "# 使用 plt.tight_layout() 可以帮助自动调整边距，但可能会与手动布局冲突\n",
    "# 如果布局看起来很好，可以不使用它\n",
    "plt.tight_layout(rect=[0, 0, 1, 0.95])\n",
    "plt.savefig(f'{working_dir}/condense_cond.pdf', dpi=300)\n",
    "# plt.savefig(f'{working_dir}/condense_condition.png', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a03ca253",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.10.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
