{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ea5ebb3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# analyze all the pythia experiments\n",
    "import torch\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d613e8dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# models = ['410m', '12b', '2.8b', '70m']\n",
    "models = ['70M', '410M', '2.8B', '12B']\n",
    "file_postfix = ['3', '0-1', '2', '1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7f502103",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = [torch.load(f'../outputs/pythia-logit-{postfix}.pt',weights_only=False) for postfix in file_postfix]\n",
    "loss = [d['loss'] for d in data]\n",
    "logit_std = [d['logit_std'] for d in data]\n",
    "\n",
    "loss[1] = loss[1][7:]\n",
    "logit_std[1] = logit_std[1][7:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f057177d",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import optimize\n",
    "import numpy as np\n",
    "\n",
    "def residuals(x, c_l, alpha_l, L0):\n",
    "    return np.log((c_l / (x ** alpha_l) + L0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "75247a41",
   "metadata": {},
   "outputs": [],
   "source": [
    "steps = [128, 256, 512, 1000, 2000, 3000, 6000, 12000, 16000, 32000, 48000, 79000, 143000]\n",
    "def lr_scheduler(step, total_steps = 143000):\n",
    "    # linear warmup 0.01 + cosine decay to 0.1 max lr\n",
    "    step = torch.tensor(step)\n",
    "    if step < total_steps * 0.01:\n",
    "        return step / (total_steps * 0.01)\n",
    "    else:\n",
    "        progress = (step - total_steps * 0.01) / (total_steps * 0.99)\n",
    "        return 0.5 * (1.0 + torch.cos(torch.pi * progress)) * 0.9 + 0.1\n",
    "\n",
    "lrs = torch.tensor([lr_scheduler(step) for step in range(1,143001)])\n",
    "tau = torch.tensor([lrs[:step].sum() for step in steps])\n",
    "del lrs\n",
    "\n",
    "steps = torch.tensor(steps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7757457f",
   "metadata": {},
   "outputs": [],
   "source": [
    "max_lrs = [1e-3, 3e-4, 1.6e-4, 1.2e-4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "87613a2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "c_taus = []\n",
    "alpha_taus = []\n",
    "alpha_std_taus = []\n",
    "L0_taus = []\n",
    "\n",
    "for i in range(4):\n",
    "    if i == 0:\n",
    "        fitout = optimize.curve_fit(residuals, tau[1:-2].numpy(), \n",
    "                                    loss[i].log()[1:-2].numpy(), \n",
    "                                    maxfev=100000, p0=[1,0.33,loss[i][-1].item()],\n",
    "                                            bounds = ([0,0,0], [np.inf,np.inf,loss[i][-1].item()]))\n",
    "    else:\n",
    "        fitout = optimize.curve_fit(residuals, tau[2:].numpy(), \n",
    "                                    loss[i].log()[2:].numpy(), \n",
    "                                    maxfev=100000, p0=[1,0.33,loss[i][-1].item()],\n",
    "                                            bounds = ([0,0,0], [np.inf,np.inf,loss[i][-1].item()]))\n",
    "    c_taus.append(fitout[0][0])\n",
    "    alpha_taus.append(fitout[0][1])\n",
    "    alpha_std_taus.append(np.sqrt(np.diag(fitout[1]))[1])\n",
    "    L0_taus.append(fitout[0][2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "89839f9e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test loss')"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "for i in range(4):\n",
    "    plt.plot(steps.numpy(), loss[i].numpy(), 'o',label=models[i])\n",
    "plt.xscale('log')\n",
    "plt.yscale('log',base = 2)\n",
    "plt.legend(frameon=False, fontsize = 'small')\n",
    "plt.xlabel(r'Training steps, $t$')\n",
    "plt.ylabel('Test loss')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "85f0d30d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test loss')"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAASMAAADdCAYAAADwzxTwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFUklEQVR4nO2dd3xT1fvH30m694DuyhYoUMooyAbZe4gDFEEQBZEvQxRwMFzAT0XwK7K+KkP2EGQIyCirQJkCsrGFUkoHpXsn9/dHaGjapE3alKblvF+vvEjuPffeJ5ebT895znOeRyZJkoRAIBCUM/LyNkAgEAhAiJFAIDAThBgJBAKzQIiRQCAwC4QYCQQCs0CIkUAgMAuEGAkEArPAorwNKEtUKhX379/H0dERmUxW3uYIBM8kkiSRkpKCj48Pcrn+/k+lFqP79+/j7+9f3mYIBAIgMjISPz8/vfsrtRg5OjoC6pvg5ORUztYIBM8mycnJ+Pv7a36P+qjUYpQ3NHNychJiJBCUM8W5SoQDWyAQmAVCjAQCgVkgxKi0pD2E3OzytkIgqPAIMSoN1/fATy3hyDflbYlAUOERYgTkJiSQc/9+CQ7MhLQ4OPod3L9gcrsEgmeJZ16MMi5dInzAQO5NnISUbeRwq8EACBgAkhK2jxPDNYGgFDzzYmTh7o4qK4vMixeJXbhQsz0uPQ6DkmD2+hbs3CHmshiuCQSl4JkXI0sfH3y++hKAhJ9/IfXIEX6/+Tu9f+/Nzn93Fn8Ch6rQ+zv1ezFcEwhKzDMvRgCOXbrg+vrrANyfOo3Ee/+SkZvB16e+Jjo1uvgTNBj4ZLi2bSzkZpWtwQJBJUSI0WM8PvoQ6/r1UT56RKcVF2ns3ojUnFQ+Of4JKklV/Al6fwd2VSD2CoTMLXuDBRUCpUrixO2HbL8QxYnbD1GqTFv/wsHBQeslk8nYsmWLZv/cuXOpWrUqbm5ufPTRRxrXQ0REBDKZjC5dumidb9++fchkMsaMGWNSOw1BiNFj5NbW+M7/DpmdHRmnwph1vSG2FracfnCaVf+sKv4E9lWgz/fq98cXQOTpMrVXYP7suRxN23kHGbL8JBPWX2DI8pO0nXeQPZcN6G0bSGpqquYVGhqKra0t3bp1A2D37t0sXryYU6dO8c8//7Bz505+/fVXzbFWVlbcvn2b+/lmkteuXUudOnVMZp8xCDHKh3WNGnjPngVAzv9+Y7b1ywD8cP4HridcL/4EAf0g8FWQVLBtDGSnl6G1AnNmz+Voxv52juikTK3tD5IyGfvbOZMKUh5r1qyhf//+mgWpq1ev5r333qNmzZp4e3szZcoUfvvtN017mUzGK6+8wvr16wHIzMxk37599O/f3+S2GYIQowI49+2L80uDQJKoteAPejq3IkeVw7Sj08hSGuAL6jkPHH3g4S3YP6vM7RWYH0qVxOwdV9A1IMvbNnvHFZMO2SRJYt26dbz+2PcJcOXKFRo1aqT53LhxY/755x+t415//XXWrl0LwI4dO+jUqRP29vYms8sYhBjpwOvTT7GqXQtlfDzv/p5BFSs3biXeYsHZBcUfbOsK/X9Uvw9bCrcPlamtAvMjLDyhUI8oPxIQnZRJWHiCya555MgR0tPT6d69u2ZbamqqVrYKJycnUlNTtY4LDAwkKyuL69evs2bNGoYOHWoym4xFiJEO5La2+C1YgMzWluxTZ/jmzgsA/Hb1N45HHS/+BLU7Q/NR6vfbx0FGYtkZKzA7YlP0C1FJ2hnCmjVreOWVV7C0tNRsc3BwIDk5WfM5OTkZBweHQscOHTqURYsWcfr0aY2/qTwQYqQH69q18ZoxAwD7VTsZL3UC4NPjn5KQacBftG5fgFtNSI6C3R+WpakCM8PD0cak7YojOzubzZs3aw3RAAICArh06ZLm899//02DBg0KHZ8nRv3799cSs6eNEKMicBk4AOeBA0GlouP/ztNYXo34jHhmHp9ZfHS2lT0MXAYyOVzaCJe3Ph2jBeVOixpueDvboC+VmAzwdrahRQ03k1xv9+7dODs707p1a63tb7zxBosXLyY8PJwHDx4wf/583njjjULHV6tWjQMHDvDpp5+axJ6SIsSoGLxmfIZ1nToo4+P55E87rLAg5F4IG65vKP5g/2Bo94H6/c5JkBRVtsYKzAKFXMbMvgEAhQQp7/PMvgEo5KYpEpHn6ymYSbF37968++67BAcHU79+fXr16sVbb72l8xwdO3bEx8fHJPaUFJlk0AKsiklycjLOzs4kJSWVKu1s1r//Ej74ZaT0dO4PbsPEOqewVlizrvc66rgWE5OhzIGfu8L981CjAwzbBkVUSBBUHvZcjmb2jitazmxvZxtm9g2gR0PvcrTs6WLo71CIkYEk7dzF/SlTANg2tiFrXa5R26U263qvw8aimLF//C1Y2g5y0qH719BqXKlsEVQclCqJsPAEYlMy8XBUD81M1SOqKBj6OxR/og3EuU9vXIa8BsDAtXeplenMrcRbfHfmu+IPrlIbun+lfr9/Fjy4VGRzQeVBIZfRqpY7/YN8aVXL/ZkTImMQYmQEntOnY9OwIVJSMp/vcUKhlFh/fT0H7x4s/uBmb0HdXqDMhi1vQ05G2RssEFQghBgZgdzKCt8FC5A7O2N5NZw55+sCMCN0Bg/SHhR9sEwG/f4LDp4Qdw32le/MhUBgbggxMhIrP1985qlX5Vf/6wqv3vUhKSuJqUemkqvKLfpg+yowYLH6/en/wbXdZWytQFBxEGJUAhw7dsR9zLsAvLQlhjqPbDgXe46lF5cWf3DtztDqffX77eMguQS5twWCSogQoxJSdfx47Fu3gswsZu6wxTZLYunfSzkVfar4gzvPAK9AyEiAre+ASln2BgsEZo4QoxIiUyjw+fZbLLy8sIqK48vDXkiSimlHp/Ew42HRB1tYw+BfwdIeIo7CsflPx2iBwIwRYlQKLNzc8Fu4ACwt8T8bxVt/uxKfEc/Hxz4uPjtkldrQ+1v1+0Nz4M6JMrdXUA6olBB+FC5tVv8resF6MWsxSklJITg4mKCgIBo1asTy5cvL26RC2DZujNcnHwPQc28CTe9aEHo/lJ8v/Vz8wY2HPE7GpoQto5DSHpKZIx7WSsOVP2BBQ1jZB7aMUv+7oKF6exlw4sQJ5HI5c+eqJ1iOHDlC+/btsbe3p0ePHoXanz59msaNG2NnZ0eHDh24c+eOZl/Hjh2Ry+XcvXtXs02SJPz9/bGxMc0C34KYtRjZ2dlx+PBhLly4wKlTp5gzZw4PHxYzBCoHXF59FedBg0ClYsoOOe5JEj9e+JHTD4pJPSuTqXNnu9WC5ChuLHuTYf87SUa2EKQKz5U/YOObhScokqPV200sSCqVikmTJhEcHKzZZmdnx5gxY5g+fXqh9llZWQwaNIgJEyaQkJDACy+8wLBhw7Ta1K5dm3Xr1mk+Hz58GFtbW5PanR+zFiOFQoGdnR2gTompVCoNq2X2lJHJZHjN+AybgAAsktP5cpcjimwlU49MJT4jvuiDrR3h5RVICmvqJh0j8N4axvx2luxcA4oACMwTlRL2TIWicj3umWbSIduyZcto2bIl9evX12xr3rw5Q4cOxc/Pr1D7kJAQHBwcGDlyJDY2NsyYMYMzZ85o9Y6GDh2qyQIJlHnytXIXozlz5hAcHIyjoyMeHh4MGDCA69ef5JtOTEykcePG+Pn58dFHH1GlSpVytFY/chsb/P77AwoXF9zvJDL5oD1x6bFMOzoNZXEPnXcgsh5fAzDNYj3JN0OZtPGCyStJCJ4Sd0KLCdmQ1Hmu7oSa5HIJCQksWLCAWbNmGXxMwZS09vb21KpViytXrmi21atXD4VCweXLl8nOzmb37t0MGjTIJDbrotzF6PDhw4wbN46TJ0/y119/kZubS7du3UhLSwPAxcWFv//+m/DwcNauXUtMTEw5W5yPAs5JS28vfOd/B3I5zc4l0/eCBaeiT7Hk4pLiz9V8FDQYhKVMySKrHzh+8QbTt15EJQSp4pFq4DNqaLti+Pjjj5k4cSKurq4GH1MwJS3oTks7dOhQ1qxZw+7du2ndunWpF5wXhUWZndlA9uzZo/X5119/xcPDg7Nnz9K+fXvNdk9PTwIDAzly5Agvv/yyznNlZWWRlfUkaX7+lJsm58of6q54/r+ATj7Y95iHxwcfEPvNN7zxVw633GUsZSlBVYNo49tG//lkMui7EKL/xifhNt9bLmbkmSnYWVkws29AoVw1AjPGwdO07Yrg/PnzhIWFsWjRIqOOK5iSFnSnpR0yZAjt2rXj1q1bhTJJmppy7xkVJCkpCQA3NzdiYmI0Nyw5OZkjR45Qt25dvcfOmTMHZ2dnzcvf379sjCzGOen2gjtOvXohU6qYvsMCt2QVU49OLb46rY0TvLISLGzopLjAWMUfrAiNYN6e62bpKxPooVprcPKhcGq1PGTg5KtuV0oOHz7MjRs38PX1xcvLiw0bNvDVV18xevToIo8rmJI2LS2N27dvExAQoNXO19eXatWqcfDgQXr16lVqe4vCrMRIkiQmT55M27ZtadiwIffu3aN9+/Y0btyYtm3b8v777xMYGKj3+OnTp5OUlKR5RUZGmt5IA5yTsr3T8f5iNtb16mGTnMVn261IT03kg8MfkK3M1nlaTeXRB27cCp4FwBTLzbSWX2bJ4dt8v/+m6b+LoGyQK6DHvMcf9OR67DFX3a6UvPPOO9y6dYsLFy5w4cIF+vXrx4QJE/jmm29QqVRkZmaSk5Oj9R7UU/epqamsWLGCrKwsvvzyS5o3b061atUKXWPZsmXs2bMHKyurUttbFOU+TMvP+++/z8WLFzl27BgAzZo148KFCwYfb21tjbW1dRlZ9xgDnZPy2PP4/fgjEYMH43MvkfF7rZjf+yL/d/r/+PQF7RX7hTMCPsePdi/SR3WQn+0X0ynlc344AJZyGeM7l0+1T4GRBPSDV1bpHMrTY656vwmws7PTzDgD2Nra4uDggIuLCyEhIXTq1Elr3/Dhw1mxYgXW1tZs3bqVUaNGMXbsWIKDg1m9erXOazytCrNmk+lx/PjxbNu2jSNHjlCjRg2TnNOQDHOSUkn6mbPkxsVhUbUqds2bIVMU8Rfr0mZ1AFtxvPQzNBpM2slT3B01CpRKVr8oZ0dLOV+1/Yp+tdQPY17l0YL/CTZks8VqJg3kd4hxakTb2A/JwYIPu9dlXKfaBt4BQbmjUqr/gKXGqH1E1VqbpEdUkTA002O594wkSWL8+PH8/vvvhISEmEyIDCF53z5ivp5D7oMnuYgsvLyoOn0qNxu7E5ceR1W7qjT1aIoi7wEy0jlp/0JLPKdNI+arr3jjkMTdKio+V3zO867PU8elrt7Ko5lYMTZnIjutP8Uz+RJba+6g778D+WavOuxBCFIFQa6AGu3K24oKQbn3jN577z3Wrl3L9u3btZzTzs7OpY72LEqRk/ftI2rCRCjw9fM+fTdITlhdtUvN086TaS2m0aVaF/VfugUN1c5qnTIiU3fFJ17S/AWUJIkHM2aQuGkzWbYKPhoG8mp+TGmwmLdXXNFxjid0kp/nV6tvADhQdyaj/lbfo8ldn+c/YsgmqABUmBzYixcvJikpiY4dO+Lt7a15bdhgQCmgEiIplcR8PaeQEIHavSgBI/5SIXsc4xObHsvkkMnsv7O/RM5JmUyG12efYdu0KdYZSj7ZIiMx7h4/XZkNFB1pfUjVhGv11An8O9+ay/+1VgdQzv/rBvP/uiFm2QSVhnIXI0mSdL5GjBhRZtdMP3NWa2hWEDlQJQXqR6p/6NLjHtC8sHnqaOo856RTgXIzTj7q7TqckzIrK/z++wMWPt54PMxl8na4nXQGq6r7irX3UfNJ8HxPUGbxyq1pzOrsAcAPB26KaX9BpaHcxag8yI2LM6ida75gVAmJB+kPOBd7Tr0hoB9MvAzDd6qd1cN3qodmRcySWLi74//TT8hsbWkUrmT4fhXWVUKwcNRdLURTebRmFRi0FNxrQ3IUIyJnMLOXeoi25PBtZu+4IiK1BRWeZ1KMLKpWNajdI4fC2+LS8wlZnnOy0WD1vwbMktjUq4fP/6mHeT3PSnQ9p8LGZxMKa+2eWqHKozbO8No6sHKEu6G8lbyELwY0BGBFaATTtl4Ua9kEFZpnUozsmjfDwstLvQRDByog3hGu+hfeX9XOMCErCqeuXak6cSIAo/5SEXgnE/vnVoMiTdPGy9mGxW801a48WvV5eGk5IIMzPzNMsZ9vX26MXAYbz9zjP+vOi9X+ggqL0WJ07tw5rTDy7du3M2DAAD7++GOys3VHF5sbMoUCz48f53gpIEgq1L2SFV3lSPkK7smQ4WXnRVOPpgZdQ1IqSTsVRtLOXaSdCkNSaq/cd3/3HZz69UWuginbJLyT4gkO3sX8VxuyblQwx161pId0vHB2wLo94cVP1O///IjB7hEsGtoUS4WMXZeieXvVGdKzi6lSIhCYIUZP7QcHBzNt2jReeukl/v33Xxo0aMDAgQM5ffo0vXv3ZsGCBWVkqvEUN6WoK84o3hFWdlVwqq62EAHM7zhfPb1f3HX1xC95fjwdp27dNNtUWVncHfEWGefPE+sqY/qbcvpWb830q0d1RO3Oe+KPkiR14OXlLWDrBqMPciTegXdXnyUjR0mQvwu/jgjG1b5sw/cFxaNUKTkXe053zNozQplN7d+4cYOgoCAANm3aRPv27Vm7di0rVqxgy5YtJTa4PHDq1o3aB/bz3MqV+Hz7Lc+tXEnWhoVENPHSaudp52mUEEVNmFhoti43JoaoCRM5t/Endv+7m9MPTiNZWuC36Ecs/fzweCQxZYuSjfdD2SwlFThpgeyAMhn0XwQ+TdQVRta9RvvnrFgzuiXOtpZciExk8JJQohJF1dryZP+d/XTf0p2Re0cy9ehURu4dSfct3dUhIiYiKyuLt956Cz8/P5ydnenYsaPWyCU/4eHhdOvWDRcXF3x9fZkzZ45m34oVK7CwsMDBwQEHBwfq16/Ptm3bTGanIRjdM3JycuLs2bPUqVOHrl270qdPHyZMmMDdu3epW7cuGRnm8wMwVJELUtK/ZpJSya3OXfSGDUjAQ0cY954CSS7TBFO2y6lOxJChqFJSONpAxuI+MpbFxBGcmZXv6MLBlCRHw/JOkBINtTrD0I3ciM9g+C9hRCdl4ulkzS/Dg0nOzCU2JRMPRxta1HAT9d6fAvvv7GdyyGRNWEgexvayiyMtLY358+fz1ltv4e3tzcKFC1m0aBG3b98u1LZPnz74+fnx3//+l3v37tGmTRtWr15N586dWbFiBevXr9ek9Nm7dy+DBg3i/v37ODs7l8rGMusZNW/enC+//JLVq1dz+PBhevfuDahV19Oz9PlZzAGFXEGwVzC9avYi2CvY4G51cfFLMrTjl/KCKY9aRuA7bRTIJNr9IzHwuMRkjypEWuS/ro7sgE7eMGQdWNrB7QOwZxrPezqyZWxr6ng4EJOcRZ//HmPI8pNMWH+BIctP0nbeQfZcLiaViaBUKFVK5obNLSREoCNmrZTY29vz2Wef4efnh0Kh4P333yc8PFxnrvg7d+7w6quvYmlpSY0aNWjbtq1WZsf8dO/eHXt7eyIiIkpto6EYLUYLFizg3LlzvP/++3zyySfUrq1eI7V582Zaty59fpaKjLHxS/kfTNs6rng1Vw/PXj4m0fgfGe97epBScMavYHZAnyYw6PEM2+nlcHIxPi62jOlQ8/E1tHmQlMnY384JQSpDzsWeIyZdfxbHQjFrJuTEiRN4enri7u5eaN+4ceNYv349WVlZ3Lx5k5MnT9KxY8fC9kkSe/bsQaVSaX7fTwOjF8oGBgbqHJN+8803KIpa7f4MUJL4Jc2DqUwhuFY6OakKHl515N0/VXzlpGCKRxUWxcQ9+Y/StVC3fh/o+jn89RnsmY7S2Z9v9+le1yeh7qHN3nGFrgFeYshWBmjFopmgnaEkJSXx7rvv8tVXX+nc37p1a3766Sfs7e1RKpXMmjVLKw/2gQMHcHFxIScnh8zMTBYsWIC9vb1JbSwKo3tGkZGR3Lt3T/M5LCyMiRMnsmrVKiwtLU1qXEWjNPFLcU6e4ORD1cBUHP0zsFDBlK0q7qbZMNfdFam47ICtx0OztwAJNo/CI/myXjslIDopk7DwBOO/pKBYDI1FM0XMWh6ZmZkMGDCA3r17M3LkyEL7lUolvXr1YvTo0WRmZhIeHs6mTZvYvHmzpk3nzp1JTEwkLS2Ny5cvM2fOHHbs2GEyG4vDaDEaOnQohw4dAuDBgwd07dqVsLAwPv74Yz7//HOTG1iRKEn8Uh5V7T2hxzxkMvB5IRHbKlnYZ8HHG5Xskznwm5ND0dkBZTLo9S3U7opCmcnPVt/iLys64XtsSmaR+wUlo6lHUzztPDXO6oIYG7NWHLm5ubz22mv4+Pjw7bff6myTkJDA/fv3GTt2LBYWFlSvXp0BAwZofssFqV+/Pm3atGHv3r0msdEQjBajy5cv06JFCwA2btxIw4YNCQ0N1UzvP+s4deuG78IFWBRw5ic4aqclyUPrwXy8AFfu6o1fuwSsHHOpkgzTNyr50cGVgw461qfkR2EBL/9KqlsDqsiSWWk5Dzf0FyVIF8UiywSFXMG0FtMACglS3uepLaaaLN5o9OjRZGRksGLFCr2FG6pWrYq/vz/Lly9HpVJx7949tm/frjVMy8+tW7c4fvy4Vh22ssZoMcrJydGkdt2/fz/9+qkD8erVq0d0tHCKQuH4pbj/+w/vv2fB6braD5/OB/PxAlyLd3bgP+cjFC6OVI+FyVuVfBIylX/i/yn64taO2A7fQjRVqSl/wC9W32CL7h7Q7B3/sPNiUSl0BSWlS7UuzO84Hw87D63txsSsGcKdO3dYsWIFR44cwdXVVRMndPToUdasWUODBg00bTdv3szq1atxdXUlODiYzp07ayXu379/Pw4ODtjb29OhQweGDBnCmDFjTGKnIRgdZ9SyZUs6depE79696datGydPnqRx48acPHmSwYMHa/mTypuSxhmVBfvv7Gdu2FytWRYvOy+mtpha5IOZcfkf7gwbhpSRwdEGMtYOrsJvfdbi51i4Smh+joYep+HeV3CVpXJQGcQ7OZPJxUKTrynA24kr0epe09iOtZjSra5wZpcBIgLb8N+h0WIUEhLCwIEDSU5OZvjw4fzyyy+AupDctWvX2Lp1a+ksNyHmJEZQ8gcz9ehRIseOhVwlf7SUcbxfTf7nORnrxIwi83afPLyboEPD1fm0le34KGc03R0jeLeJHQ3r1uWba24sOaouZ9yuThV+eK2JWEIiMDllJkag9swnJydrVbCMiIjAzs4ODw+PIo58upibGJWGxN+3ET1d7RxPtQaHfMHZuta95aG8tgf5hqHIJCW5FnZY5KY/2enkw+l6U3nzhBcZOUp8XWxZ/EZTAv1cyvjbCJ4lyjTtrEKhIDc3l2PHjnH8+HHi4uKoXr26WQlRZcNl4ACc+vYFtIUInqx7S95XOGukol4PZMFvA2gLEUByNMFhE/mrZxLV3O2ISsxg8OIT/HbyjsgeKXjqGC1GaWlpjBw5Em9vb9q3b0+7du3w8fFh1KhRpKenF38CQYmQlErSwsL07FSn6r3z+UxOR53SXmagUsI1fbEiasHxOzmbP95rRbcAT7KVKj7ddpkJ6y+QmiVSkQieHkaL0eTJkzl8+DA7duwgMTGRxMREtm/fzuHDh/nggw/KwkYB6nVvyhj9cUMywCI+kW9/LrAy3MCik86xp1k6rBkf96qHQi7jj7/v0+eHo1yOStJ7pKYK7oUoTtx+KDJNCkqF0ctBtmzZwubNm7XWtPTq1QtbW1teeeUVFi9ebEr7BI8xZt3b1ccLcOd3nE+X1ETDLpAag0wm4532tWhWzZXxa88T8TCdQT+F8lGPuoxsUwN5vtm2wlVw1fm6Z/YN0M5OKRAYiNE9o/T0dJ2r8z08PMQwrQwxZt2b1spwewOXHORb89asmhu7J7TTDNu+3HWVt1ac1kRs51XBzS9EIBbhCkqH0WLUqlUrZs6cSWbmkwcxIyOD2bNn06pVK5MaJ3hCceveJCDB/sm6N80CXBtrdR4kPUsTALB1L7TmzcXOiqXDmvHFgIZYW8g5fCOOHguO8ufjHpGuAVnettk7roghm8BojBajhQsXEhoaip+fH507d6ZLly74+/sTGhrKwoULy8JGAUWve8tbiS/JwaFAsHVcZkIRRScfk5UM/xZeoySTyRj2QjV2jG9LfW8nEtKydfaICtoiFuE+obhc6IInGC1GDRs25ObNm8yZM4egoCACAwOZO3cuN2/e1Ao9F5gefeveHtlDsi24p8AnG5TYZT7plVS1q6q/6KSjD/g2A1UOrBsKt3SnQ33e05Ft41rzboeaRfWvtBCLcNUpiG917sLd4cO5P2UKd4cP51bnLjpDMErKzJkzCQgIQC6Xs379es32FStWEBQUhKOjIzVr1mTJkiWafREREchkMs3SEV9fX2bPnm0ym0qK0Q5sAFtbW601LYKnh1O3bjh27kzq6TC+3PUBdyyTueIPXo9g9m9Kaj5QL6z98jUFjk5Vn6wMD+gH9XqrZ9dSY9Q+omqt1VP/m0bA9V1qQXr1N3i+cPCktYWC6T3r4+Vkw+wdurMD5sfD0cbE37xikZcLvWAJ9byYMBYu0Bmkaix16tRh4cKFfPbZZ1rbs7KyWLJkCc2bN+f69eu8+OKLBAQE0L59ewCsra1JTVVn+QsPD6ddu3a0atWKbiawqaQYFIH9xx9/GHzCvIWz5kBlisDWRV6eZVD7iKrFSMxcq8QhEy5Xk/HT666sHrih2HVs5GbD5rfg2k5QWMHLK6FeL51NlSqJ1nMPEJOcpXO/DHXNt2NTX3xm17oVlwsdmQwLT09qH9ivcxlPSejYsSNjxozhtdde07n/9ddfp2nTpnzwwQdERERQr149Lb/vK6+8Qps2bZgwYYJJ7MmPob9Dg3pGAwYMMOiiMpkMpRgTPzXyVobnLcC94ynjq1cVzFivouEdiXfWPeJd61H83GclXvZe+k9kYQUvr4DNI+HqH7BxGLz0P2gwsFBThVzG7H4NGPvbOb1ObE0V3GeU4nKhI0nkPnhA+pmz2LdsUeb2KJVKwsLCGDZsmM79t2/fJjQ0lEmTJpW5LUVhkBipVKJKqbnSpVoXOvl30lqA+3wXiBz9DkHhmShXR/KObCT/67OiUDoLLRSWMPhX2DYGLm1SC1NOBgQNLdS0R0NvFr/RtFCcEYCNpZyY5CyUKumZFSRDY8IMbVdaPv30U3x9fenevbtmW1ZWFi4uLqhUKlJSUnj11Vc1ecrKi2eyvHVlo2A1E4fgYJ5bsgSsrWh2S2Lw6ghG7x5JfEZ8MSeygIFLockwkFSwbSycWqqzaY+G3hyb+iLrRr/AwteCmDuoEY39nMnMUTHzj3/ov+gY5+4+KoNva/4YGhNmaLvSsGTJErZu3crmzZu1Eq9ZW1uTmJhIcnIycXFxxMfH89FHH5W5PUUhxKiSYv9CS/x/+gmsLAm+KTFw1b+8vfut4gVJroC+P8AL76k///kRhMwr5IgF9ZCtVS13+gf58lqL59j6Xhu+6N8AJxsLLkclM+inUD7c9PczN7NWXEwYMhkWXl7YNW9WpnZs2LCBr776ir1791KlShW97apUqcLAgQOfaopZXQgxqsQ4tGmD/6JFYGlJyxsSA1bd5u3dbxVflUIuh+5fQ8fHcU0hX8OfU6GY4bpCLmNYq+ocnNKRl5upneabzt7jxW8Ps+TwbbJynw1/YlExYXmfPT+ebhLndV4lD5VKpfV+3759jB8/nl27dlG9evUiz5G3vvRpppjVhRCjSo5Du3b4L/pRLUjXJQasvM3oXW8Rmx5b9IEyGXScBj2/UX8OWwpbRkGu7lm0/FRxsOablxuzZWxrGvs5k5qVy9w/r9F1/hF2XYx+JtKT6IsJs/D0xNdE0/qgzn9ta2vL0aNHefPNN7G1teXIkSPMmTOHR48e0bp1a008Uf4UsllZWZrttWrVwtHRkR9++MEkNpWUEiVXqyhU9ql9Y0g9coTI99+H7BxO15Gx5c0aLO31c9GzbHlc2gy/j1EHR1Zvp45FsnUx6LoqlcTW81F8s/eaJhwgyN+F6T3r0bJm4UKDlQ1JqVTPrsXFFZmVszJTZpkeFQoF0dHRhRKpPXz4EA8PD7Oa2hdipE3q0aNEjhsH2TmcrSVj/TB/lvT+GT9Hv+J/NLcPwoY3ITsFPALg9U3g/Dh+SaUsHExZIJ1uenYuy4+Es/TIbU1VkhfrefBBt+dp4POklrtSJREWnkBsSiYejja0qOH2zM7KVRbKTIzkcjkPHjwoJEb379+nVq1aZGRklMziMkCIUWFSjx8n8r33ICubv6vLWDnMi//aj0Ra8LNWbIzOVLbRF2HNy5D6ABy8YOgGSLwLe6Zq50xy8lGvhwsoHAAbm5zJDwdvsi4sUrOYtncjbyZ2qcPtuFSRlqQSYnIxyhtPTpo0iS+++AKHfDW8lEolR44cISIigvPnz5fSdNMhxEg3aSdPcXfsWMjIILIK+MXrWEL72NFayL+RGAlrX4HYK2BhrceH9Phsr6zSKUgA4fFpfP/XDf74+77mCF0PYp5di99oKgSpgmJyMapRowagrtPk5+eHIl8X3srKiurVq/P555/TsmXLUppuOoQY6Sf93Dnujn4HKS1Ns+q/EPqWLWQmwcY34d+QIq4gU/eQJl7SXwUXuPYgmfn7brDvStFZLJ/1JSYVGZMn5A8PDyc8PJwOHTrw999/az6Hh4dz/fp19u7da1ZCJCgau6ZN8fzwQ6CITEePly0c2rGI0w9OP8mtbeMMbSYWcwV1OlvuhBbZqp6XE2+1qVHcmURakmcAo6f2Dx06pFWiSKlUcuHCBR49ejajbSsy8uLKZT9mY+hSRu4tkFs7/aFhF0nV3+PJw9CgyOgk8/FHCkyP0WI0ceJEfv75Z0AtRO3bt6dp06b4+/sTEhJiavsEZYgxqWwBYh/n1t5/Z79WmtoiMaCdoelGvtx1lZ9CbvEoLduwawsqFEaL0aZNm2jcuDEAO3bsICIigmvXrjFx4kQ++eQTkxsoKDuKW7agAuIdtVPZwuPc2v4ti09n6+hTKJ2tLlrUcMPb2abIxG1yGSSkZfN/e67zwpwDfLjpby7eSyz23IKKg9Fi9PDhQ7y81IFyu3fv5uWXX+b5559n1KhRXLp0yeQGCsoOQ1LZrugqR8rnNNbk1o7/u/h0tq7V1Cv/i0EhlzGzb4DOM8kevxa+FsS3LzemgY8TWbkqNp29R78fj9Pvx2OsD7tLmqjxVuExWow8PT25cuUKSqWSPXv20KVLF0BdNUTxjEWWVgb0LVuQASoZWOfoPi4uPU5/OltrJ5DJ4e4JWP4ixBSfGTIvLYmXs/aQzcvZhsVvNKVvY18GN/Nj5/i2bBnbmgFBPlgp5Fy8l8S0rZcI/mo/H23+mzMRCYWWm4j6bhUDo4MeZ82axYIFC/D29iY9PZ0bN25gbW3NL7/8wvLlyzlx4kRZ2Wo0YmrfcPIisG/cOsk3N5bQ6SK0vap+NFZ3krOjpUyr9/RL918I9gpWf9AVgR0Zps4emRINFrbQcx40fVP/SvbHGBOB/TA1i63nolgXdpd/49M022tUsWdgE18GNvHln/tJIpCynCmzCGyAzZs3ExkZycsvv4yfn3pJwMqVK3FxcaF///4lt9rECDEyHqVKSfct3YlLi+H1g0r6hqkfjz+byVjRRT1k87LzYs9Le1AUET8EQFo8bH0Hbh9Qf24wCPp8b/C6NkORJInTEY/YcDqSPy9Ha5ab6EMEUj5dylSM8sjMzMTGxnwTrwsxKhn5c2v3ClMy/IA6dUjY8zJ+6CfnlcBhTG0x1bCTqVQQuhAOfAGSEpz9YdAygxzbJSEtK5c/Lz9g67l7hN7WH36gK5BSrIsrG0we9JiHUqnkiy++wNfXFwcHB/79918APvvsM82Uv6mIjIykY8eOBAQEEBgYyKZNm0x6foFu8nJre9h5sKuFnO8HyMlRQIsbEjPXKNlxZjULzy1EJRmQjlguh7aTYORecK0OSZHway/YP0tdCMDE2FtbMLiZH+NfrFNku7xAyp2Pl6PsuRxN23kHGbL8JBPWX2DI8pO0nXdQVMd9ihjdM/r8889ZuXIln3/+OaNHj+by5cvUrFmTjRs38v3335vUZxQdHU1MTAxBQUHExsbStGlTrl+/jr29vUHHi55R6VCqlJrc2p63EnD47EdUSUnEOsPclxXUbtKJOe3m4GBlWPAkWSnqJG0X1qg/ezaEgUvAq5HJbd9+IYoJ6y8Y1NbHxYb7iYUDL8VwzjSUWc9o1apVLFu2jNdff11r9iwwMJBr166VzFo9eHt7ExQUBICHhwdubm4kJIglAU+L/Lm1m3V7g+rr12FZ7Tk8kuDL1UoeHTnI0N1DCU8KN+yE1o4w4Cd4ZTXYuUPMZVjWSZ3WVqln2q6EGBpIKZehU4hAlOt+2hgtRlFRUdSuXbvQ9ry0l8YyZ84cgoODcXR0xMPDgwEDBnD9+vVC7c6cOYNKpcLf39/oawhMg3WNGlRfvx675s2xy4Jpm1Q8f+A2Q3cO4dDdwuWx9RLQD947CfX6qBO2hXytFqX7+TI+qJQQflSd2C38qPqzERQXSClDPau2+PWi81DnDecWHbpFYnrhYaUIGzAdRleUbdCgAUePHqVatWpa2zdt2kSTJk2MNuDw4cOMGzeO4OBgcnNz+eSTT+jWrRtXrlzRDMcePnzIm2++yf/+9z+jzy8wLRaurvj/8jMPZs4i6fffGfWXiufik5mUNZ6RQe8wLmhc8bNsAA4e6oyRl7fA7g8h5hIs7wyt3gOvQNg/0+AcSbrIC6Qc+9u5QulJ8gRqZt8AMg3Myz3/rxt8v/8G9bycaFnDjRY13EjNzOH7/TeNChsQTnL9GOwzGjlyJAsXLiQkJIRhw4Yxffp0Pv/8c2bPns3169dZtWoVO3fupGvXrqUyKC4uDg8PDw4fPkz79u3Jysqia9eujB49Wm8RujyysrLIynqSXyc5ORl/f3/hMyoDJEki4ZdfiP32O5AkrvjDd4MUBNR6gXnt5uFua0RK2dQ4dRWSf7YW0aj4HEm62HM5usg4oxO3HzJk+cliz+PrYktUomELdWXo9jPps+Wz3vVxtbeutAJl8qn9/Olm9+7dy9dff83Zs2dRqVQ0bdqUGTNmmKRO961bt6hTpw6XLl2iQYMGDB06lLp16zJr1qxij501axazZ88utF2IUdmRcugQ96d8iCotjXhnGf83SE56DU/mtZ9Hc6/mxp3s2p+w4XV1CIBODMuRVJCieiNKlUTbeQd5kJSpN7lbXgjAw7QswsITOHn7IetPR5JbxJDM3krBlwPVteSqu9uz78oDvVV4C1JU70rfdzHnHpfJxUhfullTIkkS/fv359GjRxw9epRjx47Rvn17AgMDNW1Wr15No0a6Z19Ez6h8yLp9m3vvjSP7zh1yLGQs7ikjtJEF7zUaw9CsIFTxCYYlow8/Civ7FH/B4TuhRjuT2b/ncjRjfzsH6B7OFezlGNqbysPeSkG2UkWO0jB/kr7r6utZ9WvszR9/R5ttlHmZiFFMTAxVy7AK5rhx49i1axfHjh3TRHaXBjG1//RQJiUR9eGHpB05CsDZWlAtBqqkPmlj4eVF1elTudnYXVOKu6lH0yc+pkub1eWQiuOln6HRYIMKARhKccO5/BgaNlDd3Y7opEyyco0vD18wKDNPMA11j5tTWEKZiJGzs7NWiVxdlHTqffz48Wzbto0jR45oUtyWFiFGTxdJqSTuv//l4RJ1SeyC6WzzHrTvBskJq6ueyPW082Rai2l0qdbF8J5Rj7ng5GtUIQBDMHSoY2jPaN3oFwiu7sryo/8yb0/hGWJDGN6qOh3qVmXq5r+JSzUuSNRc0vWWiRgtWLAAZ2fnItsNHz7cKEMlSWL8+PH8/vvvhISEUKdO0ZGzxiDE6OkjKZXcaNMWVWKizv0qIMERxr2nQJLLkD2Wq/kd59PFvxMsaAjJ0ehOz18cJXNyG4sxfiaFXGb0sM7UrBv9Aq1qlV+NOkN/h0ZN7b/22msm9xmNGzeOtWvXsn37dhwdHXnwuFyOs7Mztra2Jr2WoOxJP3NWrxCBOrCtSgrUj5S4Uk2GhIQMGfPC5tHJvxOKHvPUyf51TshLULMT/KsvpulxX2zPNKjXu8RDtuIwNGwgrzeSF/OkT7yKIri6K5GPMniQZFhqXl3su/IAKws5nk7WVHW0xtrCPFP9lGg2zaQG6Bn2/frrr4wYMaJU5xY9o6dP0s5d3J8ypdh2C/vJOd5AO+ZWk5bkyh86hmC+6uGZrWu5OLl1YYyfSZ+TXB/5e1dh4Qkm7Vm52FlS1cGaKg5qcariYI27gxVVHKxws7fGzd4Kd3sr3ByscLS2KNY1Uxwm7xmVVRXsSlxd+5nE2Lza+YlLj1O/Cein7tnock5f2myYIQYUAigtPRp60zXAyyA/U17yuILipYuCvavS9KxsLOQE+DgTk5xJXEoW2UoViek5JKbncDM2tdjjLeQyXOyscLWzxNXOCmc7S1xsLXG2tcTFzpK2daoS5O9ipFV6rmVoQ5XK+BkBwbNHXl7t3JgY0POHRgKa3Ja47iehVDz54Va1yydkcoXuno2hhQDO/ArutcDH+FUBxqCQywz2x+gSr0dp2XyxS1ugvAr0rooaFuoj764ueC1Icx5JkkjKyCE2JYu4x6/41CziUrN4mJpNfGoWCWnZPEzNJiEtm4wcJbkqifhUdTtd2FpZmEyMSpXPyNwRw7TyIXnfPqImTFR/yPd4qXiS0xrglhf82FeOSxq4p8kZ0X4SwT2Go5KhyRZQaPpfpTTOyV29HbQeD7W7qtOZ5J3DRCEBpsDQWbynHWeUmaPkUXo2j9Jy1P+mZ5OUoe5VJWXkkJSew4AmvsWK8VNJrmbuCDEqP5L37SPm6znkPp6QAHWlkZVdFUhIjNmtwiGz8PR/sosV63vYsb/GkyGE1vQ/qH1KG998vFeH+7jbVxB9Qb3uLS+a270OtHwXrJ3hQOnWvZUnIgK7giLEqHzJy6udGxeHRdWqnKiayNyz/0dMegwvnlfy7h6p0Kr6vN5T/lgkren//IKkz8mdJyqJkXBqCZxbBVnJRVj6dEICnlWEGCHEyBxRqpSciz6DzasTUMQn6UzxUTAWCdSC5GnnqZ1729DhVlYKnF8D+z4uIhVJyda9CYqnzJKrCQSlQSFXEHBPhoUeIQLtWKQ8NPXaYs/la/jYyd1osPpffSJi7QieDYrJiSRBchREHC+8q5S5lQSGYXQ+I4GgtOTGxRnUruU1iSvPSVrljaJSop6USDIGQ6f6t74NwW+rBc6tpp7hoA90mwP27mbjBK8MCDESPHUMjUXqeU6iarKKn7vLeej02G90bj7IoG/NvoYlccvD0JCA1Bg49JX65VYTEv4t3Cb5PmwusOypAjnBzRXhMxI8dSSlkludu+iNRVIBGVZgnQsWKvX7tR3k7G+mQClTt6/jWocJTSbQ3q+9JkI4fwEB40MCZODoBS9++ng4dhgMqX6S/3jQ7QQ3s1CCp41wYCPEyJwpLhbpu0FyotxljNmtpG6Uel/W889x/e1OLEz7g9TMZOpHSgTJq9G92Wsk1PXSzNTlYXRIQH4hufIHbCw6s2hhdDjB9Q3zeszTH2VeyRBihBAjc0dXLFJuVRdWdJazr4Z6Kl4mSbz0jyODD2QiT88EuRzr1i1JvPw3tonpmuPiHWFF1yfhAFCKkAAwPLeSLvLWxWnEr+BP7HEcta0bZORLuVNJh3pCjBBiVBEoGItk17yZzghsVfxDYufOI3n3bp3n0RWfBKUICTA0t5IuaneBZiNh92RIeVB8+3zWAjB4RaVyjgsxQohRZUNSKrnRth2qR4907tcVn5SHJiOAoRi77MSUyOTa/io7dwh8Fer2qpDCJOKMBJWO9DNn9QoR6I5PyiM6tXCZaqVKyekHp9n9725OPziNMn/8kFyhHjIB6I2I0oGtGzQbYfjsnS4KOs7TH8LJn9Q9tQUN1cO/SoiY2hdUGAyNT/JIlLiiXdaPb858Q2xGLIPrDMbFxoX9d/YzN2xu0Q7vgH5qp3ZBH5NOHgtW34Xq4xoOLvkwryiSo9V+qEq4dEUM0wQVhrRTYdw1IK1xig2s7SjnUGMZKrkMuUyOpFRSP1KiarolVf3rsMXuaqGhnAx15slxjcfxnNNzT8IDQNvHlP4Q9k4v2glepsO8irV0RfiMEGJU2TAkPkmSgeLxrig32NBBwRsBw3Bd+juW8Umatrpm33RRqLekuZgBTnC9oQQmotuX0GCQWphKmY2xLBFihBCjyoi++KS8dwv6y3BJk/HScRVORRSAzZt929hOxgNXGY8c4Kq/TGdvCQqEBxiDrlACzZS+oanSisHSTh0trnnVANfq4FINnP1AYVn6a5QCIUYIMaqs6IpPKlSTTXLguR3nSFi6rMiMk/mlR19vSWd4AMVEfOdHVy/q2q7CIlVwFq04nHzV51Tl6m8jU6jbufiDs7/63zYTwVpH3t8yQogRQowqM7rikwpWqzXUx5SHvlilPPKHBxTlAO/k36lkIpX+EDaNoPjeUj6fkaSCR3cg4TY8vA2PwuFRBCSEQ+JdUBZMFyuDT2PBwsrg+1JayqRUkUBgLsgUCuxbtiiyjaGzb3nIUQvSiL9UnK5TeMgWGhVKE48mhESGMDlkMlIB0YhNj2VSyCScrZ1Jynrin9Lrd9KV51tW3OzdY5t6zH3so1JAldrqV0FUKrXQJd5Vv5IiITPxqQqRMYiekaDSYmzPKD+zhsq5Ui1fJLdKon6khF+WPXF2uVzwyS4kVvow2u+U12O6vhsuboT0+Cf7dC1dMXNEz0jwzGNIpRJ9uOar4tPiuoq3/pJwT5GAFMDw2ThAU6hy7qm5OFg6kJCZUPTwLa/HVKOdesbsGVhMC6JnJKjk6Jt9K47TdWBNJwX+8TB5qzoyO38/KM+/NH+gjBRbGa6p6J2R04fe4VslQziwEWIkUKNr9k0fBWfYchRgodS9IKRgXBMY12PKY1zjcYwOHG1csrgKhBAjhBgJnpB/9i37zh3if/zx8Y58j79MBpJE1oiB5F67gd2pf5AZ+esobkZOH5W5lyTECCFGAv3oi1Xy/Hg6Tt26AfBw5Spi58wx+twqIMEBFj0uUGno8E2GrOTBlWaMcGALBEXg1K0bjp07FxmrZFOvXonOLQeqpMLMdU8CGA0ZvklIzDg+gyq2VQhwD8BKYZ5T8GWF6BkJBHoobi2cMRg7fLOQW/C86/M0cG9AgHsA9d3rU8elToUUKDFMQ4iRoPSUdDZOFyogxRbefV+OykK/INlZ2JGem15ou4XMgpouNXne9Xnqutaljmsd6rjWoaptVU1RAnNEiBFCjASmQedsnFyujnAuAUl2sLyH/h7Sz91+xsfBh8sPL3Pl4RWuPrzK1YSrWlHd+XGycqK+W32Wd1tulqIkxAghRgLTUXAtnPJRAlGTJj/eadxPKK+1Qfm6846RJGLSY7iWcI3rCde58egGNxNvcif5DipJRW2X2vze//fSfMUyQziwBQITonMtnFxucPyS1rlQC9LYXSqi3CCqigyZTC1KU1tM1RlvJJPJ8LL3wsvei47+HTXbs5RZRCRFkJqTWuiYioboGQkEpSB/j0nh7k70tGnkxsYa1Vt64ALX69rToM8w2vR5B7mtbdkZXA6IYRpCjARPH43D28CflaSQI1M+8T3JrKywbdYUhzZtsGvVCpv69ZHJK3bdDCFGCDESlA/J+/YRPXNWkZVM8vBbuhSUuaSGHCb12FFy72tXMVE4O2PXogV2LVti1yIY69q1K5w4CTFCiJGg/FBlZ3OrQ0eU+gRJJsPC05PaB/ZrAi0lSSI7PJy0Y8dJO3GC9LAwVGlpWocpXFywbd6MKu+OwbZRw7L+GiZBiBFCjATli94YpcfT774LF2iWnuhCyskh859/SDt5ivTTp0k/dw4pQ53Yu/rGDdgGBpaV6SZFiBFCjATljyFr4AxFyskh88oV0s+cwe3NN5FZlm+ifUMRYoQQI4F5YEi+7sqMiDMSCMwEQ/J1C9QLjAUCgaDcEWIkEAjMgko9TMtzhyUnJ5ezJQLBs0ve768493SlFqOUFHUlB39//3K2RCAQpKSk4OzsrHd/pZ5NU6lU3L9/H0dHR7NMrVASkpOT8ff3JzIyUswQFoG4T4ZT1vdKkiRSUlLw8fFBXkT0eKXuGcnlcvz8/MrbjDLByclJ/MgMQNwnwynLe1VUjygP4cAWCARmgRAjgUBgFggxqmBYW1szc+ZMrK2ty9sUs0bcJ8Mxl3tVqR3YAoGg4iB6RgKBwCwQYiQQCMwCIUYCgcAsEGIkEAjMAiFGAoHALBBiVEmJjIykY8eOBAQEEBgYyKZNm8rbJLNi586d1K1blzp16vC///2vvM0xS572MySm9isp0dHRxMTEEBQURGxsLE2bNuX69evY29uXt2nlTm5uLgEBARw6dAgnJyeaNm3KqVOncHNzK2/TzIqn/QyJnlElxdvbm6CgIAA8PDxwc3MjISGhfI0yE8LCwmjQoAG+vr44OjrSq1cv9u7dW95mmR1P+xkSYlROHDlyhL59++Lj44NMJmPbtm2F2vz000/UqFEDGxsbmjVrxtGjR0t0rTNnzqBSqSpNKpXS3rv79+/j6+ur+ezn50dUVNTTMP2pYspn7Gk8Q0KMyom0tDQaN27Mjz/+qHP/hg0bmDhxIp988gnnz5+nXbt29OzZk7t372raNGvWjIYNGxZ63b9/X9Pm4cOHvPnmmyxbtqzMv9PTorT3TpdnorKkmMmPKZ4xeIrPkCQodwDp999/19rWokULacyYMVrb6tWrJ02bNs3g82ZmZkrt2rWTVq1aZQozzZKS3Lvjx49LAwYM0Oz7z3/+I61Zs6bMbS1PSvqMPc1nSPSMzJDs7GzOnj1LtwJ1tbp160ZoaKhB55AkiREjRvDiiy8ybNiwsjDTLDHk3rVo0YLLly8TFRVFSkoKu3fvpnv37uVhbrlhyH162s+QECMzJD4+HqVSiaenp9Z2T09PHuQrBlgUx48fZ8OGDWzbto2goCCCgoK4dOlSWZhrVhhy7ywsLPjuu+/o1KkTTZo04cMPP8Td3b08zC03DLlPT/sZqtSZHis6Bf0YkiQZ7Nto27YtKpWqLMyqEBR37/r160e/fv2etllmR1H36Wk/Q6JnZIZUqVIFhUJRqBcUGxtb6C+ZQBtx7wzDHO+TECMzxMrKimbNmvHXX39pbf/rr79o3bp1OVlVMRD3zjDM8T6JYVo5kZqayq1btzSfw8PDuXDhAm5ubjz33HNMnjyZYcOG0bx5c1q1asWyZcu4e/cuY8aMKUerzQNx7wyjwt2nMp+vE+jk0KFDElDoNXz4cE2bRYsWSdWqVZOsrKykpk2bSocPHy4/g80Ice8Mo6LdJ7E2TSAQmAXCZyQQCMwCIUYCgcAsEGIkEAjMAiFGAoHALBBiJBAIzAIhRgKBwCwQYiQQCMwCIUYCgcAsEGIkEAjMAiFGAoHALBBiJBAIzAIhRoJyp2PHjkycOLHCnFdQNoiFshWcESNGsHLlSkCdTtXNzY3AwECGDBnCiBEjkMvN/+9NQkIClpaWODo6luj4jh07EhQUxIIFC0x6XsHTxfyfVEGx9OjRg+joaCIiIvjzzz/p1KkTEyZMoE+fPuTm5pa3ecXi5uZWJoJRVucVlBHllrxEYBKGDx8u9e/fv9D2AwcOSIC0fPlyaeXKlZKbm5uUmZmp1WbQoEHSsGHDJEmSpA4dOkjjx4+XPvzwQ8nV1VXy9PSUZs6cqdX+zz//lNq0aSM5OztLbm5uUu/evaVbt25ptenQoYP0/vvvSxMmTJBcXFwkDw8PaenSpVJqaqo0YsQIycHBQapZs6a0e/durWMmTJig+axUKqW5c+dKtWrVkqysrCR/f3/pyy+/1Pv9KZCvJzw8vNB5S2KXJEmSSqWS5s2bJ9WoUUOysbGRAgMDpU2bNun779BJ3759deYVAqTt27cbda7KjBCjCo4+MZIkSWrcuLHUs2dPKT09XXJ2dpY2btyo2RcXFydZWVlJBw8elCRJ/WN1cnKSZs2aJd24cUNauXKlJJPJpH379mmO2bx5s7Rlyxbpxo0b0vnz56W+fftKjRo1kpRKpaZNhw4dJEdHR+mLL76Qbty4IX3xxReSXC6XevbsKS1btky6ceOGNHbsWMnd3V1KS0vTHJNfjD766CPJ1dVVWrFihXTr1i3p6NGj0vLly3V+x8TERKlVq1bS6NGjpejoaCk6OlrKzc0tdN6S2CVJkvTxxx9L9erVk/bs2SPdvn1b+vXXXyVra2spJCTE4P+j+Ph4KTo6Wrp586YESLt379bYmpOTY/B5KjtCjCo4RYnRq6++KtWvX1+SJEkaO3as1LNnT82+BQsWSDVr1pRUKpUkSeofa9u2bbWODw4OlqZOnar32rGxsRIgXbp0SbOt4Hlyc3Mle3t7TQ9MkiQpOjpaAqQTJ05ojskTjeTkZMna2lqv+OiioJjp2l4Su1JTUyUbGxspNDRU67yjRo2ShgwZYrB9eYSGhkoymUxKTk42+thnAZEDuxIj5Ss7M3r0aIKDg4mKisLX15dff/2VESNGaJWqCQwM1Dre29ub2NhYzefbt2/z2WefcfLkSeLj4zVlbO7evUvDhg11nkehUODu7k6jRo002/KqT+Q/dx5Xr14lKyuLzp07l+ar68RYu65cuUJmZiZdu3bVOk92djZNmjQx+voXL16kevXqwo+lByFGlZirV69So0YNAJo0aULjxo1ZtWoV3bt359KlS+zYsUOrvaWlpdZnmUymVTerb9+++Pv7s3z5cnx8fFCpVDRs2JDs7Oxiz5N/W54A6qrJZWtrW4JvahjG2pX3765du/D19dU61tra2ujrX7x4sZDgC54gxKiScvDgQS5dusSkSZM0295++22+//57oqKi6NKlC/7+/gaf7+HDh1y9epWlS5fSrl07AI4dO2Zyu+vUqYOtrS0HDhzg7bffNugYKysrlEqlyW0JCAjA2tqau3fv0qFDh1KfLyIiQqsHKdBGiFElICsriwcPHqBUKomJiWHPnj3MmTOHPn368Oabb2ravf7660yZMoXly5ezatUqo67h6uqKu7s7y5Ytw9vbm7t37zJt2jRTfxVsbGyYOnUqH330EVZWVrRp04a4uDj++ecfRo0apfOY6tWrc+rUKSIiInBwcMDNzc0k8VWOjo5MmTKFSZMmoVKpaNu2LcnJyYSGhuLg4MDw4cONOp9KpeLOnTvcu3cPX19fg6sDPyuIOKNKwJ49e/D29qZ69er06NGDQ4cO8cMPP7B9+3YUCoWmnZOTEy+99BIODg4MGDDAqGvI5XLWr1/P2bNnadiwIZMmTeKbb74x8TdR89lnn/HBBx8wY8YM6tevz6uvvqrTv5THlClTUCgUBAQEULVqVe7evWsyW7744gtmzJjBnDlzqF+/Pt27d2fHjh2a4S/AihUrDBKW//znPxw/fpx69eohiVjjQogI7GeMrl27Ur9+fX744YfyNqXSMGvWLEJCQggJCSlvUyo0Ypj2jJCQkMC+ffs4ePAgP/74Y3mbU6nYu3cvCxcuLG8zKjxCjJ4RmjZtyqNHj5g3bx5169Ytb3MqFSdOnChvEyoFYpgmEAjMAuHAFggEZoEQI4FAYBYIMRIIBGaBECOBQGAWCDESCARmgRAjgUBgFggxEggEZoEQI4FAYBYIMRIIBGaBECOBQGAW/D/BnNHIoinsxAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plot_x = torch.logspace(torch.log10(tau[0]), torch.log10(tau[-1]*3), steps=100)\n",
    "plt.plot(tau[:-2].numpy() * max_lrs[0], loss[0][:-2].numpy(), 'o', label=models[0], color = 'C0')\n",
    "plt.plot(plot_x.numpy() * max_lrs[0], \n",
    "         (c_taus[0] / (plot_x.numpy() ** alpha_taus[0]) + L0_taus[0]), \n",
    "         '-', color = 'C0')\n",
    "for i in range(1,4):\n",
    "    plt.plot(tau.numpy() * max_lrs[i], loss[i].numpy(), 'o', label=models[i], color = f'C{i}')\n",
    "    plt.plot(plot_x.numpy() * max_lrs[i], \n",
    "             (c_taus[i] / (plot_x.numpy() ** alpha_taus[i]) + L0_taus[i]), \n",
    "             '-', color = f'C{i}')\n",
    "\n",
    "plt.xscale('log')\n",
    "plt.yscale('log',base = 2)\n",
    "plt.legend(frameon=False,fontsize = 'small')\n",
    "plt.xlabel(r'Dynamic time, $\\tau$')\n",
    "plt.ylabel('Test loss')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "71082862",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([0.34071961515447385,\n",
       "  0.3670317571265018,\n",
       "  0.33744748310751993,\n",
       "  0.3073649904236741],\n",
       " [0.02781450415735331,\n",
       "  0.01289855974771548,\n",
       "  0.012964239150829605,\n",
       "  0.016449714708779192])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha_taus, alpha_std_taus"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a99efe6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test loss (training part)')"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(steps[:-2], loss[0][:-2].numpy() - L0_taus[0], 'o', label=models[0])\n",
    "for i in range(1,4):\n",
    "    plt.plot(steps, loss[i].numpy() - L0_taus[i], 'o', label=models[i])\n",
    "\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.legend(frameon=False, fontsize = 'small')\n",
    "plt.xlabel(r'Training steps, $t$')\n",
    "plt.ylabel('Test loss (training part)')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "15373211",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(tau[:-2].numpy() * max_lrs[0], loss[0][:-2].numpy() - L0_taus[0], 'o', label=models[0]+f' ({alpha_taus[0]:.2f}±{alpha_std_taus[0]:.2f})')\n",
    "for i in range(1,4):\n",
    "    plt.plot(tau.numpy() * max_lrs[i], loss[i].numpy() - L0_taus[i], 'o', label=models[i]+f' ({alpha_taus[i]:.2f}±{alpha_std_taus[i]:.2f})')\n",
    "plt.plot([1e-1,5e+1], [4, 4 / (5e+2)**(1/3)], 'k--', linewidth=3)\n",
    "plt.legend(frameon=False, fontsize = 'small', labelspacing=0.2, handletextpad=0.2, borderaxespad=0)\n",
    "plt.xlim(1e-4, 8e+1)\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.xlabel(r'Dynamic time, $\\tau$')\n",
    "plt.ylabel('Test loss (training part)')\n",
    "plt.savefig('../figures/pythia-losses.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c7029b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(tau[:-2].numpy() * max_lrs[0], logit_std[0][:-2].numpy(), 'o', label=models[0])\n",
    "for i in range(1,4):\n",
    "    plt.plot(tau.numpy() * max_lrs[i], logit_std[i].numpy(), 'o', label=models[i])\n",
    "plt.plot([1e-4,1e-2], [8e-1, 8e-1 * (1e+2)**(0.33)], 'k--', linewidth=3)\n",
    "plt.legend(fontsize = 'small', labelspacing=0.2, handletextpad=0.2, borderaxespad=0.5)\n",
    "plt.xlim(1e-4, 8e+1)\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.xlabel(r'Dynamic time, $\\tau$')\n",
    "plt.ylabel('Logit std')\n",
    "plt.savefig('../figures/pythia-logits.pdf')"
   ]
  }
 ],
 "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
