{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import transformers\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import stats\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "\n",
    "import embd_metrics"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Classic models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# base_model_name = \"meta-llama/Llama-3.1-8B\"\n",
    "# model_name = \"meta-llama/Llama-3.2-1B\"\n",
    "model_name = \"TinyLlama/TinyLlama-1.1B-Chat-v0.1\"\n",
    "model = transformers.AutoModelForCausalLM.from_pretrained(model_name)\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(model_name)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_model_name = \"TinyLlama/TinyLlama-1.1B-intermediate-step-1431k-3T\"\n",
    "# base_model_name = \"meta-llama/Llama-3.2-1B-Instruct\"\n",
    "base_model = transformers.AutoModelForCausalLM.from_pretrained(base_model_name)\n",
    "base_tokenizer = transformers.AutoTokenizer.from_pretrained(base_model_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "embed = model.model.embed_tokens.weight.cpu()\n",
    "base_embed = base_model.model.embed_tokens.weight.cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([32001, 2048]), torch.Size([32000, 2048]))"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "embed.shape, base_embed.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([32001, 2048])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "embed.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "if embed.shape[0] > base_embed.shape[0]:\n",
    "    embed = embed[:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Compute cosine similarity along the second dimension (i.e. between embeddings for each token)\n",
    "cos_sims = torch.nn.functional.cosine_similarity(embed, base_embed, dim=-1) \n",
    "\n",
    "similarities = cos_sims.cpu().detach().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "sorted_similarities = np.sort(similarities)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Sorted cosine similarities, between TinyLlama/TinyLlama-1.1B-Chat-v0.1 and TinyLlama/TinyLlama-1.1B-intermediate-step-1431k-3T')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABGMAAAGzCAYAAACLq9qMAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAgG5JREFUeJzt3Xd0VNXax/HfJKSHNNIgpNF7MUAApShIEUVUFGwgKnrtXq4N9YIVrIgXFdsrNlTErjQVQZAi0qQjLQktgZBGCWmz3z8wI0MKk8IMCd/PWrMgZ/ac85wzpz6zi8UYYwQAAAAAAACncHN1AAAAAAAAAOcSkjEAAAAAAABORDIGAAAAAADAiUjGAAAAAAAAOBHJGAAAAAAAACciGQMAAAAAAOBEJGMAAAAAAACciGQMAAAAAACAE5GMAQAAAAAAcKJzMhmzcOFCWSwWLVy40NWh2Hn//fdlsViUlJTk6lBKZbFY9MQTT1Tb/JKSkmSxWPT+++/bpj3xxBOyWCzVtoxicXFxuummmxwq27t3b/Xu3bvaY6iom266Sf7+/q4Oo1a66aabFBcX5+owzvpjvjpU5Ng7k86W7xz2is/56enprg4Ff6vOY/Zsut+q7nuYs82Zun+qqLPpO6/tzpbv/GxU2jW/tp8DUDPvKSqcjFm/fr2GDh2q2NhYeXt7KyoqShdffLGmTJlS7cFNmDBB33zzTbXPF9i0aZOeeOKJWv0QXJo33njDLvlVm1gsFodezrpBrI3JtISEBLVq1crhbe0scXFxuvTSS522PGfbunWr/v3vf6t79+7y9vaucAJvxYoVuvPOO5WQkCAPD48yv5viBPnJr4CAAHXo0EGvvfaaioqKHF5mUVGRpk2bpt69eyskJEReXl6Ki4vTqFGjtHLlSofnUxln8jz33Xff6bzzzpO3t7diYmI0fvx4FRYWOvTZZ599VoMHD1ZERESNfii46aabHDr+nZWELX74/+KLL5yyPGeYMmWKAgMDFRUV5dC2dtZ1vSY+6FRUVY7TI0eOaPz48RowYIBCQkLK/W569+5t9x16enoqPj5et912m3bv3l09K1OOpUuX6oknnlBWVtYZX1ZN5+pnhrPhedjR+4hT/fbbb7Z9/NTzxtdff63+/furQYMG8vLyUsOGDTV06FBt2LChxHxmzJihG264QU2bNpXFYjljP5q/88476tWrlyIiIuTl5aX4+HiNGjXK7rs/9dgt6+XouaNORQJcunSpLrzwQsXExGj06NGKjIzU7t27tXz5cr366qu65557KjK705owYYKGDh2qIUOGVOt8z1Y33nijhg8fLi8vL1eHUqrc3FzVqVOhXaZcsbGxys3NlYeHR7XNsyxbt26Vm9s/ucdNmzbpySefVO/evUtkzn/88cczHo+rvPHGGwoNDT0raipUt48++sju7w8//FA//fRTiektW7bUO++8I6vV6szwarz9+/drzZo1mjZtmtzd3e3eGzt2rPz9/fXYY4+V+Nypxx4qbtmyZfrf//6nVq1aqWXLllq7dm2FPj979my9++67ateunRo1aqS//vqr3PLXXnutLrnkEklSdna2Zs+erXvuuUfJycl68cUXT7u83NxcXXnllZo7d6569uypRx99VCEhIUpKStLnn3+uDz74QCkpKWrYsGGF1sNRZ+o8N2fOHA0ZMkS9e/fWlClTtH79ej3zzDM6cOCApk6detrPP/7444qMjFTHjh01b968ao3NmW6//Xb17dvX9veuXbs0btw43XbbberRo4dteuPGjZWYmKjc3Fx5enq6ItQaa9asWerXr5+uv/56HTlyxDZ99uzZ+vTTT/XKK68oNDTUNr179+664YYb9Mgjj7gi3FqlKsdpenq6nnrqKcXExKh9+/an/fGnYcOGmjhxoiQpPz9fmzZt0ptvvql58+Zp8+bN8vX1PW2slf3Oly5dqieffFI33XSTgoKCKjWPmqayzzHlPTM4w9nwPFzR+whJslqtuueee+Tn56ejR4+WeH/9+vUKDg7Wfffdp9DQUKWmpuq9995Tly5dtGzZMrVv395WdurUqVq1apU6d+6sQ4cOVeu6nWzNmjWKj4/X4MGDFRwcrF27dumdd97RDz/8oD///FMNGjTQY489pltvvdX2mT/++EP/+9//9Oijj6ply5a26e3atXNomRXaI5999lkFBgbqjz/+KHHgHjhwoCKzKpMxRsePH5ePj0+1zK8mcXd3L/GQczbx9vau1vlZLJZqn+fJTt6XKpLg4qaxZrrhhhvs/l6+fLl++umnEtNROXPmzJG3t7euueaaEufn5557TqGhoaVu67M1uVyTDB48WFlZWapbt65eeumlCidj7rjjDj388MPy8fHR3XfffdqbqPPOO8/uu7zzzjuVmJioTz75xKFkzIMPPqi5c+fqlVde0f3332/33vjx4/XKK69UKP6zxQMPPKB27drpxx9/tN3QBwQEaMKECbrvvvvUokWLcj+/a9cuxcXFKT09XWFhYc4I+Yzo1q2bunXrZvt75cqVGjdunLp161bqOeBMXudro2PHjunXX3/V1KlTSzx8paam6tNPP9WQIUNKfSiszh/MzlVVOU7r16+v/fv3KzIyUitXrlTnzp3LLR8YGFjimImPj9fdd9+tJUuW6OKLLy7383Xq1DnrvvNjx46dNonkKpyLKq+i9xGS9Pbbb2v37t269dZb9eqrr5Z4f9y4cSWm3XrrrWrYsKGmTp2qN9980zb9o48+UlRUlNzc3NSmTZuqrUw53njjjRLThgwZok6dOunDDz/UI488UuK49Pb21v/+9z9dfPHFlaqxU6GfK3fs2KHWrVuXmkENDw+3+7uwsFBPP/20GjdubKue/OijjyovL8+uXHH18nnz5qlTp07y8fHRW2+9JYvFoqNHj+qDDz4otcrr3r17dfPNN9uqEbVu3Vrvvfdeibj27NmjIUOGyM/PT+Hh4fr3v/9dIoby7N27V7fccoutClV8fLzuuOMO5efn28rs3LlTV199tUJCQuTr66uuXbtq1qxZJeY1ZcoUtW7dWr6+vgoODlanTp30ySef2N4vrf+I4u3z22+/qUuXLvL29lajRo304Ycflph/VlaW7r//fkVHR8vLy0tNmjTR888/71ANgJUrV6p///4KDQ2Vj4+P4uPjdfPNN9uVObXKVXF11b/++ks33HCDAgMDFRYWpv/+978yxmj37t26/PLLFRAQoMjISL388st28yutz5jSTJs2TRdddJHCw8Pl5eWlVq1alforZFn7UvF7xfvP+++/r6uvvlqSdOGFF5ZovlJanzF5eXkaP368mjRpIi8vL0VHR+uhhx4qsS/99NNPuuCCCxQUFCR/f381b95cjz76aLnrdzo7d+5U//795efnpwYNGuipp56SMcaujNVq1eTJk9W6dWt5e3srIiJCt99+uzIzM+22z8aNG/Xrr7/a1rl3797KysqSu7u7/ve//9nKpqeny83NTfXq1bNb1h133KHIyEi7Zf/+++8aMGCAAgMD5evrq169emnJkiUl1sORY7a4uvnnn3+uZ599Vg0bNpS3t7f69Omj7du3V2k7nuzUtsTF++JLL72kt99+23be6ty5s/744w9buWnTpslisWjNmjUl5jlhwgS5u7tr7969VYrt22+/1aBBg2znnMaNG+vpp58u0USkd+/eatOmjdatW6devXrJ19dXTZo0sVXV//XXX5WYmCgfHx81b95cP//8s93nk5OTdeedd6p58+by8fFRvXr1dPXVV5dZDXfWrFm68MILK5woP7X/ieLz3JIlSzRmzBiFhYXJz89PV1xxhQ4ePGgrN3LkSIWGhqqgoKDEPPv166fmzZtXKI7SvPTSS+revbvq1asnHx8fJSQklNrUwWKx6O6779bMmTPVqlUr+fj4qFu3blq/fr0k6a233lKTJk3k7e2t3r17l9iGixcv1tVXX62YmBjb+ePf//63cnNzHYozJCREdevWrfR6RkREVOkHDovFooiICIdu+vfs2aO33npLF198cYlEjHTiR4cHHnigRK2YrKws2y+0gYGBGjVqlI4dO2ZXxpFrQVnnubK0adNGF154YYnpVqtVUVFRGjp0qKQTv4xu2rRJt912m912uPPOO2WMcaiJTFV+UXX0eHX0+JJO/GDxzDPPqGHDhvL19dWFF16ojRs3VjrG0pTWf0jxuWvTpk268MIL5evrq6ioKL3wwgu2MkeOHJGfn5/uu+++EvPcs2eP3N3dbTUKKqui2/S3337Tvffeq7CwMAUFBen2229Xfn6+srKyNGLECAUHBys4OFgPPfRQiWu0o+caSZo/f77y8vI0cODACq1Paf2HFJ+7vvnmG7Vp08Z27Z07d66tzIIFC2SxWPT111+XmOcnn3wii8WiZcuWVSiWUzl6Dixu3puSkqJLL71U/v7+ioqK0uuvvy7pxC/pF110kfz8/BQbG2t3Dy1JGRkZeuCBB9S2bVv5+/srICBAAwcO1J9//ulwrFU5Tr28vErcI1VU8ecdOd9W9jt/4okn9OCDD0o6kfwpPleevO9//PHHSkhIkI+Pj0JCQjR8+PASzaeKj+VVq1apZ8+e8vX11aOPPmp3T/X666+rUaNG8vX1Vb9+/bR7924ZY/T000+rYcOG8vHx0eWXX66MjIwS6zdnzhz16NFDfn5+qlu3rgYNGlTqOap4Xb29vdWmTZtS9+XibXPyc4wj54DTPTNUJM7SbNu2TVdddZUiIyPl7e2thg0bavjw4crOzrbFXNXn4eLz8IwZM/Too48qMjJSfn5+Gjx4sMNN4ip6H5GRkaHHH39cTz31VIVqXoWHh8vX17dE87no6OhK17JOTk5WkyZN1KZNG6WlpVX488XnhDPVpK9C6dTY2FgtW7ZMGzZsOG1W6tZbb9UHH3ygoUOH6j//+Y9+//13TZw4UZs3by5xkGzdulXXXnutbr/9do0ePVrNmzfXRx99pFtvvVVdunTRbbfdJulElVdJSktLU9euXW0nnLCwMM2ZM0e33HKLcnJybDeAubm56tOnj1JSUnTvvfeqQYMG+uijj/TLL784tL779u1Tly5dlJWVpdtuu00tWrTQ3r179cUXX+jYsWPy9PRUWlqaunfvrmPHjunee+9VvXr19MEHH2jw4MH64osvdMUVV0g60Qbt3nvv1dChQ3Xffffp+PHjWrdunX7//Xddd9115caxfft2DR06VLfccotGjhyp9957TzfddJMSEhLUunVrSScy0b169dLevXt1++23KyYmRkuXLtXYsWO1f/9+TZ48ucz5HzhwQP369VNYWJgeeeQRBQUFKSkpSV999ZVD22nYsGFq2bKlnnvuOc2aNUvPPPOMQkJC9NZbb+miiy7S888/r+nTp+uBBx5Q586d1bNnT4fmW2zq1Klq3bq1Bg8erDp16uj777/XnXfeKavVqrvuusuubGn70ql69uype++9t0SVspOrlp3MarVq8ODB+u2333TbbbepZcuWWr9+vV555RX99ddftnacGzdu1KWXXqp27drpqaeekpeXl7Zv315qYsJRRUVFGjBggLp27aoXXnhBc+fOtfVR8NRTT9nK3X777Xr//fc1atQo3Xvvvdq1a5dee+01rVmzRkuWLJGHh4cmT56se+65x645SUREhIKCgtSmTRstWrRI9957r6R/2nhmZGRo06ZNtv1s8eLFdtXQf/nlFw0cOFAJCQkaP3683NzcbA9MixcvVpcuXSQ5fswWe+655+Tm5qYHHnhA2dnZeuGFF3T99dfr999/r/S2dMQnn3yiw4cP6/bbb5fFYtELL7ygK6+8Ujt37pSHh4eGDh2qu+66S9OnT1fHjh3tPjt9+nT17t1bUVFRVYrh/fffl7+/v8aMGSN/f3/98ssvGjdunHJyckrUSsjMzNSll16q4cOH6+qrr9bUqVM1fPhwTZ8+Xffff7/+9a9/6brrrtOLL76ooUOHavfu3baH+j/++ENLly7V8OHD1bBhQyUlJWnq1Knq3bu3Nm3aZPfLVkFBgX7++WdNmDChSut2snvuuUfBwcEaP368kpKSNHnyZN19992aMWOGpBPNNj/88EPNmzfPrj+Y1NRU/fLLLxo/fnyVY3j11Vc1ePBgXX/99crPz9dnn32mq6++Wj/88IMGDRpkV3bx4sX67rvvbOeciRMn6tJLL9VDDz2kN954Q3feeacyMzP1wgsv6Oabb7a7zsycOVPHjh3THXfcoXr16mnFihWaMmWK9uzZo5kzZ1Z5ParbsWPHbG27c3JyNGfOHM2dO1djx4497WfnzJmjwsJC3XjjjRVa5jXXXKP4+HhNnDhRq1ev1rvvvqvw8HA9//zztjKOXAvKOs+VZdiwYXriiSeUmppq9xD122+/ad++fRo+fLgk2RKwnTp1svt8gwYN1LBhw1ITtNWpIserdPrjSzrxq+QzzzyjSy65RJdccolWr16tfv362f3YdKZkZmZqwIABuvLKK3XNNdfoiy++0MMPP6y2bdtq4MCB8vf31xVXXKEZM2Zo0qRJdrWGP/30UxljdP3111cphsps08jISD355JNavny53n77bQUFBWnp0qWKiYnRhAkTNHv2bL344otq06aNRowYYftsRc41s2fPVkJCQrn7bUX89ttv+uqrr3TnnXeqbt26+t///qerrrpKKSkpqlevnnr37q3o6GhNnz7dds9abPr06WrcuLFdTajKqMg5sKioSAMHDlTPnj31wgsvaPr06br77rvl5+enxx57TNdff72uvPJKvfnmmxoxYoS6deum+Ph4SSd+vPrmm2909dVXKz4+XmlpaXrrrbfUq1cvbdq0SQ0aNKjSelS3oqIi27m2oKBAmzdvtv3wd/7551d6vqf7zq+88kr99ddfJZq8FdcEevbZZ/Xf//5X11xzjW699VYdPHhQU6ZMUc+ePbVmzRq7h+tDhw5p4MCBGj58uG644Qa7/Xb69OnKz8/XPffco4yMDL3wwgu65pprdNFFF2nhwoV6+OGHtX37dk2ZMkUPPPCAXRLho48+0siRI9W/f389//zzOnbsmKZOnaoLLrhAa9assT0g//jjj7rqqqvUqlUrTZw4UYcOHdKoUaMcagbryDngdM8MjsZZmvz8fPXv3195eXm288vevXv1ww8/KCsrS4GBgdXyPFzs2WeflcVi0cMPP6wDBw5o8uTJ6tu3r9auXVvtLVL++9//KjIyUrfffruefvrpcstmZWWpoKBAqampmjx5snJyctSnT59qiWPHjh266KKLFBISop9++smueWd5Dh06pKKiIqWkpNiet6orphJMBfz444/G3d3duLu7m27dupmHHnrIzJs3z+Tn59uVW7t2rZFkbr31VrvpDzzwgJFkfvnlF9u02NhYI8nMnTu3xPL8/PzMyJEjS0y/5ZZbTP369U16errd9OHDh5vAwEBz7NgxY4wxkydPNpLM559/bitz9OhR06RJEyPJLFiwoNz1HTFihHFzczN//PFHifesVqsxxpj777/fSDKLFy+2vXf48GETHx9v4uLiTFFRkTHGmMsvv9y0bt263OVNmzbNSDK7du2yTSvePosWLbJNO3DggPHy8jL/+c9/bNOefvpp4+fnZ/766y+7eT7yyCPG3d3dpKSklLncr7/+2kgqdT1PJsmMHz/e9vf48eONJHPbbbfZphUWFpqGDRsai8VinnvuOdv0zMxM4+PjY/d97tq1y0gy06ZNKzHPkxV/nyfr37+/adSokd208val2NhYu2XPnDmzzH2gV69eplevXra/P/roI+Pm5mb3HRtjzJtvvmkkmSVLlhhjjHnllVeMJHPw4MES86yMkSNHGknmnnvusU2zWq1m0KBBxtPT07acxYsXG0lm+vTpdp+fO3duiemtW7e2W7did911l4mIiLD9PWbMGNOzZ08THh5upk6daowx5tChQ8ZisZhXX33VFkvTpk1N//79bceDMSe+r/j4eHPxxRfbpjl6zC5YsMBIMi1btjR5eXm2cq+++qqRZNavX+/Yxvt7nco6xY0cOdLExsba/i7eF+vVq2cyMjJs07/99lsjyXz//fe2addee61p0KCB7dg2xpjVq1eX2JdHjhxp/Pz8yo2xtGO+tP399ttvN76+vub48eO2ab169TKSzCeffGKbtmXLFiPJuLm5meXLl9umz5s3r0R8pS1n2bJlRpL58MMP7abPnz+/RJwnK2u/MqbksVe8zn379rXbb/79738bd3d3k5WVZYwxpqioyDRs2NAMGzbMbn6TJk0yFovF7Ny5024ZgwYNKnX5xU79zo0puQ3y8/NNmzZtzEUXXWQ3XZLx8vKyW/+33nrLSDKRkZEmJyfHNn3s2LEOfacTJ040FovFJCcnlxv3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Wz+c5anI83CxU7eTxWJRkyZNbM8TR44csRu9zd3dvcKdWM+YMUNLly4tdXjqspzcDHL48OG2Z+ji54/KuOyyyxQREaF58+bJ39/f7j1H1rO4L7mBAwfq8ssvV5s2beTv72/3A3l1qXQX3J6enurcubM6d+6sZs2aadSoUZo5c6ZdO35HxyCvyAmwuMbBDTfcUOZDoKNDSTlTy5YttXXrVv3www+aO3euvvzyS73xxhsaN26cnnzyyXI/W9YJ9+SThtVq1cUXX6yHHnqo1LLFD/ClsVgs+uKLL7R8+XJ9//33mjdvnm6++Wa9/PLLWr58eYmd2JH4HInZETt27FCfPn3UokULTZo0SdHR0fL09NTs2bP1yiuvlKiBciYuplarVW3bttWkSZNKfb/4ouLj46NFixZpwYIFmjVrlubOnasZM2booosu0o8//njGRsqyWq0KDw+3+/XwZI6cSBs0aKD4+HgtWrRIcXFxMsaoW7duCgsL03333afk5GQtXrxY3bt3tyWWirf9iy++qA4dOpQ6X39/f1sCriLHbHXtPxXlyHLd3d113XXX6Z133tEbb7yhJUuWaN++fdXy62FWVpZ69eqlgIAAPfXUU2rcuLG8vb21evVqPfzwwyX297LidWQ97rnnHk2bNk3333+/unXrpsDAQFksFg0fPtxuObt27dKWLVscGrq3IhyJsVWrVkpISNDHH3+sESNG6OOPP5anp6fdr6OVtXjxYg0ePFg9e/bUG2+8ofr168vDw0PTpk0r0SlkefGebj2Kiop08cUXKyMjQw8//LBatGghPz8/7d27VzfddJNtW8+YMaPEr4tnen+viD59+ui1117TokWL1LZtW91333364IMPbO/36tVLCxcutI0otH79+jLPC6U53Xas6LXgVLt37y6RrF+wYIF69+6tYcOGaezYsZo5c6buv/9+ff755woMDNSAAQNsZevXry/pxC+xpz5I7N+/39Y/1pni6PFazFXnUEc5Gt+IESP04osv6ptvvtG1116rTz75RJdeeulpH1QcUV3btLTpJ69HRc41s2fP1oABAxy+f3ZERbb1fffdpz179igvL0/Lly/Xa6+9VuXlO3oOPF28jqzHhAkT9N///lc333yznn76aYWEhMjNzU3333+/3XKKj+di06ZNs+sU1ZUSEhIUGBhoq9G+dOnSEp2MF4/4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37/fdk5t1KiRXYyVGdHr66+/LvEqvp5++OGHeuWVV2xlS+tGISkpSfPnz69yU02LxaK3335bQ4cO1ciRI+36ti1rPQsLC0v9MWLFihVav359tTYfPVmF7q7vueceHTt2TFdccYVatGih/Px8LV26VDNmzFBcXJytClb79u01cuRIvf3227Zq9ytWrNAHH3ygIUOGlKhuV5aEhAT9/PPPmjRpkq0ZRWJiop577jktWLBAiYmJGj16tFq1aqWMjAytXr1aP//8s+2hePTo0Xrttdc0YsQIrVq1SvXr19dHH31UYrjCskyYMEE//vijevXqZRvSeP/+/Zo5c6Z+++03BQUF6ZFHHtGnn36qgQMH6t5771VISIg++OAD7dq1S19++aWtSUe/fv0UGRmp888/XxEREdq8ebNee+01DRo0qFr6mXjwwQf13Xff6dJLL7UNe3306FGtX79eX3zxhZKSksq8qH7wwQd64403dMUVV6hx48Y6fPiw3nnnHQUEBNgSa67Sr18/eXp66rLLLtPtt9+uI0eO6J133lF4eLitJlZldOjQQe7u7nr++eeVnZ0tLy8vXXTRRaX2u3LjjTfq888/17/+9S8tWLBA559/voqKirRlyxZ9/vnnmjdvnjp16qSnnnpKixYt0qBBgxQbG6sDBw7ojTfeUMOGDe0ysL1799avv/7qUHVRb29vzZ07VyNHjlRiYqLmzJmjWbNm6dFHH7U1P+rVq5duv/12TZw4UWvXrlW/fv3k4eGhbdu2aebMmXr11VdtDwoJCQmaOnWqnnnmGTVp0kTh4eG2tq7FiZatW7faDWHcs2dPzZkzR15eXurcubNtupubm959910NHDhQrVu31qhRoxQVFaW9e/dqwYIFCggIsD3AOXrM1iQjRozQAw88IEllJggKCgpsv2ycLCQkRHfeeWeJ6d27d1dwcLBGjhype++9VxaLRR999NEZaVpw6aWX6qOPPlJgYKBatWqlZcuW6eeff7ZrV5+bm6sFCxZUWx8tlREWFqYBAwZo5syZCgoKKjOZv3379lK3dceOHUv9zKBBgzRp0iQNGDBA1113nQ4cOKDXX39dTZo0seu3oqpatGihxo0b64EHHtDevXsVEBCgL7/8skK1D7Kzs22JjSVLlkg6kaQNCgpSUFCQ3S/pxUnak6vcJicn66OPPpIk248LxdsqNja2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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(sorted_similarities)\n",
    "plt.title(f\"Sorted cosine similarities, between {model_name} and {base_model_name}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Compute the l2 norm of the difference between the embeddings\n",
    "l2_diff = torch.norm(embed - base_embed, dim=-1, p=2)\n",
    "l2_diff = l2_diff.cpu().detach().numpy()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "sorted_l2_diff = np.sort(l2_diff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Sorted L2 distances, between TinyLlama/TinyLlama-1.1B-Chat-v0.1 and TinyLlama/TinyLlama-1.1B-intermediate-step-1431k-3T')"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDYAAAGzCAYAAADUlpeAAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAdOhJREFUeJzt3Xd4k1XjxvE7LW2605bSXaAM2YIiUxnKFkWcgANExQWK4gQVXidu8UXF9RMUwYGI+spQRBAVHAgoQ5BdVsvsgO7m/P4oiYQOUiiEpt/PdfVq++RJcp4nycnJnTMsxhgjAAAAAACAKsjH0wUAAAAAAAA4UQQbAAAAAACgyiLYAAAAAAAAVRbBBgAAAAAAqLIINgAAAAAAQJVFsAEAAAAAAKosgg0AAAAAAFBlEWwAAAAAAIAqi2ADAAAAAABUWdUy2Fi0aJEsFosWLVrk6aKUacqUKbJYLNq6datzW9euXdW1a1ePlakqu/HGGxUSEuLpYnilG2+8UXXr1vV0MUp9zXibunXr6sYbb/R0Mc6Yxxyu/vOf/8hisWjfvn2eLgqOqMzX7JnUdrFYLPrPf/7j6WKcMo7XkqedSY+5tztTHvMzUWnv+d5eB6BqtikqHGysWrVKV111lerUqaOAgAAlJCSoR48emjhxYqUX7plnntEXX3xR6bfrLscHpWXLlpW5z/bt2/X444+rbdu2ioiIUFRUlLp27arvvvvuNJa0bEuWLNF//vMfpaene7ooXueNN97QlClTPF2MU8Jisbj1c7oaW94YTLVu3VpNmzZ1+1yfLnXr1tUll1xy2u7vdFu/fr3uvfdedezYUQEBARUOw3777Tfdeeedat26tfz8/Mp8bLZu3VriMQwLC1OrVq302muvqaioyO37LCoq0uTJk9W1a1dFRkbKarWqbt26Gjp0aLnvT5XhVNZzX331lc4991wFBASodu3aGjdunAoLC9267tNPP61+/fopJiamSjewb7zxRrde/6cr0HR8kP7ss89Oy/2dDhMnTpTNZlNCQoJb5/p0va9XxQ8NFXUyr9NDhw5p3Lhx6t27tyIjI8t9bLp27eryGPr7+ys5OVm33nqrtm/fXjkHUw7a2u5bu3at/vOf/3jsSyhPf7aU3G9HHOunn35yPsePrTdmzZqlXr16KT4+XlarVYmJibrqqqu0evXqErfzySef6Prrr1fDhg1lsVhO2Zfm77zzjrp06aKYmBhZrVYlJydr6NChJb60d6dedrfuqFGRAi5ZskQXXnihateurWHDhik2Nlbbt2/XL7/8oldffVV33XVXRW7uuJ555hldddVV6t+/f6XebmX68ssv9dxzz6l///4aMmSICgsL9cEHH6hHjx567733NHTo0Eq7r2+//bbC11myZIkef/xx3XjjjQoPD6+0sqC4wR8VFXVGfINe2aZOnery/wcffKD58+eX2N6kSRO98847stvtp7N4Vd7u3bu1YsUKTZ48Wb6+vi6XjR49WiEhIXrkkUdKXG/9+vXy8amWHe0qzdKlS/Xf//5XTZs2VZMmTbRy5coKXX/OnDl69913dfbZZ6tevXr6559/yt1/0KBBuvjiiyVJGRkZmjNnju666y5t27ZNL7zwwnHvLycnR1dccYXmzZunzp07a8yYMYqMjNTWrVv16aef6v3331dKSooSExMrdBzuOlX13Ny5c9W/f3917dpVEydO1KpVq/TUU09pz549mjRp0nGv/+ijjyo2NlbnnHOOvvnmm0ot2+l02223qXv37s7/t2zZorFjx+rWW29Vp06dnNvr16+vdu3aKScnR/7+/p4oapU1e/Zs9ezZU9ddd50OHTrk3D5nzhx99NFHeuWVVxQVFeXc3rFjR11//fV6+OGHPVFcr3Iyr9N9+/bpiSeeUO3atdWyZcvjfpGSmJio8ePHS5Ly8/O1du1avfnmm/rmm2/0999/Kygo6LhlPdHHvDq2tXNyclSjRoU+RkoqDjYef/xxde3a1SM9P8+Ez5YVbUdIkt1u11133aXg4GAdPny4xOWrVq1SRESERo4cqaioKKWmpuq9995T27ZttXTpUrVs2dK576RJk/THH3+oTZs22r9/f6Ue29FWrFih5ORk9evXTxEREdqyZYveeecdff311/rzzz8VHx+vRx55RLfccovzOr///rv++9//asyYMWrSpIlz+9lnn+3WfVboGfn000/LZrPp999/L/HC3bNnT0VuqkzGGOXm5iowMLBSbu9Uu/DCC5WSkuLypnj77berVatWGjt2bKUGGzRmcLpcf/31Lv//8ssvmj9/fontODFz585VQECArrnmmhJ13bPPPquoqKhSz7XVaj1dRfRa/fr1U3p6ukJDQ/Xiiy9WONi444479NBDDykwMFAjRow4boPk3HPPdXks77zzTrVr107Tp093K9h44IEHNG/ePL3yyiu65557XC4bN26cXnnllQqV/0xx//336+yzz9a3337rbByHhYXpmWee0ciRI9W4ceNyr79lyxbVrVtX+/btU61atU5HkU+JDh06qEOHDs7/ly1bprFjx6pDhw6l1gEBAQGns3hVXnZ2tn744QdNmjSpxAeZ1NRUffTRR+rfv3+pH7BO5EMbXJ3M6zQuLk67d+9WbGysli1bpjZt2pS7v81mK/GaSU5O1ogRI/Tzzz+rR48e5V6/Ro0aZ9xjnp2dfdxAxlOoi05cRdsRkvT2229r+/btuuWWW/Tqq6+WuHzs2LEltt1yyy1KTEzUpEmT9Oabbzq3T506VQkJCfLx8VHz5s1P7mDK8cYbb5TY1r9/f5133nn64IMP9PDDD5d4XQYEBOi///2vevTocUI9SSr01d+mTZvUrFmzUtPI6Ohol/8LCwv15JNPqn79+s5us2PGjFFeXp7Lfo5uz998843OO+88BQYG6q233pLFYtHhw4f1/vvvl9oVc+fOnbrpppuc3VuaNWum9957r0S5duzYof79+ys4OFjR0dG69957S5ThZDRr1swl1JCKP3xcfPHF2rFjh7Kyso57G2vWrNFFF12kwMBAJSYm6qmnnir1G/DS5tiYOHGimjVrpqCgIEVEROi8887T9OnTJRV3c3zggQckFVfujvPo6AI0efJkXXTRRYqOjpbValXTpk1L/abM8Rj99NNPatu2rQICAlSvXj198MEHJfZNT0/Xvffeq7p16zq7Qg0ePNily1ReXp7GjRunBg0ayGq1KikpSQ8++GCJx2X+/Pm64IILFB4erpCQEDVq1Ehjxow57vksz+bNm9WrVy8FBwcrPj5eTzzxhIwxLvvY7XZNmDBBzZo1U0BAgGJiYnTbbbfp4MGDLudkzZo1+uGHH5zntWvXrkpPT5evr6/++9//Ovfdt2+ffHx8VLNmTZf7uuOOOxQbG+ty37/++qt69+4tm82moKAgdenSRT///HOJ43Dn+e/oUvzpp5/q6aefVmJiogICAtStWzdt3LjxpM7j0Y4de+nogv/iiy/q7bffdtYBbdq00e+//+7cb/LkybJYLFqxYkWJ23zmmWfk6+urnTt3nlTZvvzyS/Xt29fZNa9+/fp68sknSwwD6Nq1q5o3b66//vpLXbp0UVBQkBo0aODsjv3DDz+oXbt2CgwMVKNGjUoMNdu2bZvuvPNONWrUSIGBgapZs6auvvrqMrtazp49WxdeeGGFA9xjx+s7hsv9/PPPGjVqlGrVqqXg4GBdfvnl2rt3r3O/IUOGKCoqSgUFBSVus2fPnmrUqFGFylGaF198UR07dlTNmjUVGBio1q1bl9qd3WKxaMSIEZoxY4aaNm2qwMBAdejQQatWrZIkvfXWW2rQoIECAgLUtWvXEufwxx9/1NVXX63atWs76497771XOTk5bpUzMjJSoaGhJ3ycMTExJxW8WywWxcTEuNWA3rFjh9566y316NGjRKghSb6+vrr//vtL9NZIT093fnNos9k0dOhQZWdnu+zjTv1fVj1XlubNm+vCCy8ssd1utyshIUFXXXWVpOJv7NauXatbb73V5TzceeedMsa4NQziZL7pc/f16u7rSyr+Uuapp55SYmKigoKCdOGFF2rNmjUnXMbSlDbfgqPuWrt2rS688EIFBQUpISFBzz//vHOfQ4cOKTg4WCNHjixxmzt27JCvr6/zm+4TVdFz+tNPP+nuu+9WrVq1FB4erttuu035+flKT0/X4MGDFRERoYiICD344IMl3qPdrWskacGCBcrLy1OfPn0qdDylzbfgqLu++OILNW/e3PneO2/ePOc+CxculMVi0axZs0rc5vTp02WxWLR06dIKleVY7taBjiGcKSkpuuSSSxQSEqKEhAS9/vrrkoq/4b3ooosUHBysOnXqONuODgcOHND999+vFi1aKCQkRGFhYerTp4/+/PNPt8t6Mq9Tq9Vaoo1UUY7ru1Pfnuhjfry2tiR9+OGHat26tQIDAxUZGamBAweWGCLjeC3/8ccf6ty5s4KCgjRmzBiXNtXrr7+uevXqKSgoSD179tT27dtljNGTTz6pxMREBQYG6rLLLtOBAwdKHN/cuXPVqVMnBQcHKzQ0VH379i21jnIca0BAgJo3b17qc9lxbo4eHuBOHTBlyhRdffXVkoq/GC5tWLO75SzNhg0bdOWVVyo2NlYBAQFKTEzUwIEDlZGR4SzzyX62dNTDn3zyicaMGaPY2FgFBwerX79+bg97qmg74sCBA3r00Uf1xBNPVKhHUHR0tIKCgkoMkUpKSjrh3r/btm1TgwYN1Lx5c6WlpVX4+o464VQN26pQNFmnTh0tXbpUq1evPm7Cc8stt+j999/XVVddpfvuu0+//vqrxo8fr7///rvEi2T9+vUaNGiQbrvtNg0bNkyNGjXS1KlTdcstt6ht27a69dZbJRV3xZSktLQ0tW/f3lnh1KpVS3PnztXNN9+szMxMZwMwJydH3bp1U0pKiu6++27Fx8dr6tSp+v777yty2CckNTVVQUFBx01aU1NTdeGFF6qwsFAPP/ywgoOD9fbbb7v1hH/nnXd0991366qrrtLIkSOVm5urv/76S7/++quuvfZaXXHFFfrnn39KdLV0pOaTJk1Ss2bN1K9fP9WoUUP/+9//dOedd8put2v48OEu97Vx40ZdddVVuvnmmzVkyBC99957uvHGG9W6dWs1a9ZMUnHjqVOnTvr7779100036dxzz9W+ffv01VdfaceOHYqKipLdble/fv30008/6dZbb1WTJk20atUqvfLKK/rnn3+c497WrFmjSy65RGeffbaeeOIJWa1Wbdy4sdQP+e4qKipS79691b59ez3//POaN2+ec0z3E0884dzvtttu05QpUzR06FDdfffd2rJli1577TWtWLFCP//8s/z8/DRhwgTdddddLkMGYmJiFB4erubNm2vx4sW6++67Jf07Ju7AgQNau3at83z9+OOPLl2Nv//+e/Xp00etW7fWuHHj5OPj4/zw8eOPP6pt27aS3H/+Ozz77LPy8fHR/fffr4yMDD3//PO67rrr9Ouvv57wuXTH9OnTlZWVpdtuu00Wi0XPP/+8rrjiCm3evFl+fn666qqrNHz4cE2bNk3nnHOOy3WnTZumrl27KiEh4aTKMGXKFIWEhGjUqFEKCQnR999/r7FjxyozM7PEt+UHDx7UJZdcooEDB+rqq6/WpEmTNHDgQE2bNk333HOPbr/9dl177bV64YUXdNVVV2n79u3OD8i///67lixZooEDByoxMVFbt27VpEmT1LVrV61du9alHigoKNB3332nZ5555qSO7Wh33XWXIiIiNG7cOG3dulUTJkzQiBEj9Mknn0iSbrjhBn3wwQf65ptvXObPSE1N1ffff69x48addBleffVV9evXT9ddd53y8/P18ccf6+qrr9bXX3+tvn37uuz7448/6quvvnLWM+PHj9cll1yiBx98UG+88YbuvPNOHTx4UM8//7xuuukmlzp7xowZys7O1h133KGaNWvqt99+08SJE7Vjxw7NmDHjpI+jsmVnZzuD3czMTM2dO1fz5s3T6NGjj3vduXPnqrCwUDfccEOF7vOaa65RcnKyxo8fr+XLl+vdd99VdHS0nnvuOec+7tT/ZdVzZRkwYID+85//KDU11eUDyU8//aRdu3Zp4MCBkuQMM8877zyX68fHxysxMbHUsLMyVeT1Kh3/9SUVf1v21FNP6eKLL9bFF1+s5cuXq2fPnsrPzz+lxyIV1129e/fWFVdcoWuuuUafffaZHnroIbVo0UJ9+vRRSEiILr/8cn3yySd6+eWXXYa/ffTRRzLG6LrrrjupMpzIOY2NjdXjjz+uX375RW+//bbCw8O1ZMkS1a5dW88884zmzJmjF154Qc2bN9fgwYOd161IXTNnzhy1bt263OdtRfz000/6/PPPdeeddyo0NFT//e9/deWVVyolJUU1a9ZU165dlZSUpGnTpunyyy93ue60adNUv359lx46J6IidWBRUZH69Omjzp076/nnn9e0adM0YsQIBQcH65FHHtF1112nK664Qm+++aYGDx6sDh06KDk5WVLxF0FffPGFrr76aiUnJystLU1vvfWWunTporVr1yo+Pv6kjqOyFRUVOevagoIC/f33384v0c4///wTvt3jPebHa2s//fTTeuyxx3TNNdfolltu0d69ezVx4kR17txZK1ascPmgun//fvXp00cDBw7U9ddf7/K8nTZtmvLz83XXXXfpwIEDev7553XNNdfooosu0qJFi/TQQw9p48aNmjhxou6//36XD+RTp07VkCFD1KtXLz333HPKzs7WpEmTdMEFF2jFihXOD5vffvutrrzySjVt2lTjx4/X/v37NXToULeGOrpTB3Tu3Fl33313iaEGjt/ulrM0+fn56tWrl/Ly8pz1y86dO/X1118rPT1dNputUj5bOjz99NOyWCx66KGHtGfPHk2YMEHdu3fXypUrK33UwWOPPabY2FjddtttevLJJ8vdNz09XQUFBUpNTdWECROUmZmpbt26VUo5Nm3apIsuukiRkZGaP39+iS/2y7J//34VFRUpJSXF+XmrsspUgqmAb7/91vj6+hpfX1/ToUMH8+CDD5pvvvnG5Ofnu+y3cuVKI8nccsstLtvvv/9+I8l8//33zm116tQxksy8efNK3F9wcLAZMmRIie0333yziYuLM/v27XPZPnDgQGOz2Ux2drYxxpgJEyYYSebTTz917nP48GHToEEDI8ksXLiw3OOdPHmykWR+//33cvc71oYNG0xAQIC54YYbjrvvPffcYySZX3/91bltz549xmazGUlmy5Ytzu1dunQxXbp0cf5/2WWXmWbNmpV7+y+88EKJ23FwnKej9erVy9SrV89lm+MxWrx4sUsZrVarue+++5zbxo4daySZzz//vMTt2u12Y4wxU6dONT4+PubHH390ufzNN980kszPP/9sjDHmlVdeMZLM3r17yz0+dw0ZMsRIMnfddZdLmfr27Wv8/f2d9/Pjjz8aSWbatGku1583b16J7c2aNXN5PByGDx9uYmJinP+PGjXKdO7c2URHR5tJkyYZY4zZv3+/sVgs5tVXX3WWpWHDhqZXr17Oc2VM8WOUnJxsevTo4dzm7vN/4cKFRpJp0qSJycvLc+736quvGklm1apV7p28I8dUVnUxZMgQU6dOHef/W7ZsMZJMzZo1zYEDB5zbv/zySyPJ/O9//3NuGzRokImPjzdFRUXObcuXLzeSzOTJk13uIzg4uNwyOl6vRz/XS3uO33bbbSYoKMjk5uY6t3Xp0sVIMtOnT3duW7dunZFkfHx8zC+//OLc/s0335QoX2n3s3TpUiPJfPDBBy7bFyxYUOZr0piyn1fGFL8Wj64THcfcvXt3l+fNvffea3x9fU16eroxxpiioiKTmJhoBgwY4HJ7L7/8srFYLGbz5s0u99G3b99S79/h2MfcmJLnID8/3zRv3txcdNFFLtslGavV6nL8b731lpFkYmNjTWZmpnP76NGj3XpMx48fbywWi9m2bVu55T5WefWjO8p7XTheB6X93HHHHS6PV1nuvfdeI8msWLHCrfKMGzfOSDI33XSTy/bLL7/c1KxZ02Wbu/V/ec/HY61fv95IMhMnTnTZfuedd5qQkBDnfTrOe0pKSonbaNOmjWnfvr1b92eMMXv37jWSzLhx49y+jruvV3dfX3v27DH+/v6mb9++LvuNGTPGSCq1HVOW33//vUT94uCo049uuzjqrqPLnZeXZ2JjY82VV17p3Oaot+bOnetym2effbbL4+u4jxkzZpRbzmPPeUXP6bHvdR06dDAWi8Xcfvvtzm2FhYUmMTGxxPPP3brGGGNq165d5nOjvNe/47V0NEnG39/fbNy40bntzz//LPGcHz16tLFarc7nhzHFz5EaNWq4lMVxH+W1c0p7zN2tAx3tnmeeeca57eDBgyYwMNBYLBbz8ccfO7c73u+OLl9ubq7Le7MxxfWa1Wo1TzzxRJllLs2JvE6PVt7rwph/XwfH/jRp0sTl/a08J/OYl/Vc2rp1q/H19TVPP/20y/ZVq1aZGjVquGx3HMObb77psq/jvaRWrVouzynH+2PLli1NQUGBc/ugQYOMv7+/s42TlZVlwsPDzbBhw1xuNzU11dhsNpftrVq1MnFxcS738+233xpJJd7zT7QOmDFjRqmfwSpSztKsWLHCrbrrZD9bOl6TCQkJLu2VTz/91EhytuvdVV47wpji55uvr6/55ptvjDHHrzcaNWrkfP6HhISYRx99tMTr+GjlvccffV9///23iY+PN23atHFp27vDarU6y1SzZk3z3//+t8x9y3p+uKtC/VB69OihpUuXql+/fvrzzz/1/PPPq1evXkpISNBXX33l3G/OnDmSpFGjRrlc/7777pNU3A37aMnJyerVq5dbZTDGaObMmbr00ktljNG+ffucP7169VJGRoaWL1/uLEdcXJyz+6skBQUFOVO6UyE7O1tXX321AgMD9eyzzx53/zlz5qh9+/bOb+Ol4pTXnW9PwsPDtWPHDpfu/RVxdKKYkZGhffv2qUuXLtq8ebOz25ZD06ZNXXoX1KpVS40aNdLmzZud22bOnKmWLVuW+JZCkrN734wZM9SkSRM1btzY5bG76KKLJBV343Qcm1Q8lKAyJ6YcMWKES5lGjBih/Px859CCGTNmyGazqUePHi7la926tUJCQpzlK0+nTp2Ulpam9evXSyr+drpz587q1KmTfvzxR0nF3wAYY5zndOXKldqwYYOuvfZa7d+/33m/hw8fVrdu3bR48WLZ7fYKPf8dhg4d6jI/i+M+j37sToUBAwYoIiKi3PsdPHiwdu3a5XJep02bpsDAQF155ZUnXYajn+NZWVnat2+fOnXqpOzsbK1bt85l35CQEOc3ypLUqFEjhYeHq0mTJmrXrp1zu+Pvo4/j6PspKCjQ/v371aBBA4WHh5d4PObMmaOmTZtW6qRZt956q0sX2k6dOqmoqEjbtm2TJPn4+Oi6667TV1995TI8btq0aerYsaPzG7qTcfQ5OHjwoDIyMtSpU6cSxy8VJ/VHH7/jnF555ZUuw0SOd64PHz6sffv2qWPHjjLGnPJv+k/Erbfeqvnz52v+/PmaOXOmhg8frrfeeqvE+2NpMjMzJanCQ2duv/12l/87deqk/fv3O29Pqlj9766zzjpLrVq1cunJUFRUpM8++0yXXnqp8z4dXeZLmzMmICDA7WFFJ6oir1fp+K+v7777zvlN6tH7lTZ86FQICQlxmVvA399fbdu2dXnddO/eXfHx8Zo2bZpz2+rVq/XXX39VytxJFT2nN998s8u5ateunYwxuvnmm53bfH19dd5555V4r3K3rlm9erVSUlJK9OI4Gd27d3d+wysVT2gXFhZW4n0tLy/PZXjMJ598osLCwko/1+7UgUdPzBceHq5GjRopODhY11xzjXO74/3u6OOwWq3O7upFRUXav3+/c1hwaY+pp9WtW9dZ186dO1cTJkxQRkaG+vTpU2LoWEW485iX5fPPP5fdbtc111zj0l6LjY1Vw4YNS7QprVZrmXPzXX311bLZbM7/He+P119/vctQm3bt2ik/P985lHf+/PlKT0/XoEGDXMrg6+urdu3aOcuwe/durVy5UkOGDHG5nx49eqhp06bHPdaK1gHHcrecZXGU+Ztvvikx9PJ4TqRtPXjwYJf35quuukpxcXHOz8CV5e6771afPn3Us2dPt/afPHmy5s2bpzfeeENNmjRRTk5OhVZhK83q1avVpUsX1a1bV999951L294dc+fO1Zw5c/TSSy+pdu3apU5+WlkqPEtOmzZt9Pnnnys/P19//vmnZs2apVdeeUVXXXWVVq5cqaZNm2rbtm3y8fFRgwYNXK4bGxur8PBwZ2PAoSKN6r179yo9PV1vv/223n777VL3cUxk6hgHdOyYucoYT16aoqIiDRw4UGvXrtXcuXPd6qa3bds2lw9NDu6U8aGHHtJ3332ntm3bqkGDBurZs6euvfZat7vc/fzzzxo3bpyWLl1aohLIyMhwqdhq165d4voREREu805s2rTpuB9GN2zYoL///rvMSaQcj92AAQP07rvv6pZbbtHDDz+sbt266YorrtBVV111wuPCfHx8VK9ePZdtZ511liQ5xwBu2LBBGRkZJeaMObZ85XF8gP/xxx+d3aqfeuop1apVSy+++KLzsrCwMOcsxRs2bJBUPBdCWTIyMlRQUOD289/h2MfOUSEd/didCu7cb48ePRQXF6dp06apW7dustvt+uijj3TZZZed1DwIDmvWrNGjjz6q77//3uVDnaQSH94SExNL1BU2m01JSUklth17HDk5ORo/frwmT56snTt3uowJP/Z+Zs+erUsvvfTED6oU7pzrwYMH67nnntOsWbM0ePBgrV+/Xn/88YfLhFIn4+uvv9ZTTz2llStXusyXU9oyZseW13FO3TnXKSkpGjt2rL766qsSz2HHuc7JySlx3k92rPaJatiwocuqF1dccYUsFosmTJigm266SS1atFBGRobLh3l/f39FRkYqLCxMktyaq+lo5T0fHLdZkfr/WEVFRSU+KERGRsrf318DBgzQmDFjtHPnTiUkJGjRokXas2ePBgwY4NzX0QAubb6r0zF5eEVer9LxX1+ONk3Dhg1d9qtVq1aFG4AnorS6KyIiQn/99Zfzf0e4OWnSJOeEhNOmTVNAQIBzzPvJONlzWl4dcOzr3N26Zvbs2YqJiSkx5OlkuNMWaty4sdq0aaNp06Y5g5pp06apffv2JdrFJ8KdOtAhICCgRHvLZrOV+X539O3Z7Xa9+uqreuONN7RlyxaXD0c1a9Z0/p2amlridjyxAEBwcLBLXdu7d29dcMEFOu+88/Tss8/qpZdeUn5+fon5J2rVqlVidbKjufOYl2XDhg0yxpSoGxz8/Pxc/k9ISChzoYATfd90tC8dXyAey/GeUFY9JsmtMKuidcCx3C1nWe/vycnJGjVqlF5++WVNmzZNnTp1Ur9+/XT99deX+34mVeyzpcOx58lisahBgwbOzxOHDh1yWYXJ19e3whPofvLJJ1qyZEmpS7aW5eihbgMHDnQO83F8/jgRl156qWJiYvTNN98oJCTE5TJ3jtMx91afPn102WWXqXnz5goJCXH5srmynPD0v/7+/mrTpo3atGmjs846S0OHDtWMGTNcxmq7uy5vRSpAx7f3119/fZkfAt1dEqayDRs2TF9//bWmTZtW5guzMjVp0kTr16/X119/rXnz5mnmzJl64403NHbsWD3++OPlXnfTpk3q1q2bGjdurJdffllJSUny9/fXnDlz9Morr5ToJVFWpX90xeUOu92uFi1a6OWXXy71ckcFHRgYqMWLF2vhwoWaPXu25s2bp08++UQXXXSRvv3223LfhE6G3W5XdHS0y7daR3OnUoqPj1dycrIWL16sunXryhijDh06qFatWho5cqS2bdumH3/8UR07dnSGNI7z/cILL6hVq1al3m5ISIhzWaaKPP8r67GrKHfu19fXV9dee63eeecdvfHGG/r555+1a9euSvlWKz09XV26dFFYWJieeOIJ1a9fXwEBAVq+fLkeeught5/j7hzHXXfdpcmTJ+uee+5Rhw4dZLPZZLFYNHDgQJf72bJli9atW+fWcpYV4U4ZmzZtqtatW+vDDz/U4MGD9eGHH8rf39/lW7sT9eOPP6pfv37q3Lmz3njjDcXFxcnPz0+TJ08uMSFdeeU93nEUFRWpR48eOnDggB566CE1btxYwcHB2rlzp2688Ubnuf7kk09KfOt1qp/vFdGtWze99tprWrx4sVq0aKGRI0fq/fffd17epUsXLVq0yLkyyKpVq8qsF0pzvPNY0fr/WNu3by/xhcTChQvVtWtXDRgwQKNHj9aMGTN0zz336NNPP5XNZlPv3r2d+8bFxUkq/obw2Eb57t27XXowngruvl4dPFWHusvd8g0ePFgvvPCCvvjiCw0aNEjTp0/XJZdcctxGvzsq65yWtv3o46hIXTNnzhz17t3b7baoOypyrkeOHKkdO3YoLy9Pv/zyi1577bWTvn9368Djlded43jmmWf02GOP6aabbtKTTz6pyMhI+fj46J577nG5H8fr2WHy5MmVvjz0iWrdurVsNpsWL14sqXhZ1mMnOHas3FKWk3n92+12WSwWzZ07t9TbOfZDYnmfh070sXQ8VlOnTi014K+slWAqWgccy91ylvf+/tJLL+nGG2/Ul19+qW+//VZ33323xo8fr19++aXceUJOxWfLF1980eWzWJ06dcqcUL4sDzzwgK6++mr5+/s7r+uYdHP79u3Kz88v90v0iIgIXXTRRZo2bdpJBRtXXnml3n//fU2bNk233Xaby2UVPc769evrnHPOcc73U9kq5dnsSMN3794tqfig7Ha7NmzY4LIGbVpamtLT01WnTh23bre0N6NatWopNDRURUVFLslsaerUqaPVq1fLGONyW44hApXpgQce0OTJkzVhwgQNGjTI7evVqVPHmVIezd0yBgcHa8CAARowYIDy8/N1xRVX6Omnn9bo0aMVEBBQ5hv6//73P+Xl5emrr75ySYHdGWpRlvr16x83Vaxfv77+/PNPdevW7biNDR8fH3Xr1k3dunXTyy+/rGeeeUaPPPKIFi5ceNzHvjR2u12bN2929tKQ5FxiyfGmVr9+fX333Xc6//zzjxu4lVf+Tp06afHixUpOTlarVq0UGhqqli1bymazad68eVq+fLlLReDo5hgWFlbusVXk+V9VDB48WC+99JL+97//ae7cuapVq5bbQ9PKs2jRIu3fv1+ff/65Onfu7Ny+ZcuWk77tY3322WcaMmSIXnrpJee23NzcErM+z549WzabTRdccEGll8EdgwcP1qhRo7R7925Nnz5dffv2rZRvlGfOnKmAgAB98803LsMLJk+efNK3fbRVq1bpn3/+0fvvv+8ymeD8+fNd9uvVq1eJbWeSwsJCSXJ+y/Hggw+6hHmOx6RPnz7y9fXVhx9+WOEJRMtTkfq/tHouNja2xPl19D5LTk5W27Zt9cknn2jEiBH6/PPP1b9/f5fnhSOkWbZsmUuIsWvXLu3YseOUDheV3H+9usvRptmwYYNLr8C9e/ee8p5xFdG8eXNngzIxMVEpKSmaOHFipdx2ZZ/Tsrhb16Snp2vJkiWnpOHsjoEDB2rUqFH66KOPlJOTIz8/P5deSyfK3TqwMnz22We68MIL9X//938u29PT010mDTz2vh0TpJ8pioqKnHVty5YtS5S3MnrzldUerF+/vowxSk5Odml7nk6O9mV0dHS57caj67FjufOZxN06oLxz5U45j/f+3qJFC7Vo0UKPPvqolixZovPPP19vvvmmnnrqqTLv/0Ta1seeJ2OMNm7c6AxABg8e7NLWO5FeTNu3b9f06dNL/YLo3HPPVcuWLY+7ZH1pPVwq6oUXXlCNGjWcE+hee+21zstO5DhzcnIqdYXSo1WoT//ChQtLTSgd44kcwycuvvhiScUzqh/N8S29u+Mdg4ODS7wgfH19deWVV2rmzJmlfog+unvsxRdfrF27drmMc8zOzi6zm9GJeuGFF/Tiiy9qzJgxpS6nVp6LL75Yv/zyi3777Tfntr1795bZY+Bojm/vHfz9/dW0aVMZY5zLOgYHB0squayOI+E9tqvYyXwQufLKK53Dk47luJ9rrrlGO3fu1DvvvFNin5ycHOe4q9KWqnI0hk/mxXD0NybGGL322mvy8/Nzzs57zTXXqKioqNRZhwsLC13OY2nPT4dOnTpp69at+uSTT5xDU3x8fNSxY0e9/PLLKigocJmzpHXr1qpfv75efPFFly5dDo7ndUWe/1XF2WefrbPPPlvvvvuuZs6cqYEDB1bKNwilPcfz8/NLXVe7Mu7r2Lpx4sSJJcY1zpkzRz179qy0b0gqatCgQbJYLBo5cqQ2b95cKT1jpOLjt1gsLse7detW5ypHlaW0x9QYU2JN97i4OHXv3t3l50Rs2rRJmzZtOvECl+F///ufpH/DgKZNm7qUtXXr1pKKe7ANGzZM3377bakfQO12u1566SXt2LGjQvdfkfq/tHouICCgxPk9OiAbMGCAfvnlF7333nvat29fiQ90zZo1U+PGjfX222+7PGcmTZoki8XiMi9WRkaG1q1bd9INs6O5+3p1V/fu3eXn56eJEye63O6xbaAzwQ033KBvv/1WEyZMUM2aNSu8DGpZKvuclnc/7tQ13377rSS5PS69skVFRalPnz768MMPNW3aNPXu3dvtFQTK424dWBlKe0xnzJhRYhn2Y+uCY3twuGPfvn1at25dhedGOJ6FCxfq0KFDzro2IiKiRHkDAgJO+n7KamtfccUV8vX11eOPP17iXBpjSrTjT4VevXopLCxMzzzzTKlLvjvajXFxcWrVqpXef/99l/p2/vz5Wrt27XHvx906oKxzVZFylvb+npmZ6fzSwKFFixby8fFx+dxwsp8tHT744AOXYaKfffaZdu/e7axT69Wr51LGE1mZZ9asWSV+HO+nH3zwgV555RXnvqUNld+6dasWLFhw0sPxLBaL3n77bV111VUaMmSIy7yaZR1nYWFhqcH+b7/9plWrVlXqEMGjVah1fddddyk7O1uXX365GjdurPz8fC1ZskSffPKJ6tat6+wa1LJlSw0ZMkRvv/22szv4b7/9pvfff1/9+/cvdZ370rRu3VrfffedXn75ZWf3/nbt2unZZ5/VwoUL1a5dOw0bNkxNmzbVgQMHtHz5cn333XfOD8XDhg3Ta6+9psGDB+uPP/5QXFycpk6detwlWI/13nvvuaxZ7TBy5Eh99913evDBB9WwYUM1adJEH374ocs+PXr0KHeZsQcffFBTp05V7969NXLkSOdyr3Xq1HEZH1uanj17KjY2Vueff75iYmL0999/67XXXlPfvn2d8xM4GsiPPPKIBg4cKD8/P1166aXq2bOn/P39demll+q2227ToUOH9M477yg6OtrZ86aiHnjgAX322We6+uqrddNNN6l169Y6cOCAvvrqK7355ptq2bKlbrjhBn366ae6/fbbtXDhQp1//vkqKirSunXr9Omnn+qbb77ReeedpyeeeEKLFy9W3759VadOHe3Zs0dvvPGGEhMTXZLBrl276ocffnCrS2BAQIDmzZunIUOGqF27dpo7d65mz56tMWPGOIeYdOnSRbfddpvGjx+vlStXqmfPnvLz89OGDRs0Y8YMvfrqq85Gd+vWrTVp0iQ99dRTatCggaKjo51DkByhxfr1612W9ezcubPmzp0rq9WqNm3aOLf7+Pjo3XffVZ8+fdSsWTMNHTpUCQkJ2rlzpxYuXKiwsDDnhyF3n/9VyeDBg3X//fdLUpkftgsKCpyJ+9EiIyN15513ltjesWNHRUREaMiQIbr77rtlsVg0derUU9J9/JJLLtHUqVNls9nUtGlTLV26VN99953LOOScnBwtXLiw0ua0OBG1atVS7969NWPGDIWHh5cZMm/cuLHUc33OOeeUep2+ffvq5ZdfVu/evXXttddqz549ev3119WgQYPj1mMV0bhxY9WvX1/333+/du7cqbCwMM2cObNC34pnZGQ4QwLH8tGvvfaawsPDFR4e7vINryPwPLpb5bZt2zR16lRJxT0OJDnPVZ06dUr0rFi+fLnzfSErK0sLFizQzJkz1bFjR7c+dL300kvatGmT7r77bn3++ee65JJLFBERoZSUFM2YMUPr1q1zmfTWHRWp/8ur58pyzTXX6P7779f999+vyMjIUoOlF154Qf369VPPnj01cOBArV69Wq+99ppuueUWl56es2bN0tChQ0t0b586daq2bdvm/CC0ePFi5+Nwww03lNsz1J3Xa0XUqlVL999/v3PZ4osvvlgrVqzQ3LlzK+XDbGW69tpr9eCDD2rWrFm64447Sozxd5g5c2aJCZal4nmgjh0+JFX+OS2Lu3XN7NmzdcEFF1TKMJsTNXjwYGd7obwlGl9++eUS7VIfHx+NGTOmxL6VUQe665JLLtETTzyhoUOHqmPHjlq1apWmTZtWYq6y8rj7On3ttdf0+OOPO4e0Obz22mtKT0/Xrl27JBWHwo4g96677nJ5fDMyMpx1bWFhodavX69JkyYpMDBQDz/88ImfCDeU1dauX7++nnrqKY0ePVpbt25V//79FRoaqi1btmjWrFm69dZbnW2fUyUsLEyTJk3SDTfcoHPPPVcDBw5UrVq1lJKSotmzZ+v88893fuk3fvx49e3bVxdccIFuuukmHThwQBMnTlSzZs1K/dLtaO7WAa1atZKvr6+ee+45ZWRkyGq16qKLLlJ0dLTb5SzN999/rxEjRujqq6/WWWedpcLCQk2dOtUZWjic7GdLh8jISF1wwQUaOnSo0tLSNGHCBDVo0EDDhg077mPibjuif//+Ja7r6KHRp08fl/eXFi1aqFu3bmrVqpUiIiK0YcMG/d///Z8KCgpKLGaxePFi5/CsvXv36vDhw87779y5s0svZwcfHx99+OGH6t+/v6655hrNmTOn3LbAoUOHlJSUpAEDBqhZs2YKDg7WqlWrNHnyZNlsNj322GPHPU8npCJLqMydO9fcdNNNpnHjxiYkJMT4+/ubBg0amLvuusukpaW57FtQUGAef/xxk5ycbPz8/ExSUpIZPXq0yxKLxpS/tOC6detM586dTWBgoNExS6alpaWZ4cOHm6SkJOPn52diY2NNt27dzNtvv+1yG9u2bTP9+vUzQUFBJioqyowcOdK5dKe7y72W9bN9+3bnUjhl/bizXM1ff/1lunTpYgICAkxCQoJ58sknzf/93/8ZqfzlXt966y3TuXNnU7NmTWO1Wk39+vXNAw88YDIyMlxu/8knnzQJCQnGx8fH5Ta/+uorc/bZZ5uAgABTt25d89xzz5n33nuvxP2W9RgdWx5jipcxHTFihElISDD+/v4mMTHRDBkyxGX5pPz8fPPcc8+ZZs2aGavVaiIiIkzr1q3N448/7iz7ggULzGWXXWbi4+ONv7+/iY+PN4MGDTL//POPy/21bt3axMbGHvccO5YL3bRpk+nZs6cJCgoyMTExZty4caUug/T222+b1q1bm8DAQBMaGmpatGhhHnzwQbNr1y7nPqmpqaZv374mNDTUSCpxLqKjo40kl9fGTz/9ZCSZTp06lVrOFStWmCuuuML5mNapU8dcc801ZsGCBS77ufP8L2vZPsfSYWUtm1aaE1nu9YUXXiixr8pY7m337t3G19fXnHXWWWXeR1mvsfr16xtjSl/u9eeffzbt27c3gYGBJj4+3rlE9bGvzS5dupS6dHJZz31JZvjw4c7/Dx48aIYOHWqioqJMSEiI6dWrl1m3bp3L8qxff/21sVgsJerKY53Icq/HLkld2hKBDo4lyW699dYy76Osc33zzTcbY0pf7vX//u//TMOGDY3VajWNGzc2kydPLnP5vKPPnTFlP2dKew6vXbvWdO/e3YSEhJioqCgzbNgw5/J77jyny1uG9dhjqlOnToltjjKV9nP041ba/dSoUcPUq1fPPPDAAyYrK+u4ZXUoLCw07777runUqZOx2WzGz8/P1KlTxwwdOtRlKdiyloEr7bXhbv1/vHquLOeff76RSi77frRZs2aZVq1aGavVahITE82jjz5aYvl4R9mPfWzLWt7Rnfddd16vR9+3O6+voqIi8/jjj5u4uDgTGBhounbtalavXl3iNo/nRJZ7La3uKu016nDxxRcbSWbJkiVl3kdZP46l2o+ty0/2nJb13C1tqe/j1TV2u91ER0eb559/vtTjdziR5V6PrbuMKVkvO+Tl5ZmIiAhjs9lMTk5OmfdR2o+vr68xpvTH3N06sKxl0t19v8vNzTX33Xef8zl9/vnnm6VLl5ba9iuLu69Tx7k49rVb3vvRse3joy+zWCwmMjLS9OvXz/zxxx9ulfVkH/Oy2trGGDNz5kxzwQUXmODgYBMcHGwaN25shg8fbtavX+9yDKU9LhV5fzSm/HqrV69exmazmYCAAFO/fn1z4403mmXLlrnsN3PmTNOkSRNjtVpN06ZNzeeff15qfXKidYAxxrzzzjumXr16xtfXt8Tj7m45j7V582Zz0003mfr165uAgAATGRlpLrzwQvPdd9+57Heyny0d5/2jjz4yo0ePNtHR0SYwMND07dvX7SXn3W1HlKasunLcuHHmvPPOMxEREaZGjRomPj7eDBw40Pz1119l3kZpP8dbkjo7O9t06dLFhISEmF9++aXMcubl5ZmRI0eas88+24SFhTnbLTfffHOpda7DyS73ajHmDJn9CqigrKwsRUZGasKECRo+fLini4OTsG/fPsXFxWns2LGnLsX1sDvvvFPLli1zGXbmCV9++aX69++vxYsXuwyHAlA9XH755Vq1apU2btzo6aKcEr/99pvatWunNWvWuLVM5alSWFio+Ph4XXrppSXmqQBQNS1atEgXXnihZsyY4TJsEmcGzwz0BirB4sWLlZCQ4Fa3L5zZpkyZoqKiokqdIPFM06pVq0pf5vVEvPPOO6pXr57HJjAF4Dm7d+/W7Nmz9cgjj3i6KKfUM88849FQQ5K++OIL7d2712WSTwDAqUOwgSqrb9++bk9EizPT999/r7Vr1+rpp59W//79y11yrao71Ss9HM/HH3+sv/76S7Nnz9arr75aqUsgAjizbdmy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eDxVOC9l49yUjvNSNs5N6TgvZfOGc0NPDQBnAqJVAAAAAABQZRFsAAAAAACAKotgA4BXs1qtGjdunKxWq6eLckbhvJSNc1M6zkvZODel47yUjXMDAJWLyUMBAAAAAECVRY8NAAAAAABQZRFsAAAAAACAKotgAwAAAAAAVFkEGwAAAAAAoMoi2AAAAAAAAFUWwQYAr/X666+rbt26CggIULt27fTbb795ukiV6j//+Y8sFovLT+PGjZ2X5+bmavjw4apZs6ZCQkJ05ZVXKi0tzeU2UlJS1LdvXwUFBSk6OloPPPCACgsLXfZZtGiRzj33XFmtVjVo0EBTpkw5HYfntsWLF+vSSy9VfHy8LBaLvvjiC5fLjTEaO3as4uLiFBgYqO7du2vDhg0u+xw4cEDXXXedwsLCFB4erptvvlmHDh1y2eevv/5Sp06dFBAQoKSkJD3//PMlyjJjxgw1btxYAQEBatGihebMmVPpx1sRxzs3N954Y4nnUO/evV328cZzM378eLVp00ahoaGKjo5W//79tX79epd9Tufr50ypq9w5L127di3xnLn99ttd9vG28yJJkyZN0tlnn62wsDCFhYWpQ4cOmjt3rvPy6vh8AYAzigEAL/Txxx8bf39/895775k1a9aYYcOGmfDwcJOWlubpolWacePGmWbNmpndu3c7f/bu3eu8/PbbbzdJSUlmwYIFZtmyZaZ9+/amY8eOzssLCwtN8+bNTffu3c2KFSvMnDlzTFRUlBk9erRzn82bN5ugoCAzatQos3btWjNx4kTj6+tr5s2bd1qPtTxz5swxjzzyiPn888+NJDNr1iyXy5999lljs9nMF198Yf7880/Tr18/k5ycbHJycpz79O7d27Rs2dL88ssv5scffzQNGjQwgwYNcl6ekZFhYmJizHXXXWdWr15tPvroIxMYGGjeeust5z4///yz8fX1Nc8//7xZu3atefTRR42fn59ZtWrVKT8HZTneuRkyZIjp3bu3y3PowIEDLvt447np1auXmTx5slm9erVZuXKlufjii03t2rXNoUOHnPucrtfPmVRXuXNeunTpYoYNG+bynMnIyHBe7o3nxRhjvvrqKzN79mzzzz//mPXr15sxY8YYPz8/s3r1amNM9Xy+AMCZhGADgFdq27atGT58uPP/oqIiEx8fb8aPH+/BUlWucePGmZYtW5Z6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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(sorted_l2_diff)\n",
    "plt.title(f\"Sorted L2 distances, between {model_name} and {base_model_name}\")   "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Double embedding model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.chdir(\"..\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from model import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hf_token = \"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\"\n",
    "instruction_text = \"Clarify the context within the upcoming text to enrich the understanding of the factual answer.?\"\n",
    "data_text = \"Indicate from which direction the sun rises. Epigenetics is the study of how behaviors and environment can cause changes that affect the way genes work. Unlike genetic changes which involve the DNA sequence, epigenetic changes are reversible and do not change the DNA sequence, but they can change how the body reads a DNA sequence. Epigenetic changes can be influenced by factors like diet, stress, and prenatal exposure to certain environments.\"\n",
    "# Load config and extract model paths\n",
    "transformers.AutoConfig.register(\"custom_llama\", CustomLlamaConfig)\n",
    "transformers.AutoModelForCausalLM.register(CustomLlamaConfig, CustomLLaMA)\n",
    "model_name = \"anonymized_path/tiny_ii_pure_double_emb_3\"  # same embedding (instr, instr), not trained\n",
    "# model_name = \"anonymized_path/tiny_di_pure_double_emb_2\" # diff embedding (data, instr) - weird order btw,  not trained\n",
    "# model_name = \"anonymized_path/tiny_id_pure_double_emb_1\" # diff embedding (instr, data),  not trained\n",
    "\n",
    "# dont' forget\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(model_name, use_auth_token=hf_token, ignore_mismatched_sizes=True,\n",
    "                                            )\n",
    "model = transformers.AutoModelForCausalLM.from_pretrained(model_name,\n",
    "                                                use_auth_token=hf_token,\n",
    "                                                tokenizer_vocab_size=len(tokenizer),\n",
    "                                                tokenizer_pad_token_id=tokenizer.pad_token_id,\n",
    "                                                ignore_mismatched_sizes=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Embedding(64000, 2048, padding_idx=2)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.model.embed_tokens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "64000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.config.vocab_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics = embd_metrics.get_embedding_metrics(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'cosine_similarity': {'mean': 0.9965313076972961,\n",
       "  'std': 0.058794792741537094,\n",
       "  'median': 1.000000238418579,\n",
       "  'min': 0.0,\n",
       "  'max': 1.0000007152557373,\n",
       "  'percentile_5': 1.0000001192092896,\n",
       "  'percentile_10': 1.0000001192092896,\n",
       "  'percentile_90': 1.0000004768371582,\n",
       "  'percentile_95': 1.0000004768371582},\n",
       " 'l2_distance': {'mean': 4.525488839135505e-05,\n",
       "  'std': 3.638035619285551e-12,\n",
       "  'median': 4.525489202933386e-05,\n",
       "  'min': 4.525489202933386e-05,\n",
       "  'max': 4.525489202933386e-05,\n",
       "  'percentile_5': 4.525489202933386e-05,\n",
       "  'percentile_10': 4.525489202933386e-05,\n",
       "  'percentile_90': 4.525489202933386e-05,\n",
       "  'percentile_95': 4.525489202933386e-05},\n",
       " 'l_inf_distance': {'mean': 1.0000001111620804e-06,\n",
       "  'std': 1.1368861310267347e-13,\n",
       "  'median': 9.999999974752427e-07,\n",
       "  'min': 9.999999974752427e-07,\n",
       "  'max': 9.999999974752427e-07,\n",
       "  'percentile_5': 9.999999974752427e-07,\n",
       "  'percentile_10': 9.999999974752427e-07,\n",
       "  'percentile_90': 9.999999974752427e-07,\n",
       "  'percentile_95': 9.999999974752427e-07}}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "topk_diff, topk_diff_indices = torch.topk(l2_diff, 550, largest=True)\n",
    "topk_diff = topk_diff.cpu().detach().numpy()\n",
    "plt.plot(topk_diff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
