{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "sys.path.append(\"../../\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-07-14 20:01:58.276051: I tensorflow/core/util/port.cc:113] oneDNN custom operations are on. You may see slightly different numerical results due to floating-point round-off errors from different computation orders. To turn them off, set the environment variable `TF_ENABLE_ONEDNN_OPTS=0`.\n",
      "2024-07-14 20:01:58.363880: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 AVX512F AVX512_VNNI FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-07-14 20:01:59.668710: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Could not find TensorRT\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import gc\n",
    "import time\n",
    "from self_control.utils import get_suffix_grads_from_wrapped_model\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"6\"\n",
    "os.environ['CUDA_LAUNCH_BLOCKING'] = '1'\n",
    "from itertools import islice\n",
    "import torch\n",
    "from tqdm import tqdm\n",
    "import json\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from transformers import AutoModelForCausalLM, AutoTokenizer, pipeline\n",
    "from self_control.suffix_gradient import WrappedReadingVecModel\n",
    "import torch.nn.functional as F\n",
    "from peft import AdaptionPromptConfig, get_peft_model, LoraModel, LoraConfig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name_or_path = \"meta-llama/Llama-2-7b-chat-hf\"\n",
    "# model_name_or_path = \"mistralai/Mistral-7B-Instruct-v0.2\"\n",
    "model = AutoModelForCausalLM.from_pretrained(model_name_or_path, torch_dtype=torch.float16, device_map=\"cuda:6\")\n",
    "use_fast_tokenizer = \"LlamaForCausalLM\" not in model.config.architectures\n",
    "tokenizer = AutoTokenizer.from_pretrained(model_name_or_path, padding_side='left')\n",
    "tokenizer.pad_token_id = 0 if tokenizer.pad_token_id is None else tokenizer.pad_token_id\n",
    "tokenizer.bos_token_id = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "mistral_adapter_dict = {\n",
    "    \"surprised\": \"../adapters/calm2surprised-final-mistralprefix+adapter-50-0.003/adapter_model.safetensors\",\n",
    "    \"reasoning\": \"../adapters/reasoning-smallernorm-final-gogogoprefix+adapter-50-0.003/adapter_model.safetensors\"\n",
    "}\n",
    "llama_adapter_dict = {\n",
    "    \"afraid\": \"../adapters/afraid2fearless-finalprefix+adapter-50-0.003/adapter_model.safetensors\",\n",
    "    \"angry\": \"../adapters/angry2peaceful-finalprefix+adapter-50-0.003/adapter_model.safetensors\",\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1IAAAIjCAYAAAAJLyrXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABvPklEQVR4nO3de3zP9f//8fsbOzPHzSyzMSIiUmkqKgzJKVEhc4hySOjE59PBoRw6f5MOSiOHSiVJShtRORNJJOeV0xI2LNtsz98ffnt/vG3s/dreb9srt+vlsku9X+/X+/6+v997v2yPvV7v19thjDECAAAAALitRFEXAAAAAAC7YZACAAAAAIsYpAAAAADAIgYpAAAAALCIQQoAAAAALGKQAgAAAACLGKQAAAAAwCIGKQAAAACwiEEKAAAAACxikAKAS+Sbb75Rw4YN5e/vL4fDoePHj3vtvqZPny6Hw6G9e/d67T4upnfv3oqKiiqS+4Z0+PBh3X333apYsaIcDodee+21oq7kcaNHj5bD4dCRI0eKugqAyxSDFIBLLueXfH9/f+3fvz/X9bfeequuvvrqImjmPX///be6deumgIAATZkyRTNnzlRQUFC+t3vzzTflcDjUpEmTS9DSmgMHDmj06NHatGlTUVdx2rt3rxwOh/OrZMmSqlatmjp37lyselo1fvx4zZ8/3+31hw8frsWLF2vUqFGaOXOm2rRp471ykstzfv7XQw895NX7LqjevXurdOnSRV0DgI2VKuoCAC5f6enpmjhxoiZPnlzUVbxu3bp1OnHihMaNG6eWLVu6fbvZs2crKipKa9eu1c6dO1WzZk0vtrTmwIEDGjNmjKKiotSwYUOX6959911lZ2cXTTFJ9913n+644w5lZWVp27Zteuutt/T1119r9erVubrawfjx43X33XerU6dObq2/dOlSdezYUY899ph3i52jVatW6tWrV67lV1555SXrAACXEoMUgCLTsGFDvfvuuxo1apTCw8O9ch/GGJ0+fVoBAQFeyXdXcnKyJKlcuXJu32bPnj1auXKl5s2bpwcffFCzZ8/Ws88+66WGnuXj41Ok93/ttdeqZ8+ezss33XSTOnTooLfeekvvvPNOnrc5deqUW3sJ7SA5OdnSay0/p0+flq+vr0qUuPCBLFdeeaXLcw7Pcud7AODSYmsEUGT+85//KCsrSxMn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Y8xff/1lDh06ZJYtW2YaNWpkJJnPPvvMGPO/78fNN99szpw54/Lc+fr6mtjYWJOVleVc/sYbbxhJ5v3338/1PM2ZM8e57LfffjOSTIkSJczq1audyxcvXpzruXr22WeNJNOhQweXxzBo0CAjyfz888/OZUFBQSYuLu6ij/1ckszgwYNdluW8Vn744QfnshMnTpjq1aubqKgo5+PN2VZq1KiR52vmQvd3oa8PP/zQuV5eeRMmTDAOh8Ps27fPuaxZs2amTJkyLsuMObsd5Mh5/vr27euyTufOnU3FihXz7RwXF2eCgoIuuk5efVetWmUkmQ8++MC57J133jGSzLZt25zLMjIyTKVKlVy+b/369TNVqlQxR44cccm89957TdmyZZ33V5DvAYBLj0P7ABSpGjVq6P7779fUqVN18ODBPNdZtGiRJGnEiBEuyx999FFJynVoUvXq1dW6des8s3r16uWyR6FJkyYyxqhv374u6zVp0kR//PGHzpw5c8Hu69evV3JysgYNGiR/f3/n8nbt2qlOnTq5elkxe/ZsVa5cWbfddpuks4d33XPPPfroo49cDsVbtGiRbrzxRt1www3OZSEhIerRo0euzHP3Up04cUJHjhzRLbfcorS0NP32228u65YqVUoPPvig87Kvr68efPBBJScna8OGDZYfz6JFi1SyZEkNHTrUZfmjjz4qY4y+/vprl+UtW7Z02evSoEEDBQcHa/fu3W7d37PPPquQkBCFhYXp1ltv1a5duzRp0iTdddddLuv1799fJUuWdF5OTExURkaGhg0b5vJelP79+ys4ODjX97R06dK69957nZdr166tcuXK6aqrrnI502LO/+fVf/DgwS6XH374YUn/e917yqJFi3TDDTfo5ptvduk/YMAA7d27V1u3bnVZPy4uztJ7Czt27KiEhIRcXzmvYcn1NXjq1CkdOXJETZs2lTFGGzdulCT99ddf+v7779W3b19Vq1bN5T7OPUwxx/lnBbzlllv0999/e+QwuHP7ZmZm6u+//1bNmjVVrlw5/fTTT87runXrJn9/f5fDbxcvXqwjR4443zdmjNFnn32m9u3byxijI0eOOL9at26tlJQUl0zJ+vcAwKXFIAWgyD311FM6c+bMBd8rtW/fPpUoUSLXGevCwsJUrlw57du3z2V59erVL3hf5/9iVrZsWUlSREREruXZ2dlKSUm5YFbO/Z576GCOOnXq5OrlrqysLH300Ue67bbbtGfPHu3cuVM7d+5UkyZNdPjwYS1ZssSlQ61atXJl5NXp119/VefOnVW2bFkFBwcrJCTE+Uve+Y8zPDw814kXcs6+VpDPptq3b5/Cw8NzHdZ21VVXOa8/1/nfJ0kqX768jh075tb9DRgwQAkJCVqyZIk2bNig5ORkPfHEE7nWO/+1cqHvqa+vr2rUqJGrZ9WqVXP9cl+2bNk8X0+S8ux//vcvOjpaJUqU8PhngO3bty/P18WFvgcX247yUrVqVbVs2TLXV+XKlZ3rJCUlqXfv3qpQoYJKly6tkJAQNW/eXNL/XoM5w6a7H4Fw/mulfPnykvJ+rq36559/9Mwzzzjf11epUiWFhITo+PHjLttMuXLl1L59e82ZM8e5bPbs2briiiuc78/766+/dPz4cU2dOlUhISEuX3369JH0v5PS5LD6PQBwafEeKQBFrkaNGurZs6emTp2qkSNHXnC9vP4anZeL/QX33L0P7iw3550I4VJYunSpDh48qI8++kgfffRRrutnz56t2NhYS5nHjx9X8+bNFRwcrLFjxyo6Olr+/v766aef9OSTTxbpqcrzUtjvR61atdw6zXxh/9rvjdeTu69zb/P0npCsrCy1atVKR48e1ZNPPqk6deooKChI+/fvV+/evQv8GvTmtvvwww8rPj5ew4YNU0xMjMqWLSuHw6F77703V99evXrpk08+0cqVK1W/fn0tWLBAgwYNcu7ZzFm/Z8+ezpPPnK9BgwYul9kbBRRvDFIAioWnnnpKs2bNyvMN4pGRkcrOztaOHTucfz2Xzr5x+/jx44qMjLyUVV16SWdPbpHzV+cc27dvL3Cv2bNnKzQ0VFOmTMl13bx58/T555/r7bffVkBAgCIjI7Vjx45c623fvt3l8rJly/T3339r3rx5atasmXN5zlnsznfgwIFcpwP//fffJcl5Nj4rv/BHRkYqMTFRJ06ccNkrlXNIYVF9D8937ve0Ro0azuUZGRnas2ePpc8Ac9eOHTtc9jzs3LlT2dnZLmc99MRwFRkZmet1IV2678Evv/yi33//XTNmzHA5CUZCQoLLejnP+5YtW7zaxx2ffvqp4uLi9PLLLzuXnT59OtcZHCWpTZs2CgkJ0ezZs9WkSROlpaXp/vvvd14fEhKiMmXKKCsryyuvIwCXHof2ASgWoqOj1bNnT73zzjs6dOiQy3V33HGHJOm1115zWf7KK69IOvuepKJw3XXXKTQ0VG+//bbLqdK//vprbdu2rUC9/vnnH82bN0933nmn7r777lxfQ4YM0YkTJ7RgwQJJZ5+b1atXa+3atc6Mv/76K9ep0nP+an/uX+kzMjL05ptv5tnjzJkzLp+3lJGRoXfeeUchISFq3LixJDmHrLx+qTxfzofjvvHGGy7LX331VTkcDrVt2zbfjEuhZcuW8vX11euvv+7yXE2bNk0pKSleea2dPzDnfED1uc9JUFCQW8/zxdxxxx1au3atVq1a5Vx26tQpTZ06VVFRUapbt26h8vOT12vQGKP/+7//c1kvJCREzZo10/vvv6+kpCSX6y71HuKSJUvmus/Jkyfn+sgA6ez7CnPOcDl9+nTVr1/fZQ9TyZIl1aVLF3322Wd5Dol//fWX5x8AAK9ijxSAYuO///2vZs6cqe3bt6tevXrO5ddcc43i4uI0depU5yFqa9eu1YwZM9SpUyeXN7NfSj4+Ppo0aZL69Omj5s2b67777nOe/jwqKirXqZDdsWDBAp04cUIdOnTI8/obb7zR+Vfve+65R0888YRmzpypNm3a6JFHHnGe/jwyMlKbN2923q5p06YqX7684uLiNHToUDkcDs2cOfOCv5iGh4dr0qRJ2rt3r6688kp9/PHH2rRpk6ZOneo8WUd0dLTKlSunt99+W2XKlFFQUJCaNGmS5/s62rdvr9tuu03//e9/tXfvXl1zzTX69ttv9cUXX2jYsGFunQ7+UggJCdGoUaM0ZswYtWnTRh06dND27dv15ptv6vrrr/fKB87u2bNHHTp0UJs2bbRq1SrNmjVL3bt31zXXXONcp3HjxkpMTNQrr7yi8PBwVa9e3eVkFu4YOXKkPvzwQ7Vt21ZDhw5VhQoVNGPGDO3Zs0efffZZoT/o9ffff9esWbNyLa9cubJatWqlOnXqKDo6Wo899pj279+v4OBgffbZZ3m+l+n111/XzTffrGuvvVYDBgxQ9erVtXfvXn311VfatGlToXqeKzMzU88991yu5RUqVNCgQYN05513aubMmSpbtqzq1q2rVatWKTEx8YKn4O/Vq5def/11fffdd3nuXZ84caK+++47NWnSRP3791fdunV19OhR/fTTT0pMTNTRo0c99tgAXAKX/kSBAC53FzsVeFxcnJHkcvpzY4zJzMw0Y8aMMdWrVzc+Pj4mIiLCjBo1yuW03cacPf15u3btcuXmnE74k08+catLzqmV//rrr3wfz8cff2waNWpk/Pz8TIUKFUyPHj3Mn3/+6fZjPlf79u2Nv7+/OXXq1AXX6d27t/Hx8XGeQnnz5s2mefPmxt/f31xxxRVm3LhxZtq0ablOf75ixQpz4403moCAABMeHm6eeOIJ52m5v/vuO+d6OaefX79+vYmJiTH+/v4mMjLSvPHGG7m6fPHFF6Zu3bqmVKlSLqf3Pv/058acPdX28OHDTXh4uPHx8TG1atUyL774ossprY3J+9Tdxpz93uZ3CvCc05+/+OKLF10vv+/HG2+8YerUqWN8fHxM5cqVzcCBA82xY8dc1jn/NP3n9szrNXj+48p5jW3dutXcfffdpkyZMqZ8+fJmyJAhLqfTN+bsadWbNWtmAgICjKR8n4cLPYe7du0yd999tylXrpzx9/c3N9xwg1m4cKHLOhfaVvK7vwt9NW/e3Lne1q1bTcuWLU3p0qVNpUqVTP/+/Z2ntj//NPpbtmwxnTt3dnatXbu2efrpp53XX2gbzfnenvvaz0vOvzV5fUVHRxtjjDl27Jjp06ePqVSpkildurRp3bq1+e233y76WqxXr54pUaJErn8Dchw+fNgMHjzYREREGB8fHxMWFmZatGhhpk6d6lynIN8DAJeew5gieCc1AKDYuvXWW3XkyJFi8R6Vf7OcD/7966+/VKlSpaKuAw9p1KiRKlSo4HJ2TQD/TrxHCgAAwAPWr1+vTZs2uZxMA8C/F++RAgAAKIQtW7Zow4YNevnll1WlShXdc889RV0JwCXAHikAAIBC+PTTT9WnTx9lZmbqww8/lL+/f1FXAnAJ8B4pAAAAALCIPVIAAAAAYBGDFAAAAABYxMkmJGVnZ+vAgQMqU6aMHA5HUdcBAAAAUESMMTpx4oTCw8Mv+mHlDFKSDhw4oIiIiKKuAQAAAKCY+OOPP1S1atULXs8gJalMmTKSzj5ZwcHBRdolMzNT3377rWJjY+Xj42OLbDt2tmu2HTvbNduOnb2ZbcfOds22Y2e7Ztuxszez7djZrtl27GznbKtSU1MVERHhnBEuhEFKch7OFxwcXCwGqcDAQAUHB3vlBeqNbDt2tmu2HTvbNduOnb2ZbcfOds22Y2e7Ztuxszez7djZrtl27Gzn7ILK7y0/nGwCAAAAACxikAIAAAAAixikAAAAAMAiBikAAAAAsIhBCgAAAAAsYpACAAAAAIsYpAAAAADAIgYpAAAAALCIQQoAAAAALGKQAgAAAACLGKQAAAAAwCIGKQAAAACwiEEKAAAAACxikAIAAAAAixikAAAAAMCiIh2koqKi5HA4cn0NHjzYuc6qVat0++23KygoSMHBwWrWrJn++ecf5/VHjx5Vjx49FBwcrHLlyqlfv346efJkUTwcAAAAAJeJIh2k1q1bp4MHDzq/EhISJEldu3aVdHaIatOmjWJjY7V27VqtW7dOQ4YMUYkS/6vdo0cP/frrr0pISNDChQv1/fffa8CAAUXyeAAAAABcHkoV5Z2HhIS4XJ44caKio6PVvHlzSdLw4cM1dOhQjRw50rlO7dq1nf+/bds2ffPNN1q3bp2uu+46SdLkyZN1xx136KWXXlJ4ePgleBQAAAAALjdFOkidKyMjQ7NmzdKIESPkcDiUnJysNWvWqEePHmratKl27dqlOnXq6Pnnn9fNN98s6eweq3LlyjmHKElq2bKlSpQooTVr1qhz58553ld6errS09Odl1NTUyVJmZmZyszM9OKjzF/O/Xujh7ey7djZrtl27GzXbDt29ma2HTvbNduOne2abcfO3sy2Y2e7Ztuxs52zrXK3g8MYY7zcxS1z585V9+7dlZSUpPDwcK1evVoxMTGqUKGCXnrpJTVs2FAffPCB3nzzTW3ZskW1atXS+PHjNWPGDG3fvt0lKzQ0VGPGjNHAgQPzvK/Ro0drzJgxuZbPmTNHgYGBXnl8AAAAAIq/tLQ0de/eXSkpKQoODr7gesVmj9S0adPUtm1b5+F42dnZkqQHH3xQffr0kSQ1atRIS5Ys0fvvv68JEyYU+L5GjRqlESNGOC+npqYqIiJCsbGxF32yLoXMzEwlJCSoVatW8vHxsUW2HTvbNduOne2abcfO3sy2Y2e7Ztuxs12z7djZm9l27GzXbDt2tnO2VTlHq+WnWAxS+/btU2JioubNm+dcVqVKFUlS3bp1Xda96qqrlJSUJEkKCwtTcnKyy/VnzpzR0aNHFRYWdsH78/Pzk5+fX67lPj4+Rf6Ny+HNLt7KtmNnu2bbsbNds+3Y2ZvZduxs12w7drZrth07ezPbjp3tmm3HznbOttLBHcXic6Ti4+MVGhqqdu3aOZdFRUUpPDw812F7v//+uyIjIyVJMTExOn78uDZs2OC8funSpcrOzlaTJk0uTXkAAAAAl50i3yOVnZ2t+Ph4xcXFqVSp/9VxOBx6/PHH9eyzz+qaa65Rw4YNNWPGDP3222/69NNPJZ3dO9WmTRv1799fb7/9tjIzMzVkyBDde++9nLEPAAAAgNcU+SCVmJiopKQk9e3bN9d1w4YN0+nTpzV8+HAdPXpU11xzjRISEhQdHe1cZ/bs2RoyZIhatGihEiVKqEuXLnr99dcv5UMAAAAAcJkp8kEqNjZWFztx4MiRI10+R+p8FSpU0Jw5c7xRDQAAAADyVCzeIwUAAAAAdsIgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARUU6SEVFRcnhcOT6Gjx4sCTp1ltvzXXdQw895JKRlJSkdu3aKTAwUKGhoXr88cd15syZong4AAAAAC4TpYryztetW6esrCzn5S1btqhVq1bq2rWrc1n//v01duxY5+XAwEDn/2dlZaldu3YKCwvTypUrdfDgQfXq1Us+Pj4aP378pXkQAAAAAC47RTpIhYSEuFyeOHGioqOj1bx5c+eywMBAhYWF5Xn7b7/9Vlu3blViYqIqV66shg0baty4cXryySc1evRo+fr6erU/AAAAgMtTkQ5S58rIyNCsWbM0YsQIORwO5/LZs2dr1qxZCgsLU/v27fX0008790qtWrVK9evXV+XKlZ3rt27dWgMHDtSvv/6qRo0a5Xlf6enpSk9Pd15OTU2VJGVmZiozM9MbD89tOffvjR7eyrZjZ7tm27GzXbPt2Nmb2XbsbNdsO3a2a7YdO3sz246d7Zptx852zrbK3Q4OY4zxche3zJ07V927d1dSUpLCw8MlSVOnTlVkZKTCw8O1efNmPfnkk7rhhhs0b948SdKAAQO0b98+LV682JmTlpamoKAgLVq0SG3bts3zvkaPHq0xY8bkWj5nzhyXQwcBAAAAXF7S0tLUvXt3paSkKDg4+ILrFZs9UtOmTVPbtm2dQ5R0dlDKUb9+fVWpUkUtWrTQrl27FB0dXeD7GjVqlEaMGOG8nJqaqoiICMXGxl70yboUMjMzlZCQoFatWsnHx8cW2XbsbNdsO3a2a7YdO3sz246d7Zptx852zbZjZ29m27GzXbPt2NnO2VblHK2Wn2IxSO3bt0+JiYnOPU0X0qRJE0nSzp07FR0drbCwMK1du9ZlncOHD0vSBd9XJUl+fn7y8/PLtdzHx6fIv3E5vNnFW9l27GzXbDt2tmu2HTt7M9uOne2abcfOds22Y2dvZtuxs12z7djZztlWOrijWHyOVHx8vEJDQ9WuXbuLrrdp0yZJUpUqVSRJMTEx+uWXX5ScnOxcJyEhQcHBwapbt67X+gIAAAC4vBX5Hqns7GzFx8crLi5OpUr9r86uXbs0Z84c3XHHHapYsaI2b96s4cOHq1mzZmrQoIEkKTY2VnXr1tX999+vF154QYcOHdJTTz2lwYMH57nHCQAAAAA8ocgHqcTERCUlJalv374uy319fZWYmKjXXntNp06dUkREhLp06aKnnnrKuU7JkiW1cOFCDRw4UDExMQoKClJcXJzL504BAAAAgKcV+SAVGxurvE4cGBERoeXLl+d7+8jISC1atMgb1QAAAAAgT8XiPVIAAAAAYCcMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWMQgBQAAAAAWMUgBAAAAgEUMUgAAAABgEYMUAAAAAFjEIAUAAAAAFjFIAQAAAIBFDFIAAAAAYBGDFAAAAABYxCAFAAAAABYxSAEAAACARQxSAAAAAGARgxQAAAAAWFSkg1RUVJQcDkeur8GDB7usZ4xR27Zt5XA4NH/+fJfrkpKS1K5dOwUGBio0NFSPP/64zpw5cwkfBQAAAIDLTamivPN169YpKyvLeXnLli1q1aqVunbt6rLea6+9JofDkev2WVlZateuncLCwrRy5UodPHhQvXr1ko+Pj8aPH+/1/gAAAAAuT0W6RyokJERhYWHOr4ULFyo6OlrNmzd3rrNp0ya9/PLLev/993Pd/ttvv9XWrVs1a9YsNWzYUG3bttW4ceM0ZcoUZWRkXMqHAgAAAOAyUqR7pM6VkZGhWbNmacSIEc69T2lpaerevbumTJmisLCwXLdZtWqV6tevr8qVKzuXtW7dWgMHDtSvv/6qRo0a5Xlf6enpSk9Pd15OTU2VJGVmZiozM9OTD8uynPv3Rg9vZduxs12z7djZrtl27OzNbDt2tmu2HTvbNduOnb2ZbcfOds22Y2c7Z1vlbgeHMcZ4uYtb5s6dq+7duyspKUnh4eGSpAcffFBZWVl67733JEkOh0Off/65OnXqJEkaMGCA9u3bp8WLFztz0tLSFBQUpEWLFqlt27Z53tfo0aM1ZsyYXMvnzJmjwMBADz8yAAAAAHaRszMnJSVFwcHBF1yv2OyRmjZtmtq2bescohYsWKClS5dq48aNHr+vUaNGacSIEc7LqampioiIUGxs7EWfrEshMzNTCQkJatWqlXx8fGyRbcfOds22Y2e7Ztuxszez7djZrtl27GzXbDt29ma2HTvbNduOne2cbVXO0Wr5KRaD1L59+5SYmKh58+Y5ly1dulS7du1SuXLlXNbt0qWLbrnlFi1btkxhYWFau3aty/WHDx+WpDwPBczh5+cnPz+/XMt9fHyK/BuXw5tdvJVtx852zbZjZ7tm27GzN7Pt2Nmu2XbsbNdsO3b2ZrYdO9s1246d7ZxtpYM7isXnSMXHxys0NFTt2rVzLhs5cqQ2b96sTZs2Ob8k6dVXX1V8fLwkKSYmRr/88ouSk5Odt0tISFBwcLDq1q17SR8DAAAAgMtHke+Rys7OVnx8vOLi4lSq1P/q5JzJ73zVqlVT9erVJUmxsbGqW7eu7r//fr3wwgs6dOiQnnrqKQ0ePDjPPU4AAAAA4AlFvkcqMTFRSUlJ6tu3r+XblixZUgsXLlTJkiUVExOjnj17qlevXho7dqwXmgIAAADAWZb3SH3wwQe65557cu3xycjI0EcffaRevXpZyouNjZW7Jw7Ma73IyEgtWrTI0n0CAAAAQGFY3iPVp08fpaSk5Fp+4sQJ9enTxyOlAAAAAKA4szxIGWOcH5h7rj///FNly5b1SCkAAAAAKM7cPrSvUaNGcjgccjgcatGihcuJIbKysrRnzx61adPGKyUBAAAAoDhxe5Dq1KmTJGnTpk1q3bq1Spcu7bzO19dXUVFR6tKli8cLAgAAAEBx4/Yg9eyzz0qSoqKidM8998jf399rpQAAAACgOLN81r64uDhJ0vr167Vt2zZJUt26ddW4cWPPNgMAAACAYsryILV//37de++9WrFihcqVKydJOn78uJo2baqPPvpIVatW9XRHAAAAAChWLJ+1r1+/fsrMzNS2bdt09OhRHT16VNu2bVN2drYeeOABb3QEAAAAgGLF8h6p5cuXa+XKlapdu7ZzWe3atTV58mTdcsstHi0HAAAAAMWR5T1SERERyszMzLU8KytL4eHhHikFAAAAAMWZ5UHqxRdf1MMPP6z169c7l61fv16PPPKIXnrpJY+WAwAAAIDiyPKhfb1791ZaWpqaNGni/FDeM2fOqFSpUurbt6/69u3rXPfo0aOeawoAAAAAxYTlQeq1117zQg0AAAAAsI8Cf44UAAAAAFyuLA9SOZKTk5WcnKzs7GyX5Q0aNCh0KQAAAAAoziwPUhs2bFBcXJy2bdsmY4zLdQ6HQ1lZWR4rBwAAAADFkeVBqm/fvrryyis1bdo0Va5cWQ6Hwxu9AAAAAKDYsjxI7d69W5999plq1qzpjT4AAAAAUOxZ/hypFi1a6Oeff/ZGFwAAAACwBct7pN577z3FxcVpy5Ytuvrqq+Xj4+NyfYcOHTxWDgAAAACKI8uD1KpVq7RixQp9/fXXua7jZBMAAAAALgeWD+17+OGH1bNnTx08eFDZ2dkuXwxRAAAAAC4Hlgepv//+W8OHD1flypW90QcAAAAAij3Lg9Rdd92l7777zhtdAAAAAMAWLL9H6sorr9SoUaP0448/qn79+rlONjF06FCPlQMAAACA4qhAZ+0rXbq0li9fruXLl7tc53A4GKQAAAAA/OtZHqT27NnjjR4AAAAAYBuW3yN1LmOMjDGe6gIAAAAAtlCgQeqDDz5Q/fr1FRAQoICAADVo0EAzZ870dDcAAAAAKJYsH9r3yiuv6Omnn9aQIUN00003SZJ+/PFHPfTQQzpy5IiGDx/u8ZIAAAAAUJxYHqQmT56st956S7169XIu69Chg+rVq6fRo0czSAEAAAD417N8aN/BgwfVtGnTXMubNm2qgwcPeqQUAAAAABRnlgepmjVrau7cubmWf/zxx6pVq5ZHSgEAAABAcWb50L4xY8bonnvu0ffff+98j9SKFSu0ZMmSPAcsAAAAAPi3sbxHqkuXLlq7dq0qVaqk+fPna/78+apUqZLWrl2rzp07e6MjAAAAABQrlvZIZWZm6sEHH9TTTz+tWbNmeasTAAAAABRrlvZI+fj46LPPPvNWFwAAAACwBcuH9nXq1Enz58/3QhUAAAAAsAfLJ5uoVauWxo4dqxUrVqhx48YKCgpyuX7o0KEeKwcAAAAAxZHlQWratGkqV66cNmzYoA0bNrhc53A4GKQAAAAA/OtZHqT27NnjjR4AAAAAYBuWBqnVq1fryy+/VEZGhlq0aKE2bdp4qxcAAAAAFFtuD1Kffvqp7rnnHgUEBMjHx0evvPKKJk2apMcee8yb/QAAAACg2HH7rH0TJkxQ//79lZKSomPHjum5557T+PHjvdkNAAAAAIoltwep7du367HHHlPJkiUlSY8++qhOnDih5ORkr5UDAAAAgOLI7UEqLS1NwcHBzsu+vr7y9/fXyZMnvVIMAAAAAIorSyebeO+991S6dGnn5TNnzmj69OmqVKmScxmnPwcAAADwb+f2IFWtWjW9++67LsvCwsI0c+ZM52WrnyMVFRWlffv25Vo+aNAgTZkyRQ8++KASExN14MABlS5dWk2bNtWkSZNUp04d57pJSUkaOHCgvvvuO5UuXVpxcXGaMGGCSpWyfGZ3AAAAAHCL29PG3r17PX7n69atU1ZWlvPyli1b1KpVK3Xt2lWS1LhxY/Xo0UPVqlXT0aNHNXr0aMXGxmrPnj0qWbKksrKy1K5dO4WFhWnlypU6ePCgevXqJR8fH06EAQAAAMBrinS3TUhIiMvliRMnKjo6Ws2bN5ckDRgwwHldVFSUnnvuOV1zzTXau3evoqOj9e2332rr1q1KTExU5cqV1bBhQ40bN05PPvmkRo8eLV9f30v6eAAAAABcHorN8W8ZGRmaNWuWRowYIYfDkev6U6dOKT4+XtWrV1dERIQkadWqVapfv74qV67sXK9169YaOHCgfv31VzVq1CjP+0pPT1d6errzcmpqqiQpMzNTmZmZnnxYluXcvzd6eCvbjp3tmm3HznbNtmNnb2bbsbNds+3Y2a7ZduzszWw7drZrth072znbKnc7OIwxxstd3DJ37lx1795dSUlJCg8Pdy5/88039cQTT+jUqVOqXbu2vvrqK0VHR0s6u8dq3759Wrx4sXP9tLQ0BQUFadGiRWrbtm2e9zV69GiNGTMm1/I5c+YoMDDQw48MAAAAgF2kpaWpe/fuSklJcTlr+fmKzSDVunVr+fr66ssvv3RZnpKSouTkZB08eFAvvfSS9u/frxUrVsjf37/Ag1Ree6QiIiJ05MiRiz5Zl0JmZqYSEhLUqlUr+fj42CLbjp3tmm3HznbNtmNnb2bbsbNds+3Y2a7ZduzszWw7drZrth072znbqtTUVFWqVCnfQapYHNq3b98+JSYmat68ebmuK1u2rMqWLatatWrpxhtvVPny5fX555/rvvvuU1hYmNauXeuy/uHDhyWdPaPghfj5+cnPzy/Xch8fnyL/xuXwZhdvZduxs12z7djZrtl27OzNbDt2tmu2HTvbNduOnb2ZbcfOds22Y2c7Z1vp4I4CDVLZ2dnauXOnkpOTlZ2d7XJds2bNLOfFx8crNDRU7dq1u+h6xhgZY5x7k2JiYvT8888rOTlZoaGhkqSEhAQFBwerbt26lnsAAAAAgDssD1KrV69W9+7dtW/fPp1/VKDD4XA5nbk7srOzFR8fr7i4OJfPftq9e7c+/vhjxcbGKiQkRH/++acmTpyogIAA3XHHHZKk2NhY1a1bV/fff79eeOEFHTp0SE899ZQGDx6c5x4nAAAAAPAEy4PUQw89pOuuu05fffWVqlSpkucZ9qxITExUUlKS+vbt67Lc399fP/zwg1577TUdO3ZMlStXVrNmzbRy5Urn3qeSJUtq4cKFGjhwoGJiYhQUFKS4uDiNHTu2UJ0AAAAA4GIsD1I7duzQp59+qpo1a3qkQGxsbK49W5IUHh6uRYsW5Xv7yMhIt9YDAAAAAE8pYfUGTZo00c6dO73RBQAAAABswfIeqYcffliPPvqoDh06pPr16+c6q0WDBg08Vg4AAAAAiiPLg1SXLl0kyeU9TQ6HQ8aYAp1sAgAAAADsxvIgtWfPHm/0AAAAAADbsDxIRUZGeqMHAAAAANhGgT6Qd9euXXrttde0bds2SVLdunX1yCOPKDo62qPlAAAAAKA4snzWvsWLF6tu3bpau3atGjRooAYNGmjNmjWqV6+eEhISvNERAAAAAIoVy3ukRo4cqeHDh2vixIm5lj/55JNq1aqVx8oBAAAAQHFkeY/Utm3b1K9fv1zL+/btq61bt3qkFAAAAAAUZ5YHqZCQEG3atCnX8k2bNik0NNQTnQAAAACgWLN8aF///v01YMAA7d69W02bNpUkrVixQpMmTdKIESM8XhAAAAAAihvLg9TTTz+tMmXK6OWXX9aoUaMkSeHh4Ro9erSGDh3q8YIAAAAAUNxYHqQcDoeGDx+u4cOH68SJE5KkMmXKeLwYAAAAABRXBfocqRwMUAAAAAAuR24NUtdee62WLFmi8uXLq1GjRnI4HBdc96effvJYOQAAAAAojtwapDp27Cg/Pz/n/19skAIAAACAfzu3Bqlnn33W+f+jR4/2VhcAAAAAsAXLnyNVo0YN/f3337mWHz9+XDVq1PBIKQAAAAAoziwPUnv37lVWVlau5enp6frzzz89UgoAAAAAijO3z9q3YMEC5/8vXrxYZcuWdV7OysrSkiVLVL16dc+2AwAAAIBiyO1BqlOnTpLOfo5UXFycy3U+Pj6KiorSyy+/7NFyAAAAAFAcuT1IZWdnS5KqV6+udevWqVKlSl4rBQAAAADFmeUP5N2zZ483egAAAACAbVg+2YQkLVmyRHfeeaeio6MVHR2tO++8U4mJiZ7udtnJyjZas+eoNhxxaM2eo8rKNsU+246d7Zptx852zbZjZ29m27GzXbPt2Nmu2Xbs7M1sO3a2a7YdO9s525scxhhLTd9880098sgjuvvuuxUTEyNJWr16tT799FO9+uqrGjx4sFeKelNqaqrKli2rlJQUBQcHF0mHb7Yc1Jgvt+pgymnnsipl/fVs+7pqc3WVYpltx852zbZjZ7tm27GzN7Pt2Nmu2XbsbNdsO3b2ZrYdO9s1246d7ZxdUO7OBpYHqapVq2rkyJEaMmSIy/IpU6Zo/Pjx2r9/f8EaF6GiHqS+2XJQA2f9pPO/EY7//9+3el5b4BeSt7Lt2Nmu2XbsbNdsO3b2ZrYdO9s1246d7Zptx87ezLZjZ7tm27GznbMLw2uDVOnSpbVp0ybVrFnTZfmOHTvUqFEjnTx5smCNi1BRDlJZ2UY3T1rqMoWfyyGpcrC/EkY0U8kSjjzXuVh2y1eW63BqukezvZVL9r+js12z7djZm9l27GzXbDt2tmu2HTt7M9uOne2abcfOxSE7rKy/fnzydsvZheW1Qap79+5q1KiRHn/8cZflL730ktavX6+PPvqoYI2LUFEOUqt2/a373l19Se8TAAAAsIMP+9+omOiKl/Q+3Z0NLJ+1r27dunr++ee1bNkyl/dIrVixQo8++qhef/1157pDhw4tQPXLS/KJvPdEAQAAAJe74vy7suU9UtWrV3cv2OHQ7t27C1TqUrPDHqnpfa7XDdUrWMpeu+eoesev83i2t3LJvnS5ZF+6XLtm27GzXbPt2Nmu2Xbs7M1sO3a2a7YdOxeX7H/VHik+R8qzbqheQVXK+utQyulcb7ST/nd86C21QiwfH3pLrRCvZHsrl+x/R2e7Ztuxszez7djZrtl27GzXbDt29ma2HTvbNduOnYtLttUB7VIq0OdIwXNKlnDo2fZ1Jf3vDCU5ci4/275ugd5k561sO3a2a7YdO9s1246dvZltx852zbZjZ7tm27GzN7Pt2Nmu2XbsbOfsS8XyoX2S9Oeff2rBggVKSkpSRkaGy3WvvPKKx8pdKkV9+nPJnufnt2Nnu2bbsbNds+3Y2ZvZduxs12w7drZrth07ezPbjp3tmm3HznbOLiivnbVvyZIl6tChg2rUqKHffvtNV199tfbu3StjjK699lotXbq00OUvteIwSElnTwO5ameyvv1hjWJvaaKYmqEem8K9lW3HznbNtmNnu2bbsbM3s+3Y2a7Zduxs12w7dvZmth072zXbjp3tnF0QXnuP1KhRo/TYY49pzJgxKlOmjD777DOFhoaqR48eatOmTaFKX+5KlnCoSfUK+nubUZPqFTz6AvJWth072zXbjp3tmm3Hzt7MtmNnu2bbsbNds+3Y2ZvZduxs12w7drZztjdZfo/Utm3b1KtXL0lSqVKl9M8//6h06dIaO3asJk2a5PGCAAAAAFDcWB6kgoKCnO+LqlKlinbt2uW87siRI55rBgAAAADFlOVD+2688Ub9+OOPuuqqq3THHXfo0Ucf1S+//KJ58+bpxhtv9EZHAAAAAChWLA9Sr7zyik6ePClJGjNmjE6ePKmPP/5YtWrVsuUZ+wAAAADAKsuDVI0aNZz/HxQUpLffftujhQAAAACguOMDeQEAAADAIrf2SJUvX14Oh3unITx69GihCgEAAABAcefWIPXaa685///vv//Wc889p9atWysmJkaStGrVKi1evFhPP/20V0oCAAAAQHHi1iAVFxfn/P8uXbpo7NixGjJkiHPZ0KFD9cYbbygxMVHDhw/3fEsAAAAAKEYsv0dq8eLFatOmTa7lbdq0UWJiokdKAQAAAEBxZnmQqlixor744otcy7/44gtVrFjRI6UAAAAAoDizfPrzMWPG6IEHHtCyZcvUpEkTSdKaNWv0zTff6N133/V4QQAAAAAobizvkerdu7dWrFih4OBgzZs3T/PmzVNwcLB+/PFH9e7d21JWVFSUHA5Hrq/Bgwfr6NGjevjhh1W7dm0FBASoWrVqGjp0qFJSUlwykpKS1K5dOwUGBio0NFSPP/64zpw5Y/VhAQAAAIDbLO+RkqQmTZpo9uzZLsuys7O1cOFC3XnnnW7nrFu3TllZWc7LW7ZsUatWrdS1a1cdOHBABw4c0EsvvaS6detq3759euihh3TgwAF9+umnkqSsrCy1a9dOYWFhWrlypQ4ePKhevXrJx8dH48ePL8hDAwAAAIB8FWiQOtfOnTv1/vvva/r06frrr7+UmZnp9m1DQkJcLk+cOFHR0dFq3ry5HA6HPvvsM+d10dHRev7559WzZ0+dOXNGpUqV0rfffqutW7cqMTFRlStXVsOGDTVu3Dg9+eSTGj16tHx9fQv78AAAAAAglwINUv/8848++eQTvffee1qxYoVuueUWPfPMM+rcuXOBi2RkZGjWrFkaMWLEBT/8NyUlRcHBwSpV6mztVatWqX79+qpcubJzndatW2vgwIH69ddf1ahRozxz0tPTlZ6e7rycmpoqScrMzLQ0CHpDzv17o4e3su3Y2a7Zduxs12w7dvZmth072zXbjp3tmm3Hzt7MtmNnu2bbsbOds61yt4PDGGPcDV23bp3ee+89ffTRR4qOjlaPHj305JNPavPmzapbt26By0rS3Llz1b17dyUlJSk8PDzX9UeOHFHjxo3Vs2dPPf/885KkAQMGaN++fVq8eLFzvbS0NAUFBWnRokVq27Ztnvc1evRojRkzJtfyOXPmKDAwsFCPAwAAAIB9paWlqXv37s6dOBfi9h6pBg0aKDU1Vd27d9fKlStVr149SdLIkSML31bStGnT1LZt2zyHqNTUVLVr105169bV6NGjC31fo0aN0ogRI1zyIyIiFBsbe9En61LIzMxUQkKCWrVqJR8fH1tk27GzXbPt2Nmu2Xbs7M1sO3a2a7YdO9s1246dvZltx852zbZjZztnW5VztFp+3B6ktm/frnvuuUe33XZbofc+nW/fvn1KTEzUvHnzcl134sQJtWnTRmXKlNHnn3/u8sSGhYVp7dq1LusfPnzYed2F+Pn5yc/PL9dyHx+fIv/G5fBmF29l27GzXbPt2Nmu2Xbs7M1sO3a2a7YdO9s1246dvZltx852zbZjZztnW+ngDrdPf757927Vrl1bAwcOVNWqVfXYY49p48aNF3w/kxXx8fEKDQ1Vu3btXJanpqYqNjZWvr6+WrBggfz9/V2uj4mJ0S+//KLk5GTnsoSEBAUHB3t82AMAAACAHG4PUldccYX++9//aufOnZo5c6YOHTqkm266SWfOnNH06dP1+++/F6hAdna24uPjFRcX5zyJhPS/IerUqVOaNm2aUlNTdejQIR06dMh5yvTY2FjVrVtX999/v37++WctXrxYTz31lAYPHpznHicAAAAA8ATLH8grSbfffrtmzZqlgwcP6o033tDSpUtVp04dNWjQwHJWYmKikpKS1LdvX5flP/30k9asWaNffvlFNWvWVJUqVZxff/zxhySpZMmSWrhwoUqWLKmYmBj17NlTvXr10tixYwvysAAAAADALYX6HKmyZctq0KBBGjRokDZt2qT333/fckZsbKzyOnHgrbfemufy80VGRmrRokWW7xcAAAAACqpAe6Ty0rBhQ73++uueigMAAACAYstjgxQAAAAAXC4YpAAAAADAIgYpAAAAALDIrUGqQoUKOnLkiCSpb9++OnHihFdLAQAAAEBx5tYglZGRodTUVEnSjBkzdPr0aa+WAgAAAIDizK3Tn8fExKhTp05q3LixjDEaOnSoAgIC8ly3IKdABwAAAAA7cWuQmjVrll599VXt2rVLDodDKSkp7JUCAAAAcNlya5CqXLmyJk6cKEmqXr26Zs6cqYoVK3q1GAAA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scx69erp4MGDzq8ff/zRI7nHjh3TTTfdJB8fH3399dfaunWrXn75ZZUvX77Q2evWrXPpnJCQIEnq2rVroXInTZqkt956S2+88Ya2bdumSZMm6YUXXtDkyZML3VmSHnjgASUkJGjmzJn65ZdfFBsbq5YtW2r//v2WcvLbPl544QW9/vrrevvtt7VmzRoFBQWpdevWOn36dKGzT506pZtvvlmTJk3yWOe0tDT99NNPevrpp/XTTz9p3rx52r59uzp06FDobEm68sor9cYbb+iXX37Rjz/+qKioKMXGxuqvv/4qdHaOzz//XKtXr1Z4eLhbnd3NbtOmjctr/cMPPyx07q5du3TzzTerTp06WrZsmTZv3qynn35a/v7+hc4+t+vBgwf1/vvvy+FwqEuXLoXOHjFihL755hvNmjVL27Zt07BhwzRkyBAtWLCgUNnGGHXq1Em7d+/WF198oY0bNyoyMlItW7bM92eDOz9Thg8fri+//FKffPKJli9frgMHDuiuu+4qdG5aWpratGmj//znP/k+fivZBw4c0IEDB/TSSy9py5Ytmj59ur755hv169ev0NmS1LhxY8XHx2vbtm1avHixjDGKjY1VVlZWobNzvPbaa3I4HB55PnL079/f5bX9wgsveCR71apVatOmjWJjY7V27VqtW7dOQ4YMUYkSF/91N7/siIiIXNvjmDFjVLp0abVt27bQvXv16qXt27drwYIF+uWXX3TXXXepW7du2rhxY4FzT506pdjYWDkcDi1dulQrVqxQRkaG2rdvr+zs7It2zu93sIJsh+5mF3RbLDIGxcYNN9xgBg8e7LyclZVlwsPDzYQJEzx2H5LM559/7rG8cyUnJxtJZvny5V7JL1++vHnvvfc8knXixAlTq1Ytk5CQYJo3b24eeeSRQmc+++yz5pprril0Tl6efPJJc/PNN3sl+3yPPPKIiY6ONtnZ2YXKadeunenbt6/Lsrvuusv06NGjULnGGJOWlmZKlixpFi5c6LL82muvNf/9738LnHv+9pGdnW3CwsLMiy++6Fx2/Phx4+fnZz788MNCZZ9rz549RpLZuHFjoTvnZe3atUaS2bdvn8ezU1JSjCSTmJjokew///zTXHHFFWbLli0mMjLSvPrqq5ZyL5QdFxdnOnbsaDkrv9x77rnH9OzZs1C5F8o+X8eOHc3tt9/ukex69eqZsWPHuiwryPZzfvb27duNJLNlyxbnsqysLBMSEmLeffddS9nn/0w5fvy48fHxMZ988olznW3bthlJZtWqVQXOPdd3331nJJljx45Z6upOdo65c+caX19fk5mZ6fHsn3/+2UgyO3fu9Ej2xo0bzRVXXGEOHjxYoN8f8sr11M/cvLKbNGlinnrqKa9kn69hw4a5fsYVNDsoKMh88MEHLutVqFDB0jZzfu7ixYtNiRIlTEpKinOd48ePG4fDYRISEiz3zvkdzFPbYV7Z5yrstnipsEeqmMjIyNCGDRvUsmVL57ISJUqoZcuWWrVqVRE2c1/OoQoVKlTwaG5WVpY++ugjnTp1SjExMR7JHDx4sNq1a+fyfHvCjh07FB4erho1aqhHjx5uHd7jjgULFui6665T165dFRoaqkaNGundd9/1SPa5MjIyNGvWLPXt29ftv0BeSNOmTbVkyRL9/vvvkqSff/5ZP/74Y75/vXPHmTNnlJWVleuv/gEBAR7bCyhJe/bs0aFDh1xeJ2XLllWTJk1ss11KZ7dNh8OhcuXKeTQ3IyNDU6dOVdmyZXXNNdcUOi87O1v333+/Hn/8cdWrV88DDV0tW7ZMoaGhql27tgYOHKi///67UHnZ2dn66quvdOWVV6p169YKDQ1VkyZNPHb49LkOHz6sr776yq09Ge5o2rSpFixYoP3798sYo++++06///67YmNjC5Wbnp4uSS7bZokSJeTn52d52zz/Z8qGDRuUmZnpsj3WqVNH1apVs7Q9eutnlbvZKSkpCg4OVqlSpTyaferUKcXHx6t69eqKiIgodHZaWpq6d++uKVOmKCwszFJefp1nz56tSpUq6eqrr9aoUaOUlpZW6Ozk5GStWbNGoaGhatq0qSpXrqzmzZsX6GdCfs/1hg0btGnTpgJtj3llN23aVB9//LGOHj2q7OxsffTRRzp9+rRuvfXWAuemp6fL4XC4fLitv7+/SpQoYek5Of93ME9th3ll21JRT3I4a//+/UaSWblypcvyxx9/3Nxwww0eux95aY9UVlaWadeunbnppps8lrl582YTFBRkSpYsacqWLWu++uorj+R++OGH5uqrrzb//POPMcZzfx1btGiRmTt3rvn555/NN998Y2JiYky1atVMampqobP9/PyMn5+fGTVqlPnpp5/MO++8Y/z9/c306dMLnX2ujz/+2JQs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jZWvr68WLFjg1hkdC9rbnP0Deb7bY37ZI0eOzLU9StKrr76q+Ph4j3bOyc5vW8wvOyoqSuHh4QXaHq30njZtmjp06KCQkJCLZrqbnfP+MKvbo5XOlSpVUrly5bR06VIlJye7fRbXc+X8O1/Q7dCdbFsqkvENefroo4+Mn5+fmT59utm6dasZMGCAKVeunDl06FChck+cOGE2btxoNm7caCQ5j+W3egav8w0cONCULVvWLFu2zBw8eND5lZaWVqhcY4wZOXKkWb58udmzZ4/ZvHmzGTlypHE4HObbb78tdPb5PHVo36OPPmqWLVtm9uzZY1asWGFatmxpKlWqZPmvVnlZu3atKVWqlHn++efNjh07zOzZs01gYKCZNWtWobONOXt8dbVq1cyTTz7pkTxjzp4l7YorrjALFy40e/bsMfPmzTOVKlVye9d/fr755hvz9ddfm927d5tvv/3WXHPNNaZJkyaWD5nJb/uYOHGiKVeunPP9NR07djTVq1d366/K+WX//fffZuPGjearr74yksxHH31kNm7caA4ePFjg3IyMDNOhQwdTtWpVs2nTJpdtMz09vVCdT548aUaNGmVWrVpl9u7da9avX2/69Olj/Pz8cv01tSDPx/msHNp3sewTJ06Yxx57zKxatcrs2bPHJCYmmmuvvdbUqlXLnD59ulCd582bZ3x8fMzUqVPNjh07zOTJk03JkiXNDz/84JHnIyUlxQQGBpq33nrLrefB3ezmzZubevXqme+++87s3r3bxMfHG39/f/Pmm28WOnvu3Lnmu+++M7t27TLz5883kZGR5q677so3152fKQ899JCpVq2aWbp0qVm/fr2JiYnJddhzQXIPHjxoNm7caN59910jyXz//fdm48aN5u+//y5UdkpKimnSpImpX7++2blzp8s6+R0BkV/2rl27zPjx48369evNvn37zIoVK0z79u1NhQoV8j3UtiA/v+XGnt78cnfu3GnGjh1r1q9fb/bs2WO++OILU6NGDdOsWbOL5rrb+dVXXzXBwcHmk08+MTt27DBPPfWU8ff3z/ewQXefjx07dhiHw2G+/vrrfPu6m52RkWFq1qxpbrnlFrNmzRqzc+dO89JLLxmHw3HR94a70/n99983q1atMjt37jQzZ840FSpUMCNGjMi3c36/gxVkO3Q3u6DbYlFhkCpmJk+ebKpVq2Z8fX3NDTfcYFavXl3ozJzdo+d/xcXFFSo3r0xJJj4+vtCd+/btayIjI42vr68JCQkxLVq08MoQZYznBql77rnHVKlSxfj6+porrrjC3HPPPZbf9HsxX375pbn66quNn5+fqVOnjpk6darHshcvXmwkme3bt3ssMzU11TzyyCOmWrVqxt/f39SoUcP897//deuXeXd8/PHHpkaNGsbX19eEhYWZwYMHm+PHj1vOyW/7yM7ONk8//bSpXLmy8fPzMy1atHD7ecovOz4+Ps/rn3322QLn5hwmmNfXd999V6jO//zzj+ncubMJDw83vr6+pkqVKqZDhw5un2zC6r9FVgapi2WnpaWZ2NhYExISYnx8fExkZKTp37+/W3+kcqfztGnTTM2aNY2/v7+55ppr3D481p3sd955xwQEBFh+beeXffDgQdO7d28THh5u/P39Te3atc3LL7/s1sce5Jf9f//3f6Zq1arGx8fHVKtWzTz11FNubffu/Ez5559/zKBBg0z58uVNYGCg6dy5c75/eHAn99lnny3Qz7P8si/0XEkye/bsKVT2/v37Tdu2bU1oaKjx8fExVatWNd27dze//fbbRXPdfU7yuk1+g1R+uUlJSaZZs2amQoUKxs/Pz9SsWdM8/vjjbr2H093OEyZMMFWrVjWBgYEmJibGrT9quJs9atQoExERYbKysvLNtJL9+++/m7vuusuEhoaawMBA06BBg1ynQy9I7pNPPmkqV65sfHx8TK1atdzexvP7Hawg26G72QXdFouKwxhjBAAAAABwG++RAgAAAACLGKQAAAAAwCIGKQAAAACwiEEKAAAAACxikAIAAAAAixikAAAAAMAiBikAAAAAsIhBCgAAAAAsYpACAAAAAIsYpAAAtte7d2916tSpqGsAAC4jDFIAAHhYRkZGUVcAAHgZgxQA4F/tlVdeUf369RUUFKSIiAgNGjRIJ0+elCSdOnVKwcHB+vTTT11uM3/+fAUFBenEiROSpD/++EPdunVTuXLlVKFCBXXs2FF79+51rp+zR+z5559XeHi4ateufckeHwCgaDBIAQD+1UqUKKHXX39dv/76q2bMmKGlS5fqiSeekCQFBQXp3nvvVXx8vMtt4uPjdffdd6tMmTLKzMxU69atVaZMGf3www9asWKFSpcurTZt2rjseVqyZIm2b9+uhIQELVy48JI+RgDApecwxpiiLgEAQGH07t1bx48f1/z58/Nd99NPP9VDDz2kI0eOSJLWrl2rpk2b6o8//lCVKlWUnJysK664QomJiWrevLlmzZql5557Ttu2bZPD4ZB09tC9cuXKaf78+YqNjVXv3r31zTffKCkpSb6+vt58qACAYoI9UgCAf7XExES1aNFCV1xxhcqUKaP7779ff//9t9LS0iRJN9xwg+rVq6cZM2ZIkmbNmqXIyEg1a9ZMkvTzzz9r586dKlOmjEqXLq3SpUurQoUKOn36tHbt2uW8n/r16zNEAcBlhEEKAPCvtXfvXt15551q0KCBPvvsM23YsEFTpkyR5HpCiAceeEDTp0+XdPawvj59+jj3Pp08eVKNGzfWpk2bXL5+//13de/e3ZkRFBR06R4YAKDIlSrqAgAAeMuGDRuUnZ2tl19+WSVKnP3b4dy5c3Ot17NnTz3xxBN6/fXXtXXrVsXFxTmvu/baa/Xxxx8rNDRUwcHBl6w7AKB4Y48UAOBfISUlJddeo0qVKikzM1OTJ0/W7t27NXPmTL399tu5blu+fHndddddevzxxxUbG6uqVas6r+vRo4cqVaqkjh076ocfftCePXu0bNkyDR06VH/++eelfIgAgGKEQQoA8K+wbNkyNWrUyOVr5syZeuWVVzRp0iRdffXVmj17tiZMmJDn7fv166eMjAz17dvXZXlgYKC+//57VatWTXfddZeuuuoq9evXT6dPn2YPFQBcxjhrHwAAkmbOnKnhw4frwIEDnDQCAJAv3iMFALispaWl6eDBg5o4caIefPBBhigAgFs4tA8AcFl74YUXVKdOHYWFhWnUqFFFXQcAYBMc2gcAAAAAFrFHCgAAAAAsYpACAAAAAIsYpAAAAADAIgYpAAAAALCIQQoAAAAALGKQAgAAAACLGKQAAAAAwCIGKQAAAACw6P8ByrU0/I9P2tcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from safetensors import safe_open\n",
    "\n",
    "# Path to your SafeTensor file\n",
    "safetensor_file = llama_adapter_dict[\"angry\"]\n",
    "\n",
    "# Load the SafeTensor file\n",
    "with safe_open(safetensor_file, framework=\"pt\") as f:  # Use 'pt' for PyTorch, 'tf' for TensorFlow\n",
    "    tensors = {key: f.get_tensor(key) for key in f.keys()}\n",
    "\n",
    "# Extract and calculate norms for each layer\n",
    "layer_names = []\n",
    "norms = []\n",
    "\n",
    "for key, tensor in tensors.items():\n",
    "    if 'adaption_prompt' in key:\n",
    "        layer_name = key.split('.')[4]  # Assuming the layer number is at this position\n",
    "        norm = torch.norm(tensor).item()\n",
    "        layer_names.append(layer_name)\n",
    "        norms.append(norm)\n",
    "\n",
    "# Sort layers by their numerical order\n",
    "layer_names, norms = zip(*sorted(zip(layer_names, norms), key=lambda x: int(x[0])))\n",
    "\n",
    "# Plot the norms\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(layer_names, norms, marker='o')\n",
    "plt.xlabel('Layer')\n",
    "plt.ylabel('Norm of Adaption Prompt')\n",
    "plt.title('Norm of Adaption Prompt for Each Layer')\n",
    "plt.grid(True)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "explanation",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
