{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "533e9037-a55e-4c3a-addd-595ff952549a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# @title Imports external sources\n",
    "#  conda activate py310_ICL\n",
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"5\"\n",
    "import io\n",
    "from IPython.display import display\n",
    "import PIL.Image, PIL.ImageDraw, PIL.ImageFont\n",
    "import base64\n",
    "import zipfile\n",
    "import json\n",
    "import requests\n",
    "import matplotlib.pylab as pl\n",
    "import numpy as np\n",
    "import glob\n",
    "import requests\n",
    "import random as pyrandom\n",
    "from concurrent import futures\n",
    "from functools import partial\n",
    "from scipy.ndimage import rotate\n",
    "from IPython.display import Image, HTML, clear_output\n",
    "from tqdm import tqdm_notebook, tnrange\n",
    "import time\n",
    "from typing import Any, MutableMapping, NamedTuple, Tuple\n",
    "\n",
    "import jax\n",
    "from jax import grad, jit, vmap\n",
    "import jax.numpy as jnp\n",
    "\n",
    "import haiku as hk\n",
    "import math\n",
    "\n",
    "from ml_collections import config_dict\n",
    "import matplotlib.pylab as pl\n",
    "import matplotlib.colors as mcolors\n",
    "\n",
    "colors = pl.colormaps['Dark2']\n",
    "from src.transformer import Transformer\n",
    "from src.data import create_reg_data_classic_token, create_weights\n",
    "from src.config import config\n",
    "from src.train import *\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b947d273-cbde-4f3b-aee2-4f5ed1b8a5bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# @title Config\n",
    "softmax = False  # @param {type:\"boolean\"}\n",
    "layernorm = False  # @param {type:\"boolean\"}\n",
    "\n",
    "recurrent_Transformer = True  # @param {type:\"boolean\"}\n",
    "num_layers = 5 # @param {type:\"integer\"}\n",
    "num_heads = 1  # @param {type:\"integer\"}\n",
    "num_seeds = 1  # @param {type:\"integer\"}\n",
    "\n",
    "config.seed = 0\n",
    "config.local_usage = True\n",
    "\n",
    "####\n",
    "config.deq = recurrent_Transformer\n",
    "config.gd_deq = recurrent_Transformer\n",
    "config.att_only_trans = True\n",
    "####\n",
    "\n",
    "config.pre_train_gd = True\n",
    "config.train_gd_whitening = True\n",
    "config.train_gd_lr = True\n",
    "config.use_bias = False\n",
    "config.include_query = False\n",
    "\n",
    "config.distract_size = 0\n",
    "config.training_steps =8000 if config.deq else 8000\n",
    "config.training_steps_gd = 1000 if config.gd_deq else 30000\n",
    "config.use_softmax = softmax\n",
    "config.first_layer_sm = False\n",
    "config.use_non_lin_mix = False\n",
    "\n",
    "config.widening_factor = 4\n",
    "\n",
    "config.layer_norm = layernorm\n",
    "config.out_proj = False\n",
    "config.in_proj = False\n",
    "config.adam = True\n",
    "config.dataset_size = 10\n",
    "config.input_size = 10\n",
    "\n",
    "\"\"\"------------------need to change----------\"\"\"\n",
    "document_num=1\n",
    "config.key_size = 11+(config.dataset_size*document_num)   \n",
    "config.num_layers = num_layers\n",
    "config.num_heads = num_heads\n",
    "\n",
    "config.grad_clip_value = 10 if num_layers > 2 else 0.001\n",
    "config.grad_clip_value_gd = 10 if num_layers > 2 else 0.001\n",
    "config.lr = 0.0005# if num_layers > 3 else 0.001\n",
    "config.gd_lr = 0.0005# if num_layers > 3 else 0.001\n",
    "config.wd = 0.0\n",
    "config.init_scale = 0.002 / config.num_layers\n",
    "config.bs = 2048\n",
    "config.bs_gd_train = 512\n",
    "config.dampening = 1.0\n",
    "config.clip = 10 if num_layers > 3 else 0\n",
    "\n",
    "config.dropout_rate = 0.0\n",
    "data_creator = vmap(create_reg_data,\n",
    "                    in_axes=(0, None, None, None, None, None),\n",
    "                    out_axes=0)\n",
    "\n",
    "config.y_update = False\n",
    "config.input_range = 1\n",
    "\n",
    "\n",
    "config.pos_enc = False\n",
    "config.pos_enc_size = 20\n",
    "config.concat_pos_enc = False\n",
    "config.analyse = True\n",
    "\n",
    "config.cycle_data = 0  # 0 means online learning\n",
    "config.num_seeds = num_seeds\n",
    "if config.num_layers == 1:\n",
    "    assert config.deq == True\n",
    "    assert config.gd_deq == True\n",
    "\n",
    "if config.num_layers > 1:\n",
    "    assert config.y_update == False\n",
    "\n",
    "config.in_proj = False\n",
    "config.emb_size = 11\n",
    "\n",
    "# @title Utils\n",
    "pl.rcParams.update({'font.size': 12})\n",
    "pl.rc('axes', labelsize=14)\n",
    "pl.rcParams.update({\n",
    "    \"text.usetex\": False,\n",
    "})\n",
    "\n",
    "import matplotlib.colors as mcolors\n",
    "\n",
    "colors = pl.colormaps['Dark2']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f2fa147a-a008-47d3-bdb4-87f3e72b5abc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.10.18 | packaged by conda-forge | (main, Jun  4 2025, 14:45:41) [GCC 13.3.0]\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "print(sys.version)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ed66ef30-999e-439f-8e81-ab139f73cdb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def np2pil(a):\n",
    "    if a.dtype in [np.float32, np.float64]:\n",
    "        a = np.uint8(np.clip(a, 0, 1) * 255)\n",
    "    return PIL.Image.fromarray(a)\n",
    "\n",
    "\n",
    "def imwrite(f, a, fmt=None):\n",
    "    a = np.asarray(a)\n",
    "    if isinstance(f, str):\n",
    "        fmt = f.rsplit('.', 1)[-1].lower()\n",
    "        if fmt == 'jpg':\n",
    "            fmt = 'jpeg'\n",
    "        f = open(f, 'wb')  # GFile.open(f, 'wb')\n",
    "    np2pil(a).save(f, fmt, quality=95)\n",
    "\n",
    "\n",
    "def imencode(a, fmt='jpeg'):\n",
    "    a = np.asarray(a)\n",
    "    if len(a.shape) == 3 and a.shape[-1] == 4:\n",
    "        fmt = 'png'\n",
    "    f = io.BytesIO()\n",
    "    imwrite(f, a, fmt)\n",
    "    return f.getvalue()\n",
    "\n",
    "\n",
    "def moving_average(x, w):\n",
    "    return np.convolve(x, np.ones(w), 'valid') / w\n",
    "\n",
    "\n",
    "def grab_plot(close=True):\n",
    "    \"\"\"Return the current Matplotlib figure as an image.\"\"\"\n",
    "    fig = pl.gcf()\n",
    "    fig.canvas.draw()\n",
    "    img = np.array(fig.canvas.renderer._renderer)\n",
    "    a = np.float32(img[..., 3:] / 255.0)\n",
    "    img = np.uint8(255 * (1.0 - a) + img[..., :3] * a)  # alpha\n",
    "    if close:\n",
    "        pl.close()\n",
    "    return img\n",
    "\n",
    "\n",
    "def display_learning(train, test=None, gt=None, inter=None, title=\"train\",\n",
    "                     title1=\"Trained TF\", title2=\"Test\",\n",
    "                     title3='Gradient descent', title4='Interpolated',\n",
    "                     y_label1='L2 Norm', y_label2='Cosine sim',\n",
    "                     y_lim_l=0, y_lim_u=1, single_seeds=False,\n",
    "                     plot_title=None,\n",
    "                     y_lim_u2=1., y_lim_l2=0., x_label='Training steps',\n",
    "                     second_axis=False, color_add=0.2, rw=10, num_iter_os=None,\n",
    "                     allow_download=False, plot_num=1, two_plots=False,\n",
    "                     loc_first='upper left', label_title=\"Loss\",\n",
    "                     loc_sec='upper left', yscale_log=False, line=\"-\",\n",
    "                     color_axis=True,\n",
    "                     height=3.5, width=4, ax1=None, ax2=None):\n",
    "    \"\"\"Update learning curve image.\"\"\"\n",
    "  \n",
    "    train_list = train\n",
    "    train = np.array(train)\n",
    "    num_seeds_train = train.shape[0]\n",
    "    train_std = np.std(train, axis=0)\n",
    "    train = np.mean(train, axis=0)\n",
    "\n",
    "    if test is not None:\n",
    "        test_list = test\n",
    "        test_std = np.std(test, axis=0)\n",
    "        test = np.mean(test, axis=0)\n",
    "\n",
    "    if gt is not None:\n",
    "        gt_list = gt\n",
    "        gt_std = np.std(gt, axis=0)\n",
    "        gt = np.mean(gt, axis=0)\n",
    "\n",
    "    if inter is not None:\n",
    "        inter_list = inter\n",
    "        inter_std = np.std(inter, axis=0)\n",
    "        inter = np.mean(inter, axis=0)\n",
    "\n",
    "    if plot_num == 1:\n",
    "        fig, ax1 = pl.subplots()\n",
    "        ax1.set_xlabel(x_label,fontsize=14)\n",
    "        ax1.tick_params(axis='both', labelsize=14) \n",
    "        fig.set_size_inches(width, height)\n",
    "\n",
    "    if test is not None and not second_axis:\n",
    "       \n",
    "        \"\"\"---get in to ---------\"\"\"\n",
    "        # print(\"num_iter_os\",num_iter_os)\n",
    "        x_range = np.arange(0, num_iter_os, int(num_iter_os / len(test)))  # 50\n",
    "       \n",
    "      \n",
    "        if len(test_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in test_list:\n",
    "                    ax1.plot(x_range, s, color=colors(0.1 + color_add), alpha=0.2, label=title2, linewidth='2')\n",
    "            else:\n",
    "                ax1.fill_between(x_range, test - test_std, test + test_std, alpha=0.2,\n",
    "                                 facecolor=colors(0.1 + color_add))\n",
    "        ax1.plot(x_range, test, color=colors(0.1 + color_add), label=title2, linewidth='3')\n",
    "        # test_avg = moving_average(test, rw)\n",
    "        # ax1.plot(x_range[:len(test_avg)], test_avg, color=colors(0.1+color_add), label=title2)\n",
    "\n",
    "    if gt is not None:\n",
    "        if not second_axis:\n",
    "            x_range = np.arange(0, num_iter_os, int(num_iter_os / len(gt)))\n",
    "            # ax1.plot(x_range[:len(gt[:-rw])], gt[:-rw], color=colors(0.2+color_add), alpha=0.3)\n",
    "            # gt_avg = moving_average(gt, rw)\n",
    "            ax1.plot(x_range, gt, color=colors(0.2 + color_add), label=title3, linewidth='3')\n",
    "            if len(gt_list) > 1:\n",
    "                if single_seeds:\n",
    "                    for s in gt_list:\n",
    "                        ax1.plot(x_range, s, color=colors(0.2 + color_add), alpha=0.2, linewidth='2', zorder=0)\n",
    "                else:\n",
    "                    ax1.fill_between(x_range, gt - gt_std, gt + gt_std, alpha=0.2, facecolor=colors(0.2 + color_add))\n",
    "        else:\n",
    "            x_range = np.arange(0, num_iter_os, int(num_iter_os / len(gt)))\n",
    "            ax1.plot(x_range, gt, color=colors(0.6 + color_add), label=title3, linewidth='3')\n",
    "            if len(gt_list) > 1:\n",
    "                if single_seeds:\n",
    "                    for s in gt_list:\n",
    "                        ax1.plot(x_range, s, color=colors(0.6 + color_add), alpha=0.3, linewidth='2', zorder=0)\n",
    "                else:\n",
    "                    ax1.fill_between(x_range, gt - gt_std, gt + gt_std, alpha=0.2, facecolor=colors(0.6 + color_add))\n",
    "\n",
    "    if test is not None and second_axis:\n",
    "        x_range = np.arange(0, num_iter_os, int(num_iter_os / len(test)))\n",
    "     \n",
    "        ax1.plot(x_range, test, color=colors(0.5 + color_add), label=title2, linewidth='3')\n",
    "        # test_avg = moving_average(test, rw)\n",
    "        # ax1.plot(x_range[:len(test_avg)],test_avg, color=colors(0.5+color_add))\n",
    "        if len(test_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in test_list:\n",
    "                    ax1.plot(x_range, s, color=colors(0.5 + color_add), linewidth='2', alpha=0.3, zorder=0)\n",
    "            else:\n",
    "                ax1.fill_between(x_range, test - test_std, test + test_std, alpha=0.2,\n",
    "                                 facecolor=colors(0.5 + color_add))\n",
    "\n",
    "    if inter is not None and not second_axis:\n",
    "        x_range = np.arange(0, num_iter_os, int(num_iter_os / len(inter)))\n",
    "        ax1.plot(x_range, inter, color=colors(0.4 + color_add), label=title4, linewidth='3', zorder=10)\n",
    "        if len(inter_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in inter_list:\n",
    "                    ax1.plot(x_range, s, color=colors(0.4 + color_add), alpha=0.3, linewidth='2', zorder=0)\n",
    "            else:\n",
    "                ax1.fill_between(x_range, inter - inter_std, inter + inter_std, alpha=0.2,\n",
    "                                 facecolor=colors(0.4 + color_add), zorder=1)\n",
    "        # inter_avg = moving_average(inter, rw)\n",
    "        # ax1.plot(x_range[:len(inter_avg)], inter_avg, color=colors(0.7+color_add), label=title4)\n",
    "    \"\"\"\n",
    "\n",
    "    the label of model cos \n",
    "    \"\"\"\n",
    "    if second_axis:   \n",
    "        if ax2 is None:\n",
    "            ax2 = ax1.twinx()\n",
    "        ax2.set_zorder(0)\n",
    "        ax1.set_zorder(1)\n",
    "        ax1.set_frame_on(False)\n",
    "        # train_avg = moving_average(train, rw)\n",
    "        # ax2.plot(train[:-rw], color=colors(0.1+color_add), alpha=0.3)\n",
    "        ax2.plot(x_range, train, color=colors(0.4 + color_add), label=title1, linewidth='3')\n",
    "        ax2.plot(x_range, np.ones_like(train), \"--\", color=\"gray\", linewidth='0.7')\n",
    "        # legend2 = ax2.legend(loc='upper right', framealpha=0.5, facecolor='white')\n",
    "        # legend2.set_zorder(100)\n",
    "        if len(train_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in train_list:\n",
    "                    print(x_range, s)\n",
    "                    ax1.plot(x_range, s, line, color=colors(0.4 + color_add), alpha=0.3, linewidth='2', zorder=0)\n",
    "            else:\n",
    "                ax2.fill_between(x_range, train - train_std, train + train_std, alpha=0.2,\n",
    "                                 facecolor=colors(0.4 + color_add))\n",
    "\n",
    "        if color_axis:\n",
    "            ax2.yaxis.label.set_color(colors(0.4 + color_add))\n",
    "        # else:\n",
    "        #     legend2 = ax2.legend(loc='upper right', framealpha=0.99, facecolor='white')\n",
    "        #     legend2.set_zorder(100)\n",
    "            \n",
    "        ax2.set_ylabel(y_label2, color=\"black\",fontsize=14)\n",
    "        ax1.tick_params(axis='both', labelsize=14) \n",
    "        ax2.spines['top'].set_visible(False)\n",
    "    else:\n",
    "        ax1.spines['right'].set_visible(False)\n",
    "        # train_avg = moving_average(train, rw)\n",
    "        if line != \"-\":\n",
    "            ax1.scatter(x_range, train, s=[100 for _ in x_range],\n",
    "                        marker=\"+\", color=colors(0.3 + color_add), alpha=1, label=title1, zorder=3, linewidths=3)\n",
    "        else:\n",
    "            ax1.plot(x_range, train, line, color=colors(0.3 + color_add), label=title1, linewidth='3', zorder=11)\n",
    "        # ax1.plot(x_range[:len(train_avg)], train_avg, line, color=colors(0.3+color_add), label=title1)\n",
    "        if len(train_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in train_list:\n",
    "                    ax1.plot(x_range, s, line, color=colors(0.3 + color_add), alpha=0.3, linewidth='2', zorder=0)\n",
    "            else:\n",
    "                ax1.fill_between(x_range, train - train_std, train + train_std,\n",
    "                                 alpha=0.5, facecolor=colors(0.3 + color_add))\n",
    "\n",
    "        # ax1.legend(loc='best', framealpha=1, facecolor='white')\n",
    "        # ax1.spines['right'].set_visible(False)\n",
    "        # legend = ax1.legend(loc='upper right', framealpha=0.99, facecolor='white')\n",
    "        # legend.set_zorder(100)\n",
    "\n",
    "    # legend1 = ax1.legend(loc=loc_first, framealpha=0.99, facecolor='white')\n",
    "    # legend1.set_zorder(100)\n",
    "    if second_axis:\n",
    "        ax2.set_ylabel(y_label2,fontsize=14)\n",
    "        ax1.tick_params(axis='both', labelsize=14) \n",
    "        ax1.set_ylabel(y_label1,fontsize=14)\n",
    "        ax1.tick_params(axis='both', labelsize=14) \n",
    "        ax1.set_ylim(y_lim_l, y_lim_u)\n",
    "        # legend1 = ax1.legend(loc=loc_sec, framealpha=0.99, facecolor='white')\n",
    "        # ax2.set_ylim(y_lim_l2, y_lim_u2)\n",
    "        # ax1.set_ylim(bottom=0)\n",
    "    else:\n",
    "        ax1.set_ylabel(label_title, fontsize=14)\n",
    "    # pl.ylim(y_lim_l, y_lim_u)\n",
    "        pl.ylim(y_lim_l, y_lim_u)\n",
    "    ax1.spines['top'].set_visible(False)\n",
    "    \"\"\"---adding new--------\"\"\"\n",
    "    handles1, labels1 = ax1.get_legend_handles_labels()\n",
    "    if second_axis:\n",
    "        handles2, labels2 = ax2.get_legend_handles_labels()\n",
    "        handles = handles1 + handles2\n",
    "        labels = labels1 + labels2\n",
    "    else:\n",
    "        handles, labels = handles1, labels1\n",
    "    \"\"\"---------\"\"\"\n",
    "    legend = ax1.legend(handles, labels,\n",
    "                    loc='upper center',\n",
    "                    bbox_to_anchor=(0.5, 1.25),   # 图例在上方\n",
    "                    ncol=3,                      \n",
    "                    framealpha=0.9,\n",
    "                    facecolor='white',\n",
    "                    fontsize=10,\n",
    "                    handlelength=1.5,   # 控制线段长度 (默认 2)\n",
    "                    handletextpad=0.5   # 线段与文字间距\n",
    "                   )\n",
    "    legend.set_zorder(100)\n",
    "\n",
    "\n",
    "    if second_axis:   \n",
    "        ax2.set_ylabel(y_label2, fontsize=10, color=\"black\")\n",
    "        ax1.set_ylabel(y_label1, fontsize=10)\n",
    "        # if ax2 is None:\n",
    "        #     ax2 = ax1.twinx()\n",
    "        ax2.set_zorder(0)\n",
    "        ax1.set_zorder(1)\n",
    "        ax1.set_frame_on(False)\n",
    "\n",
    "\n",
    "    \n",
    "        # 右侧曲线\n",
    "        ax2.plot(x_range, train, color=colors(0.4 + color_add),\n",
    "                 label=title1, linewidth='3')\n",
    "        ax2.plot(x_range, np.ones_like(train), \"--\", color=\"gray\", linewidth='0.7')\n",
    "    \n",
    "        legend2 = ax2.legend(loc='upper right', framealpha=0.5,\n",
    "                             facecolor='white', fontsize=14)\n",
    "        legend2.set_zorder(100)\n",
    "        ax2.get_legend().remove()\n",
    "        if len(train_list) > 1:\n",
    "            if single_seeds:\n",
    "                for s in train_list:\n",
    "                    ax1.plot(x_range, s, line, color=colors(0.4 + color_add),\n",
    "                             alpha=0.3, linewidth='2', zorder=0)\n",
    "            else:\n",
    "                ax2.fill_between(x_range, train - train_std, train + train_std,\n",
    "                                 alpha=0.2, facecolor=colors(0.4 + color_add))\n",
    "    \n",
    "        # 坐标轴标题字体\n",
    "        ax1.set_ylabel(y_label1, fontsize=14)                 # 左边标题\n",
    "        ax2.set_ylabel(y_label2, color=\"black\", fontsize=14)  # 右边标题\n",
    "    \n",
    "        # 刻度字体大小\n",
    "        ax1.tick_params(axis='both', labelsize=14)  # 左边 y + x\n",
    "        ax2.tick_params(axis='y', labelsize=14)     # 右边 y\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    \n",
    "    if plot_title is not None:\n",
    "        pl.title(plot_title)\n",
    "\n",
    "    if yscale_log:\n",
    "        ax1.set_yscale(\"log\")\n",
    "    # pl.title(title)\n",
    "    pl.tight_layout()\n",
    "\n",
    "    if allow_download:\n",
    "        if second_axis:\n",
    "            pl.savefig(title, format=\"pdf\")\n",
    "            # % download_file\n",
    "            # sim.pdf\n",
    "        else:\n",
    "            pl.savefig(title, format=\"pdf\")\n",
    "            # % download_file\n",
    "            # train.pdf\n",
    "    else:\n",
    "        img = grab_plot()\n",
    "        display(Image(data=imencode(img, fmt='jpeg')), display_id=title)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "76cecb9c-f921-4904-9039-138294407309",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# @title Lists\n",
    "\n",
    "loss_trans_list = [[] for _ in range(config.num_seeds)]\n",
    "loss_trans_train_list = [[] for _ in range(config.num_seeds)]\n",
    "losses_gd_list = [[] for _ in range(config.num_seeds)]\n",
    "losses_gd_list_trained = [[] for _ in range(config.num_seeds)]\n",
    "losses_int_list_trained = [[] for _ in range(config.num_seeds)]\n",
    "cos_sim_list, cos_sim_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "grad_norm_list, grad_norm_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "p_norm_list, p_norm_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "cos_sim_list, cos_sim_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "grad_norm_list, grad_norm_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "p_norm_list, p_norm_list_o = [[] for _ in range(config.num_seeds)], [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "ir_t_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_t_list = [[] for _ in range(config.num_seeds)]\n",
    "ir_gd_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_gd_list = [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "ir_t_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_t_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "ir_gd_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_gd_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "ir_gd_trained_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_gd_trained_list = [[] for _ in range(config.num_seeds)]\n",
    "ir_gd_ood_trained_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_gd_ood_trained_list = [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "ir_inter_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_inter_list = [[] for _ in range(config.num_seeds)]\n",
    "ir_inter_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "ws_inter_ood_list = [[] for _ in range(config.num_seeds)]\n",
    "\n",
    "losses_noisy_list = [[] for _ in range(config.num_seeds)]\n",
    "losses_gd_noisy_list = [[] for _ in range(config.num_seeds)]\n",
    "losses_gd_noisy_trained_list = [[] for _ in range(config.num_seeds)]\n",
    "losses_inter_noisy_list = [[] for _ in range(config.num_seeds)]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4c7a5fba-d6b7-48c9-8392-2e77fbf22ea4",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# @title Logic how to interpolate weights\n",
    "def interpolate_weights(train_state, params_gd, deq=False):\n",
    "    if (config.num_heads == 1 and\n",
    "            config.sum_norm == False and config.deq == True and\n",
    "            config.layer_norm == False and config.att_only_trans == True):\n",
    "\n",
    "        cur_train_params = {k.replace('transformer', 'Transformer_gd'): v.copy() for\n",
    "                            k, v in train_state.params.items()}\n",
    "\n",
    "        inter_params = {k.replace('transformer', 'Transformer_gd'): {'w': jnp.zeros_like(v['w'])} for\n",
    "                        k, v in train_state.params.items()}\n",
    "\n",
    "        for k, v in cur_train_params.items():\n",
    "            if \"key\" in k:\n",
    "                key_gd = params_gd[k]['w'].copy()\n",
    "                key = cur_train_params[k]['w'].copy()\n",
    "            if \"linear\" in k:\n",
    "                linear_gd = params_gd[k]['w'].copy()\n",
    "                linear = cur_train_params[k]['w'].copy()\n",
    "            if \"query\" in k:\n",
    "                query_gd = params_gd[k]['w'].copy()\n",
    "                query = cur_train_params[k]['w'].copy()\n",
    "            if \"value\" in k:\n",
    "                value_gd = params_gd[k]['w'].copy()\n",
    "                value = cur_train_params[k]['w'].copy()\n",
    "\n",
    "                query = jnp.matmul(query, key.T)\n",
    "                # print(query)\n",
    "                key = jnp.identity(query.shape[0])\n",
    "                mean = np.mean([query[a, a] for a in range(query.shape[0] - 1)])\n",
    "                query = query / mean\n",
    "                query_gd = jnp.matmul(query_gd, key.T)\n",
    "                key_gd = jnp.identity(query.shape[0])\n",
    "                query = (query + query_gd) / 2\n",
    "\n",
    "                linear = jnp.matmul(value, linear)\n",
    "                # print(linear)\n",
    "                value = jnp.identity(query.shape[0])\n",
    "                linear = linear * mean\n",
    "                linear_gd = jnp.matmul(value_gd, linear_gd)\n",
    "                value_gd = jnp.identity(query.shape[0])\n",
    "                linear = (linear + linear_gd) / 2\n",
    "\n",
    "                inter_params[k.replace('value', 'linear')]['w'] = linear\n",
    "                inter_params[k.replace('value', 'value')]['w'] = value\n",
    "                inter_params[k.replace('value', 'query')]['w'] = query\n",
    "                inter_params[k.replace('value', 'key')]['w'] = key\n",
    "\n",
    "        losses_int, _, _ = predict_test.apply(inter_params, eval_rng, eval_data, True)\n",
    "    else:\n",
    "        losses_int = None\n",
    "        inter_params = None\n",
    "    return losses_int, inter_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "34047498-9e22-4f50-a3bb-a9acd9e0808f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best lr found for  5  steps of gradient descent:  0.3801  with loss  0.4567448\n",
      "Loss of GD++ (we learn eta and gamma):  0 0.43024555\n",
      "Loss of GD++ (we learn eta and gamma):  100 0.4293015\n",
      "Loss of GD++ (we learn eta and gamma):  200 0.42939413\n",
      "Loss of GD++ (we learn eta and gamma):  300 0.42936385\n",
      "Loss of GD++ (we learn eta and gamma):  400 0.42860383\n",
      "Loss of GD++ (we learn eta and gamma):  500 0.42853093\n",
      "Loss of GD++ (we learn eta and gamma):  600 0.42897016\n",
      "Loss of GD++ (we learn eta and gamma):  700 0.42870736\n",
      "Loss of GD++ (we learn eta and gamma):  800 0.42901635\n",
      "Loss of GD++ (we learn eta and gamma):  900 0.42917752\n",
      "-----loss_trans 0.84109986\n",
      "-----loss_trans 0.82818747\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.7505975\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.7015273\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.6846181\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.67708087\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.6665423\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.6514329\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.6248184\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.5976242\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.5686365\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.542325\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.52315253\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.5049707\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4938133\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48999503\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48845658\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48728448\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48880178\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48692438\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4859715\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48496732\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48362672\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48682204\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48494425\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.49008796\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48358923\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48416469\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48545843\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48634568\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48510003\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48514533\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48322302\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48435563\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48507825\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4833802\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48445013\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48378092\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48687688\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4828299\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48324963\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48530138\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.484209\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48376775\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48357278\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48250458\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48459318\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4833226\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48375002\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4821218\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48351085\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48381755\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4806798\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48104656\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4811218\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48108646\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48033297\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48344\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.482138\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48136458\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48262638\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48117742\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48089066\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47942957\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47867444\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.48062557\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4799883\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4778888\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47749934\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47895765\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47871286\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47848722\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47721258\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47789046\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47721496\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47870344\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47958577\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47957098\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.4782127\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----loss_trans 0.47720906\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('Current seed',\n",
       " 0,\n",
       " 'Training step',\n",
       " 7900,\n",
       " 'Gradient descent loss',\n",
       " 0.4567447900772095,\n",
       " 'GD ++ loss',\n",
       " 0.4316410422325134,\n",
       " 'Trained TF loss',\n",
       " 0.47720906138420105,\n",
       " 'Interpolated model loss',\n",
       " 38.85091018676758,\n",
       " 'Cosine sim TF vs GD',\n",
       " 0.9633032083511353,\n",
       " 'Cosine sim TF vs GD++',\n",
       " 0.9534380435943604)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# @title Training\n",
    "\n",
    "# interpolate GD and trained TF\n",
    "inter = True if (config.deq and not config.use_softmax and config.num_heads == 1) else False\n",
    "\n",
    "eval_rng = jax.random.PRNGKey(5)\n",
    "for cur_seed in range(0, config.num_seeds):\n",
    "    # print(\"-------cur_seed\", cur_seed)\n",
    "    config.seed = cur_seed\n",
    "    optimiser, train_state, _, rng = init()\n",
    "    # print(\" ===nini\")\n",
    "    # print( train_state )\n",
    "    # print(len(train_state))\n",
    "    rng, data_rng = jax.random.split(rng, 2)\n",
    "    if config.analyse:\n",
    "        lr_min, min_loss = scan_lrs(eval_rng, lin_diag=False, bs=10000)\n",
    "        if cur_seed == 0:\n",
    "            print('Best lr found for ', config.num_layers, ' steps of gradient descent: ', lr_min / config.dataset_size,\n",
    "                  \" with loss \", min_loss)\n",
    "\n",
    "        params_gd = create_weights(config.input_size, 1, config.dataset_size, lr_min,\n",
    "                                   jax.random.normal(data_rng, shape=[1, 1, config.input_size])* 0 , # * 0\n",
    "                                   lin_diag=False, gd_deq=config.gd_deq,\n",
    "                                   num_layers=config.num_layers,\n",
    "                                   input_mlp_rnd=rng if (config.input_mlp or config.in_proj) else None,\n",
    "                                   in_proj=config.in_proj)\n",
    "        # print(\"params_gd\",params_gd)\n",
    "\n",
    "        if config.num_layers > 1 or (config.in_proj and config.num_layers == 1):\n",
    "            if cur_seed == 0:\n",
    "                lr_min, min_loss = scan_lrs(eval_rng, lin_diag=True, bs=10000)\n",
    "                params_init = create_weights(config.input_size, 1, config.dataset_size, lr_min,\n",
    "                                             jax.random.normal(data_rng, shape=[1, 1, config.input_size])* 0, # * 0\n",
    "                                             lin_diag=True, gd_deq=config.gd_deq,\n",
    "                                             num_layers=config.num_layers,\n",
    "                                             input_mlp_rnd=eval_rng if (config.input_mlp or config.in_proj) else None,\n",
    "                                             in_proj=config.in_proj)\n",
    "                params_gd_trained, data_rng = pre_train_gd_hps(eval_rng, params_init)\n",
    "        else:\n",
    "            params_gd_trained = params_gd\n",
    "    #\n",
    "    # print(\" config.input_size\", config.input_size)\n",
    "    # print(\"  config.dataset_size,\",  config.dataset_size)\n",
    "    eval_data = data_creator(jax.random.split(eval_rng, num=10000),\n",
    "                             config.input_size,\n",
    "                             config.dataset_size,\n",
    "                             config.size_distract,\n",
    "                             config.input_range,\n",
    "                             config.weight_scale)\n",
    "    if config.analyse:\n",
    "        # print(\"-----------,get in to---------\")\n",
    "        # # print(\"params_gd\", params_gd)\n",
    "        # print(\"eval_data seq\",eval_data[0].shape)\n",
    "        # print(\"eval_data target\", eval_data[1].shape)\n",
    "        # print(\"eval_data weight\", eval_data[2].shape)\n",
    "        #\n",
    "        # \"\"\"---------loss gd---------\"\"\"\n",
    "        loss_gd, _, _ = predict_test.apply(params_gd, eval_rng, eval_data, True)\n",
    "        loss_gd_trained, _, _ = predict_test.apply(params_gd_trained, eval_rng,\n",
    "                                                   eval_data, True)\n",
    "\n",
    "\n",
    "    original_data_rng = data_rng\n",
    "    i=0\n",
    "    for step in range(config.training_steps):\n",
    "      if config.cycle_data > 0:\n",
    "        if step % config.cycle_data == 0:\n",
    "          data_rng = original_data_rng\n",
    "\n",
    "      rng, data_rng = jax.random.split(data_rng, 2)\n",
    "      # print(\"training rng99999999999\",rng)\n",
    "      train_data = data_creator(jax.random.split(rng, num=config.bs),\n",
    "                                config.input_size,\n",
    "                                config.dataset_size,\n",
    "                                config.size_distract,\n",
    "                                config.input_range,\n",
    "                                config.weight_scale)\n",
    "      # print(\"----before--train_state params\",train_state.params)\n",
    "      train_state, metrics = update(train_state, train_data, optimiser)\n",
    "      if step % 100 == 0:\n",
    "        \"\"\"---------loss transformer---------\"\"\"\n",
    "        loss_trans, _, _ = predict_test.apply(train_state.params, eval_rng,\n",
    "                                              eval_data, False)\n",
    "        print(\"-----loss_trans\",loss_trans)\n",
    "        loss_trans_list[cur_seed].append(loss_trans)\n",
    "\n",
    "        loss_trans_train_list[cur_seed].append(metrics['train_loss'].item(),)\n",
    "        if config.analyse:\n",
    "          losses_gd_list[cur_seed].append(loss_gd)\n",
    "       \n",
    "\n",
    "          losses_int, inter_params = interpolate_weights(train_state, params_gd_trained)\n",
    "\n",
    "          losses_int_list_trained[cur_seed].append(losses_int)\n",
    "\n",
    "          #rng, data_rng, eval_rng = jax.random.split(data_rng, 3)\n",
    "          # Alignment Transformers and GD\n",
    "          cos_sim, w_norm, p_norm = analyse(eval_data, train_state, eval_rng,\n",
    "                                            params_gd)\n",
    "          cos_sim_o, w_norm_o, p_norm_o = analyse(eval_data, train_state, eval_rng,\n",
    "                                            params_gd_trained)\n",
    "          if step > 0:\n",
    "            # print(\"loss_gd_trained.item()\",loss_gd_trained.item())\n",
    "            display((\"Current seed\", cur_seed,\n",
    "                     \"Training step\", step, \"Gradient descent loss\", loss_gd.item(),\n",
    "                      \"GD ++ loss\", loss_gd_trained.item(),\n",
    "                      \"Trained TF loss\", loss_trans.item(),\n",
    "                      \"Interpolated model loss\", losses_int.item() if inter else \"-\",\n",
    "                      \"Cosine sim TF vs GD\", cos_sim.item(),\n",
    "                      \"Cosine sim TF vs GD++\", cos_sim_o.item() if config.num_layers > 1 else \"-\"),\n",
    "                      display_id=\"Cur met\")\n",
    "       \n",
    "          cos_sim_list[cur_seed].append(cos_sim)\n",
    "          grad_norm_list[cur_seed].append(w_norm)\n",
    "          p_norm_list[cur_seed].append(p_norm)\n",
    "          losses_gd_list_trained[cur_seed].append(loss_gd_trained.item())\n",
    "\n",
    "          cos_sim_list_o[cur_seed].append(cos_sim_o)\n",
    "          grad_norm_list_o[cur_seed].append(w_norm_o)\n",
    "          p_norm_list_o[cur_seed].append(p_norm_o)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "da170238-8210-40b1-ac57-149fdd44750a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.8410998582839966, 0.8281874656677246, 0.7505974769592285, 0.7015272974967957, 0.6846181154251099, 0.6770808696746826, 0.6665422916412354, 0.6514328718185425, 0.6248183846473694, 0.5976241827011108, 0.5686364769935608, 0.5423250198364258, 0.5231525301933289, 0.5049707293510437, 0.49381330609321594, 0.4899950325489044, 0.4884565770626068, 0.48728448152542114, 0.4888017773628235, 0.4869243800640106, 0.48597151041030884, 0.48496732115745544, 0.48362672328948975, 0.4868220388889313, 0.48494425415992737, 0.49008795619010925, 0.483589231967926, 0.48416468501091003, 0.4854584336280823, 0.48634567856788635, 0.48510003089904785, 0.48514533042907715, 0.483223021030426, 0.484355628490448, 0.48507824540138245, 0.48338019847869873, 0.4844501316547394, 0.4837809205055237, 0.48687687516212463, 0.48282989859580994, 0.48324963450431824, 0.4853013753890991, 0.48420900106430054, 0.4837677478790283, 0.483572781085968, 0.48250457644462585, 0.4845931828022003, 0.4833225905895233, 0.48375001549720764, 0.4821217954158783, 0.4835108518600464, 0.48381754755973816, 0.48067981004714966, 0.48104655742645264, 0.48112180829048157, 0.48108646273612976, 0.48033297061920166, 0.48344001173973083, 0.4821380078792572, 0.48136457800865173, 0.48262637853622437, 0.481177419424057, 0.4808906614780426, 0.47942957282066345, 0.47867444157600403, 0.48062556982040405, 0.47998830676078796, 0.4778887927532196, 0.4774993360042572, 0.4789576530456543, 0.47871285676956177, 0.4784872233867645, 0.4772125780582428, 0.4778904616832733, 0.4772149622440338, 0.47870343923568726, 0.47958576679229736, 0.47957098484039307, 0.47821271419525146, 0.47720906138420105]\n",
      "---p_norm_list\n",
      "[0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095, 0.4567447900772095]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "'\\n# 2:\\n# 0.56672347\\n# 0.56188846\\n5:\\n0.571959\\n0.56197524\\n\\n10\\n0.5745692\\n0.56199145\\n\\n15\\n0.57516754\\n0.56204414\\n\\n25;\\n\\n0.5765719\\n0.56224084\\n\\n'"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print([float(x) for x in loss_trans_list[0]])\n",
    "print(\"---p_norm_list\")\n",
    "print([float(x) for x in losses_gd_list[0]])   \n",
    "# print(loss_trans_list[0][-1])\n",
    "# print(losses_gd_list[0][-1])\n",
    "display_learning(loss_trans_list, test=losses_gd_list, y_lim_u=0.9, y_lim_l=0.4,\n",
    "                 rw=1, title=\"train_loss_layer1_doc2_dim10_R_all_0.pdf\", allow_download=True,   \n",
    "                 title1='Trained TF', title2='GD', single_seeds=True,second_axis=False,\n",
    "                 num_iter_os=len(loss_trans_list[0])*100)\n",
    "\n",
    "# 0.5139412879943848\n",
    "# 2:\n",
    "# 0.56672347\n",
    "# 0.56188846\n",
    "\"\"\"\n",
    "# 2:\n",
    "# 0.56672347\n",
    "# 0.56188846\n",
    "5:\n",
    "0.571959\n",
    "0.56197524\n",
    "\n",
    "10\n",
    "0.5745692\n",
    "0.56199145\n",
    "\n",
    "15\n",
    "0.57516754\n",
    "0.56204414\n",
    "\n",
    "25;\n",
    "\n",
    "0.5765719\n",
    "0.56224084\n",
    "\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bad6c23f-882e-4514-be67-833d110147e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display_learning(cos_sim_list_o, grad_norm_list, p_norm_list, title1=\"Partial cosine\",\n",
    "                 title2=\"Partial diff\", y_lim_u=2.5,\n",
    "                 title3=\"Preds diff\", second_axis=True,\n",
    "                 y_lim_u2=1,  color_add=0.2, loc_sec = 'lower left',\n",
    "                 y_lim_l2=0.8,\n",
    "                 rw=1, num_iter_os=len(cos_sim_list[0])*100, title=\"sim_layer1_doc2_dim10_R_w_all_0.pdf\",\n",
    "                 allow_download=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "33bd8779-c4c0-4422-b1da-0013c55c719a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.01488451473414898, 0.24034516513347626, 0.5463016629219055, 0.632989227771759, 0.6605537533760071, 0.6715195775032043, 0.6877228021621704, 0.7162724137306213, 0.7608907222747803, 0.8077932000160217, 0.8523134589195251, 0.8895808458328247, 0.9207809567451477, 0.9414463639259338, 0.9546831846237183, 0.9598259329795837, 0.9621407985687256, 0.9631851315498352, 0.9642993807792664, 0.9634947180747986, 0.9638466835021973, 0.9644044637680054, 0.9644529819488525, 0.9637818336486816, 0.9644536972045898, 0.9642395973205566, 0.9643325805664062, 0.964299201965332, 0.9646262526512146, 0.9643584489822388, 0.9643864035606384, 0.9647175669670105, 0.964537501335144, 0.964845597743988, 0.9643481969833374, 0.9646847248077393, 0.9647567868232727, 0.9646455645561218, 0.9640781283378601, 0.9652612805366516, 0.9642566442489624, 0.9643917679786682, 0.965015709400177, 0.9643441438674927, 0.9647429585456848, 0.9649603962898254, 0.9655185341835022, 0.9649274945259094, 0.9641247987747192, 0.9644367098808289, 0.9638968706130981, 0.9646196961402893, 0.9650458693504333, 0.9648552536964417, 0.9645453095436096, 0.9637913703918457, 0.9649539589881897, 0.9645745754241943, 0.964766263961792, 0.9644249677658081, 0.9637802243232727, 0.9641081690788269, 0.9638733863830566, 0.9647077918052673, 0.9642075896263123, 0.9635871052742004, 0.9636783003807068, 0.9640102982521057, 0.9642999768257141, 0.9637343287467957, 0.9633336663246155, 0.9638433456420898, 0.9638871550559998, 0.9632827639579773, 0.9633694887161255, 0.9625527262687683, 0.9624134302139282, 0.9633190035820007, 0.9627329707145691, 0.9633032083511353]\n",
      "-----------\n",
      "[1.39322829246521, 1.2239124774932861, 0.9433386325836182, 0.8456500768661499, 0.8115862607955933, 0.7981546521186829, 0.7782276272773743, 0.7418847680091858, 0.680158257484436, 0.6073706746101379, 0.5282544493675232, 0.45287254452705383, 0.3789599537849426, 0.3206943869590759, 0.27489590644836426, 0.25275227427482605, 0.24077394604682922, 0.23551137745380402, 0.2295866161584854, 0.23384052515029907, 0.23196186125278473, 0.22876596450805664, 0.228816956281662, 0.23264381289482117, 0.22920024394989014, 0.23038332164287567, 0.2294308990240097, 0.22956325113773346, 0.22837181389331818, 0.22970294952392578, 0.22991637885570526, 0.2274118810892105, 0.22867770493030548, 0.22647421061992645, 0.23010683059692383, 0.22750024497509003, 0.22719618678092957, 0.2276763617992401, 0.2312852442264557, 0.2247174233198166, 0.22941820323467255, 0.2297736257314682, 0.22628356516361237, 0.22962060570716858, 0.22762125730514526, 0.2259259670972824, 0.2225617617368698, 0.2263515591621399, 0.23114030063152313, 0.22849321365356445, 0.23215560615062714, 0.22775712609291077, 0.2252693772315979, 0.22655844688415527, 0.22780907154083252, 0.23231108486652374, 0.22591276466846466, 0.22771169245243073, 0.22691453993320465, 0.22831566631793976, 0.23224464058876038, 0.23008036613464355, 0.23098647594451904, 0.22666025161743164, 0.2294706553220749, 0.23208138346672058, 0.23190374672412872, 0.23024867475032806, 0.22849410772323608, 0.23159155249595642, 0.23348969221115112, 0.2307090312242508, 0.2305913269519806, 0.23365101218223572, 0.2332657128572464, 0.23753373324871063, 0.23781079053878784, 0.23332801461219788, 0.23628747463226318, 0.23339875042438507]\n",
      "-----------\n",
      "[0.6351759433746338, 0.6219488382339478, 0.5449684858322144, 0.4960799813270569, 0.4766864478588104, 0.46859192848205566, 0.45867934823036194, 0.44179466366767883, 0.4111008048057556, 0.3718119263648987, 0.3294554352760315, 0.2866169810295105, 0.24429632723331451, 0.2112703025341034, 0.17868342995643616, 0.16912029683589935, 0.16071556508541107, 0.15830792486667633, 0.15330860018730164, 0.1572786569595337, 0.1562567502260208, 0.15324033796787262, 0.15278534591197968, 0.156387060880661, 0.15203960239887238, 0.15602129697799683, 0.15276660025119781, 0.15347345173358917, 0.15275967121124268, 0.1533026546239853, 0.15496930480003357, 0.15152573585510254, 0.15364022552967072, 0.15101540088653564, 0.15371385216712952, 0.15163670480251312, 0.15042324364185333, 0.1515030711889267, 0.15601247549057007, 0.15103620290756226, 0.15155453979969025, 0.15273605287075043, 0.1514236330986023, 0.15334491431713104, 0.15300799906253815, 0.14958029985427856, 0.14776058495044708, 0.15096116065979004, 0.15556849539279938, 0.15333662927150726, 0.15710550546646118, 0.15281635522842407, 0.15079142153263092, 0.15192504227161407, 0.1525518000125885, 0.1544785499572754, 0.15091915428638458, 0.15304486453533173, 0.1522151380777359, 0.1547737717628479, 0.15539953112602234, 0.15405765175819397, 0.15517987310886383, 0.15205134451389313, 0.15389329195022583, 0.15625455975532532, 0.15672944486141205, 0.15501956641674042, 0.1536436676979065, 0.1562490612268448, 0.15780112147331238, 0.1572674810886383, 0.1564815640449524, 0.15882760286331177, 0.15706533193588257, 0.16065022349357605, 0.16221044957637787, 0.1580202579498291, 0.1601090282201767, 0.1575974076986313]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "print([float(x) for x in cos_sim_list[0]])\n",
    "print(\"-----------\")\n",
    "print([float(x) for x in grad_norm_list[0]])\n",
    "print(\"-----------\")\n",
    "\n",
    "print([float(x) for x in p_norm_list[0]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3d79a29b-584a-461d-9084-988e7d0d9eb8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "plt.rcParams.update({'font.size': 23})\n",
    " \n",
    "x = [2, 5, 10, 25]\n",
    " \n",
    "\n",
    "\"\"\"\n",
    "\n",
    "\n",
    "\"\"\"\n",
    "loss_trans = [0.56,0.57,0.57,0.57]  \n",
    "losses_gds = [0.56,0.56,0.57,0.57]  \n",
    "\n",
    "plt.figure(figsize=(7,5))\n",
    "plt.ylim(0, 1)\n",
    " \n",
    "plt.scatter(x, losses_gds, marker=\"v\", color=\"green\", s=200, label=\"RAG\")\n",
    "plt.scatter(x, loss_trans, marker=\"+\", color=\"blue\", s=200, label=\"Trained TF\")\n",
    "\n",
    " \n",
    "plt.xscale(\"log\")\n",
    "plt.xticks(x, labels=[str(i) for i in x])  # 显式显示你的横坐标点\n",
    "\n",
    " \n",
    "plt.xlabel(\"Num document\",fontsize=23)\n",
    "plt.ylabel(\"Loss\",fontsize=23)\n",
    "# plt.title(\"Comparison of GD and Trained Transformer\")\n",
    "plt.legend()\n",
    "plt.grid(False)\n",
    "ax = plt.gca()\n",
    "ax.spines[\"top\"].set_visible(False)\n",
    "ax.spines[\"right\"].set_visible(False)\n",
    "# plt.scatter(x, losses_gds, marker=\"v\", color=\"green\", s=80, label=\"RAG\")\n",
    "# plt.scatter(x, loss_trans, marker=\"+\", color=\"blue\", s=100, label=\"Trained TF\")\n",
    "plt.savefig(\"R2_different_doc.pdf\",format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9faf8d49-934d-4638-bbc0-5898bff618ce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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SUnavXu3eT+3g/g9PDzUvn178z4hEUUlr7/F58+fV8+ePVWtWjX5+PioXLlyatSokR588EEtX768UGokJJZC8+bNM5dvvfVWF1YC5G79+vX6448/dPnyZSUlJenEiRNatWqVXnzxRdWuXVuTJk1S2mE7gLR3716lpqZKksqWLevQHJrXXXedubxr165Cqw3IKK+/xZcuXdKyZct08uRJXb16VRcvXtTevXv18ccfq0ePHmrdurUOHDjg1BqZAqeU2bVrlz7++GPz/ogRI1xYDZCzypUr65ZbblGDBg0UHBysS5cuaefOnVq5cqUSEhKUmJioMWPG6MCBA5oxY4ary0UxkHGC4po1azq0TWhoaJbbA4Ulr7/FHh4eat26tVq2bKlq1arJw8NDf/31l9asWWNO87Rlyxa1bt1aa9euVZMmTZxSJyGxFImPj9d9991nzjnWr18/RUREuLYoIAvt2rXTqlWr1LFjR3l4WHd4nDlzRk899ZTmzJkjSfr444/Vtm1bPfzww0VdKoqZS5cumcuBgYEObZNxns2M2wOFIa+/xZMmTdIDDzygypUrZ7l+8eLF+ve//60zZ84oNjZWffr00e7du+Xn51fgWtndXErY7XYNHTpU27dvl5T2P+zp06e7tiggG927d1enTp2yDIhS2vE7n3/+uYYOHWo+FhkZqaSkpKIqEcVUQkKCuezj4+PQNhl/TK9cueL0moB0+fktfv7557MNiJLUp08frVy50vxP0ZEjR/TBBx84pV5CYilgGIZGjBihb775RpIUHByshQsXqkKFCi6uDCiY//3vfwoKCpKUtpvw559/dnFFcDV/f39zOTk52aFtMl7thav3oLAU5m9x06ZN9eSTT5r3Mx7vWBCExFJg5MiR+uijjySlXeZqxYoVuummm1xcFVBw5cuXV5cuXcz7xXWuMRSdMmXKmMvx8fEObZNx9DDj9oAzFfZvccbpnjZt2mTOFVoQhEQ3N2rUKL377ruSpKCgIC1fvlw333yzi6sCnCfjmalMiYOqVauay8ePH3dom4ztqlSp4vSagKL4Lc74XZiSkuKUuRcJiW5s1KhReueddySlHcC9bNkyhYeHu7gqwLlsNpurS0Ax0qBBA/NY1osXL+rs2bO5bnPw4EFzOburswD5VVS/xYXxXUhIdFMjR440P5QBAQH69ttvmRMRbinjDzyj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",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\"\"\"----R1\"\"\"\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "plt.rcParams.update({'font.size': 23})\n",
    " \n",
    "x = [2, 5, 10, 25]\n",
    "\n",
    " \n",
    "loss_trans = [0.94,2.08,4.20,10.55] \n",
    "losses_gds = [0.94,2.08,4.20,10.50]\n",
    "\n",
    "plt.figure(figsize=(7,5))\n",
    "\n",
    " \n",
    "plt.scatter(x, losses_gds, marker=\"v\", color=\"green\", s=200, label=\"RAG\")\n",
    "plt.scatter(x, loss_trans, marker=\"+\", color=\"blue\", s=200, label=\"Trained TF\")\n",
    "\n",
    " \n",
    "plt.xscale(\"log\")\n",
    "plt.xticks(x, labels=[str(i) for i in x])   \n",
    "\n",
    " \n",
    "plt.xlabel(\"Num document\",fontsize=23)\n",
    "plt.ylabel(\"Loss\",fontsize=23)\n",
    "# plt.title(\"Comparison of GD and Trained Transformer\")\n",
    "plt.legend()\n",
    "plt.grid(False)\n",
    "ax = plt.gca()\n",
    "ax.spines[\"top\"].set_visible(False)\n",
    "ax.spines[\"right\"].set_visible(False)\n",
    "\n",
    "plt.savefig(\"R1_different_doc.pdf\",format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "96af6c4a-1773-4566-ad3e-451b8397b568",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6RdHZImKUByV5WisdoqjsqdOnRLbHTt2LFWx2LJlS3h5eQEAcnJysGnTJpVxderUwYoVKxAXF4dVq1ZhxIgR8PLyQp06dWBqagpra2vUr18f7dq1w+TJk7F161YkJCRg9erVLGKJiKoIjsiSVtVtRBYoGJXdf3M/+nr2rRajsUTGyhhfX4hIfzgiS6TC/M7z4ebghnmB8wydChEREanBnb2IVPBx8kHMOzGQSCSGToWIiIjU4IgskRosYomIiCo3FrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERm9uXPnQiKRQCKRYP369YZOp9zFxcWJzzcwMNDQ6RARGQwLWaJqTLEg0sfjtddeM/RTIh2sX79erz93xX88vPbaayW+vmXLlgb7XhCRcWMhS0RERERGSWboBCq75ORkbN68GQcOHMCVK1eQmJiIvLw82Nvbo2nTpvDz88OYMWPQokULnfrLycnBhg0bsGPHDkRGRuLJkyeoUaMGmjRpgoEDB2LcuHGws7MrUY5nz57F+vXrcfr0aTx48AAmJiZwcXFB9+7dMW7cOHh7e5fmqVM1UKNGDSxZskRjzMKFC5GUlAQAeOONN9C4cWO1sbr+f0CG1aZNG40/96SkJCxcuFA81vY70qZNG5Vf7969O3r06KE1nzp16miNISJSSSC1du3aJdSqVUsAoPEhkUiESZMmCbm5uRr7u3r1qtC8eXONfTVs2FA4c+aMTvnl5OQIEyZM0NifTCYTZs+eXabvQ0pKigBASElJKdX1WVlZQmRkpJCVlVWmPMgwXF1dxd+nEydOGDodEgQhNjZW/JkEBASUa/8l/TMxduxY8bo5c+boPbei+PpCVL1xRFaN/fv3Y/DgwZDL5QAAKysrvPLKK2jUqBHMzc1x9+5dHDx4EAkJCRAEAT/++COSk5Pxyy+/qOwvLi4O3bt3R0JCAgDAwcEBgwYNgpubGx4+fIhdu3YhISEBd+/eRVBQEE6dOgVfX1+1+QmCgNdeew1bt24FAEgkEvTo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1gz+/v4ICgrSuIZs3bp1ceHCBaxbtw6bNm3CP//8g/T0dDg7O6N9+/aYNGkSAgICEBcXV3FPkIioEpMIAvclUmfhwoUICQnRupGBRCLBlClTsGTJEo07bV25cgXDhw9HVFSU2hgXFxds3rwZnTp10ppfTk4O3nzzTaV1a4syMTHBxx9/jAULFmjtT53U1FTY29sjJSVFnBNYEtnZ2YiNjYW7u7vWNW8rg4yM/3b/Sk/nEltElZmxvb4QkX6xkNUiPj4eP//8M06cOIHIyEgkJSUhPz8fDg4OaNKkCTp27Ihx48YprQOpSU5ODn7++Wfs2LEDkZGRePr0KRwdHeHh4YGBAwdiwoQJJS4Wz5w5g3Xr1uHMmTN48OABTExM4OLigm7dumH8+PFl3pe9uhWyRGQ8+PpCVL2xkCWtWMgSUWXF1xei6o2rFhARERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsVRjuhkxE+sbXFaLqjYUslTuptODXTC6XGzgTIqpq8vPzAQAmJiYGzoSIDIGFLJU7U1NTmJiYICMjw9CpEFEVk56eDplMBplMZuhUiMgAWMhSuZNIJLC1tUVqairfBiQivcnPz0dKSgrs7e0hkUgMnQ4RGQALWaoQ9vb2eP78OR48eMBilojKLDc3F3fu3AEAODg4GDYZIjIYvhdDFcLKygouLi6Ij49HVlYW7OzsYGVlBRMTE46kEJFWgiBALpcjJycHGRkZyMjIgEwmg5ubG8zMzAydHhEZiETg8BhpkZqaCnt7e6SkpMDOzq5MfWVmZiIlJQVpaWnihzSIiHQlkUhgaWkJGxsb2Nvbc24sUTXHVwCqUFZWVrCysoKTkxOeP3/OlQyISGdSqRQymUxcCYWIiIUsGYREIuHbgURERFQm/GctERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUs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EhYWpjWHM2fOiG1fXy71QURERMaPc2RVaNmyJcaOHatT7M8//yy2Bw0aBBsbG7GPQrVr10aHDh0QFhYGuVyO0NBQTJgwQW2fO3fuFNv9+vUrtj1t4dd//fVXAMCOHTswdepUtf3dvHlT3J7W0tISPXv21Om5EREREVVmEkEQBEMnYcwUpxfExsbCzc1NZdyPP/6IN954AwDQtGlTXL58WWn1gUKPHj1C8+bNkZiYCAA4evSoyk0YEhMT4erqKn7YS10cAIwaNQqbN28W2xs3btT9CaJgHVl7e3ukpKTAzs6uRNcSERERlRdOLagg48aNE7eSvXnzJkaPHq20HiwAPHv2DIMHDxaL2G7duqktTmvWrInp06eLx6NHj0ZERESxuC+++EIsYs3MzDBvHhdfJiIioqqBI7JlpOuILAD8+eef6Ny5s7gUlrOzMwYNGgQnJyfExcUhNDRUnD/r5OSE8+fPa+wvOzsb3bt3x9mzZwEApqam6Nu3L7y9vZGRkYFDhw4pFbcrV67EpEmTSvwcOSJLRERElREL2TIqSSELACdPnsSoUaNw//59tTFeXl7Ytm0bWrRoofX+SUlJGDNmjDhfVhVLS0ssWbIEb7/9ttb+VGEhS0RERJURC9kyKmkhCwApKSlYs2YNdu3ahejoaCQlJaFWrVrw8vLCkCFDMHbs2BJvSPDrr79i06ZN+OOPP5CQkAALCws0bNgQQUFBmDBhAho3blzSpyZiIUtERESVEQtZ0oqFLBEREVVG/LAXERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYUsERERERklFrJEREREZJRYyBIRERGRUWIhS0RERERGiYWsGoIg4Pz585g/fz6CgoLg5uYGKysrWFhYwNnZGd26dcPChQuRkJBQon7lcjl++eUX9OvXD66urrCwsECdOnXQtm1bfPbZZ3j06FGJc71y5QqmTp2K5s2bw97eHjY2NmjatCkmTpyIsLCwEvdHREREZAwkgiAIhk6istm3bx/efPNNPHjwQGushYUF5s+fj2nTpmmNjY+Px/DhwzUWlzVq1MDq1asxYMAArf0JgoDZs2dj0aJFyM/PVxv3v//9D8uXL4epqanWPlVJTU2Fvb09UlJSYGdnV6o+iIiIiPRNZugEKqPIyEilIrZx48bw8/NDw4YNYWlpidjYWOzfvx+PHj1CdnY2pk+fjocPH2LZsmVq+0xKSkKPHj0QFRUFALC0tMTAgQPh6emJpKQk7N27FzExMXj27BmGDh2K/fv3o1evXhrznDFjBj7//HPxuEOHDggICIBMJsMff/yBI0eOQBAErFq1CpmZmdiwYQMkEkkZvztERERElYRAxSxatEiwtbUV3n//feHq1asqY7KysoRJkyYJAMTH8ePH1fY5btw4Me6FF14QYmNjlc7n5eUJb731lhhTu3ZtISUlRW1/p0+fFmNNTEyETZs2FYs5cuSIYG1tLcZt2bJFt29AESkpKQIAjfkQERERVTROLVDhypUrcHFxQY0aNbTGBgUF4eDBgwCAgQMHIjQ0tFjM9evX0bx5c8jlcpiamiI8PBzNmzcvFieXy9GpUydx6sGnn36KefPmqbyvn58fzp07BwCYOXMmPvvsM5Vxq1atwqRJkwAAbm5uuH37NqTSkk2N5tQCIiIiqoz4YS8VvL29dSpiAeCdd94R2+fPn1cZs3nzZsjlcgDA4MGDVRaxACCVSvHpp5+Kxxs3blQZd/v2bbGItbKy0jg/d9y4cXBxcQEAxMXF4fTp0xqeDREREZHxYCFbRu7u7mI7MTFRZczevXvF9tChQzX21717dzg4OAAoKDzDw8M19te9e3c4Ojqq7U8mkyl9cGz37t0a709ERERkLFjIltH9+/fFdu3atYudz8nJQWRkpHjs7++vsT+pVIoOHTqIx6oK2UuXLuncHwB07NhRY39ERERExoiF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",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import FixedLocator, FixedFormatter, NullLocator\n",
    "\n",
    "x = [0.5, 0.75, 1, 1.25, 1.5, 1.75, 2]\n",
    "loss_trans = [0.56,2.30,12.60,53.20,170.90,452.71,1000]   # 1043.43\n",
    "losses_gds = [0.57,2.26,12.20,50.72,162.59,430.49,995]  # 992.1\n",
    "\n",
    "plt.figure(figsize=(7,5))\n",
    "\n",
    "plt.scatter(x, losses_gds, marker=\"v\", color=\"green\", s=200, label=\"RAG\")\n",
    "plt.scatter(x, loss_trans, marker=\"+\", color=\"blue\", s=200, label=\"Trained TF\")\n",
    "plt.ylim(-20, 1050)\n",
    "ax = plt.gca()\n",
    "ax.set_xscale(\"log\")\n",
    "\n",
    " \n",
    "ticks = [0.5, 1, 1.5, 2]\n",
    "ax.xaxis.set_major_locator(FixedLocator(ticks))\n",
    "ax.xaxis.set_major_formatter(FixedFormatter(['0.5', '1', '1.5', '2']))\n",
    "ax.xaxis.set_minor_locator(NullLocator())   \n",
    "\n",
    "plt.xlabel(r\"$\\alpha \\;\\;\\text{where } x \\sim U(-\\alpha, \\alpha)$\", fontsize=23)\n",
    "plt.ylabel(\"Loss\", fontsize=23)\n",
    "# plt.plot(x, y, marker=\"o\", label=r\"$\\alpha \\;\\;\\text{where } x \\sim U(-\\alpha, \\alpha)$\")\n",
    "plt.legend()\n",
    "plt.grid(False)\n",
    "\n",
    "ax.spines[\"top\"].set_visible(False)\n",
    "ax.spines[\"right\"].set_visible(False)\n",
    "\n",
    "plt.savefig(\"R2_out_distrubtion.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0232064f-05d4-4dda-8fb4-60f4afccfd27",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TIGNjY1R1925cwe9evXCgQMHUFBQoLWOUqnE5s2bMWTIECiVSgBAhw4ddPaeKhQKLF26VDx+8803ERERoVFv+/btWLlypXisWiYiIiKyZjJBEARzB2EN/vrrLzz77LMAiiZj3bx5E40aNTLq2vj4eLEXtFq1aujUqROaN28OT09PKJVK3Lt3D4cPH0Z8fLx4ja+vL06dOqV3+1lBEDB27FhxrVmZTIZ+/fqhQ4cOKCgowPHjx3HixAmx/rx587BixYrSvnSkpaXB3d0dqampXIqLiIiILAYTWSO9+eab+PTTTwEAPXv2xNGjR42+VjWRNcagQYOwfv16oyaS5ebmYsaMGdi4caPOOjY2Npg3bx6WLVtmdAyqmMgSERGRJWIia4S8vDzUqVMHT548AVD0df24ceOMvl6pVOLs2bM4ffo0Tp8+jevXryMxMRFPnjyBUqmEh4cHGjdujC5dumDChAnw9/cvdYxRUVHYuHEjoqKicP/+fdjY2MDX1xe9e/fGtGnTytRmMSayREREZImYyJJBTGSJiIjIEnGyFxERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVFKa+YVJSErZt24a///4bjo6O6N69O0JDQyGTyUwdChERERFZMZkgCIIUDT1+/BgzZ84EAIwYMQJjxozRqBMdHY3BgwcjJSVF7fnAwEDs27cP7u7uUoRCEktLS4O7uztSU1Ph5uZm7nCIiIiIAEg4tCA8PBw//PAD9uzZg5YtW2qcz8jIwKhRo5CcnAxBENQe0dHRGD9+vFShEBEREVEVIFkie/jwYQBAw4YN0apVK43za9euxcOHDyGTydCoUSOsXLkSK1euRO3atSEIAg4cOIDIyEipwiEiIiKiSk6yMbIXLlyATCZDx44dtZ7fvn07AMDNzQ2nTp1CjRo1AACDBg1C69atIQgCduzYgeDgYKlCIiIiIqJKTLIe2Xv37gEAGjdurHHu6dOniImJgUwmw5gxY8QkFgBatGiBHj16QBAE/PHHH1KFQ0RERESVnGSJbEZGBgDA1dVV49ypU6dQPKcsJCRE47y/vz8A4O7du1KFQ0RERESVnGSJrEJRNEohOztb49ypU6cAADKZDN26ddM4X716dQD/JsNERERERIZIlsh6eXkBAG7duqVx7ujRowCA5s2bw9PTU+N8cfJrZ2cnVThEREREVMlJlsgWT9g6ePAgcnJyxOdv3ryJM2fOQCaToXv37lqvLR5SUKtWLanCISIiIqJKTrJEdvDgwQCAJ0+eYMyYMYiJiUF0dDTGjh0rjo8dPny41mvPnTsHmUwGPz8/qcIhIiIiokpOsp29cnJy0Lx5c50Tttq2bYuzZ89qPB8fH49GjRpBJpNhwYIFWLp0qRThkIS4sxcRERFZIsl6ZB0cHPDrr7+iTp06Gjt31alTR1xHtqTvvvtOLPfs2VOqcIiIiIiokpNsQwQAaNmyJa5evYpdu3YhJiYGhYWF8Pf3x/PPPw8XFxet18TGxiIoKAh2dnY6x9ASEREREZUk2dACqrw4tICIiIgskWRDC4iIiIiITImJLBERERFZJZMnskePHsXw4cPRsmVLtGvXDm+99RYePHhg6jCIiIiIyMpJNkb277//FrefXbRoEV599VWNOl9//TVmzpyp8byXlxeOHTuGli1bShEKSYxjZImIiMgSSdYjGx4ejidPnuDp06cYOXKkxvm7d+/izTff1FiaSxAEPHnyBKNGjUJhYaFU4RARERFRJSdZInv06FEAQJs2bbRuNfvFF18gLy8PMpkMw4YNw+nTp3H69GkEBwcDKOrR3bVrl1ThEBEREVElJ1kie/XqVchkMrRt21br+R9++AEAUK9ePezatQsdOnRAhw4d8OOPP8LJyQkAsHfvXqnCISIiIqJKTrJEtnjClq+vr8a5+Ph43LlzBzKZDBMmTICNjY14zsPDAwMHDoQgCIiJiZEqHCIiIiKq5CRLZLOzswEAjo6OGudOnz4tlvv27atxvnHjxgCAhw8fShUOEREREVVykiWyDg4OAIDU1FSNc9HR0QAAW1tbdOjQQeO8u7s7ACAnJ0eqcIiIiIiokpMskfXx8QEAXLlyRePcoUOHIJPJ0K5dO9jb22ucL05+nZ2dpQqHiIiIiCo5yRLZdu3aQRAEHDp0CAkJCeLzR48exc2bNwFAXKGgpBs3bgAAateuLVU4RERERFTJKaRqaNy4cfj++++Rm5uL4OBgvPrqq8jKysLHH38s1nn++ee1XvvHH39AJpOhefPmUoVDRERERJWcZIlsaGgoevbsiYiICMTFxWH27NkAAEEQIJPJMHbsWLRo0ULjunPnziEhIQEymQydO3eWKhwiIiIiquQkG1oAFK0DO3ToULVduwBg8ODBWLt2rdZr1q1bJ5b79OkjZThEREREVIlJ1iMLAK6urvjxxx8RFxeHmJgYFBYWonXr1mjWrJnOaxo3boxFixbBzs4O/v7+UoZDRERERJWYTCjuNiXSIS0tDe7u7khNTYWbm5u5wyEiIiICIPHQAiIiIiIiU2EiS0RERERWqcIS2StXruDtt99Gly5dUKNGDdja2sLW1hY1atRAYGAg3n77bcTGxlbU7SWxePFiyGQyox/Vq1c3qt3c3FysW7cOffv2ha+vL+zt7eHj44Pu3bvj008/RVpaWqljPXHiBKZPn46mTZvCxcUF7u7uaNmyJd544w1cunSp1O0RERERWTrJx8impKTg5Zdfxg8//CA+V/IWMplMLI8aNQrffPMNPDw8pAxDEosXL0ZYWJjR9b28vPDkyRO9df766y+MHTtW6w5oxerVq4dt27aha9euBu+Zl5eHV199FevXr9dZR6FQYMGCBaV6Lao4RpaIiIgskaSrFjx+/BiBgYG4ffu2RvKqSvXc7t27cf78eURHR6NGjRpShiOpMWPGoF27dnrrODk56T0fHx+PPn364OHDhwAADw8PjBgxAg0aNMCDBw/w448/4uHDh7h79y5CQkLw+++/IyAgQGd7giBgypQp2LFjB4CifyD07dsXHTp0QEFBAX7//XecPHkSBQUFWLJkCQoLC7Fs2bJSvnIiIiIiCyVIqHv37oJMJhNkMpmgUCiECRMmCL/88ouQkJAg5OTkCDk5OUJCQoKwb98+YeLEiYKtra0gl8sFmUwmBAUFSRmKJBYtWiQAEAAIGzduLHd7PXv2FNsLDAwUnjx5onY+KytLGDp0qFinRYsWQkFBgc72tmzZItZ1cXERDh8+rFHnu+++E2xsbMR6J0+eLHXcqampAgAhNTW11NcSERERVRTJxsju27cPUVFRkMlkqFOnDs6cOYPvvvsOoaGhqFOnDuzt7WFvb486depg0KBB2LJlC86ePYs6deoAAKKiorBv3z6pwrE4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zOszzzyDyZMna723QqHA0qVLxeM333wTERERGvW2b9+OlStXiseqZSIiIqo4AT4BCG0aCoXcuJGcCrkCg5sN5koFpVBhY2StXWZmJj755BN88skneOaZZ9CuXTvUr18frq6uyMjIwOXLl3H48GG1Za2mTJmC//znPzrb/Pbbb9G5c2c8fvwYJ06cgJ+fH0aOHIn69evj4cOH2LNnDx48eAAAcHFxwdatW6FQ6P4VTZo0Cfv378euXbuQnp6O3r17o1+/fujQoQMKCgpw/PhxnDhxQqw/b948BAYGSvDTISIiImOEBYdh3/V9RtVlb2zpMZE1wrVr13Dt2jWd552cnBAWFoa33npLbzuNGjXC4cOHMXbsWFy9ehXJyclYt26dRj1fX19s27YNzz33nN72ZDIZtmzZAmdnZ2zcuBGCIODgwYM4ePCgWj0bGxvMmzcPy5Yt09seERERSau4V/bAzQN6hxko5AqENAlhb2wpyQRDi72awKhRo7Bnzx7IZDK9k5ZMKTk5GdHR0Th9+jTOnj2LhIQEPHnyBMnJyXBwcICXlxf8/f3Rs2dPTJw4EZ6enka3nZubi82bN2P37t2IjY3FkydP4OnpCT8/PwwfPhzTp08v9W5aUVFR2LhxI6KionD//n3Y2NjA19cXvXv3xrRp0/SukmBIWlqauOoCd/kiIiIqnZgHMWi7tm3RQZ4TsPz/J3wtcC6a5PX/zr90nolsKTGRJYOYyBIREZXP4B2Di3plc+w0Etni3tifx/5s3iCtECd7EREREVUwfSsYcGxs2TGRJSIiIqpg4goGDnnAYlnR4/97Y7lSQdkxkSUiIiIyAW29suyNLZ8yrVpw/PhxSYNITEyUtD0iIiIiS1NyBQOuVFB+ZZrsJZfLIZPJJA1EEARO9rJQnOxFREQkDbUVDMCVCsqrXEMLBEGQ5EFERERUFRT3ygLg2FgJlGloQb169STvkSUiIiKqCpb2WIrLjy9jSfASc4di9SxiHVmybBxaQEREJK3iIZVUPly1gIiIiMjEmMRKg4ksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyBIRERGRVWIiS0RERERWiYksEREREVklJrJEREREZJWYyOogCAJOnTqFpUuXIiQkBA0aNICTkxMcHBzg4+OD3r17Y/ny5Xj48KFR7clkslI9vvzyS6NjvXTpEl5//XW0bNkS7u7ucHFxQdOmTfHiiy8iOjq6rD8CIiIiIosmEwRBMHcQluaXX37BjBkzcP/+fYN1HRwcsHTpUsyePVtvPZlMVqoYvvjiC8ycOVNvHUEQsHDhQqxYsQKFhYU667300kv48ssvYWtrW6oYiqWlpcHd3R2pqalwc3MrUxtEREREUlOYOwBLFBsbq5bENm7cGIGBgahXrx4cHR0RFxeHffv24dGjR8jJycGcOXPw4MEDrF692mDbnp6eWLBggcF6Xbt2NVhn/vz5+OCDD8TjLl26ICgoCAqFAn/88QcOHz4MQRCwdu1aZGVlYcuWLaVOqImIiIgsFXtktVi5ciWWL1+OF198ES+88AJatWqlUScnJwdvvPEG/ve//4nPRUREoEePHlrbLE4g69evj/j4+HLHGBUVhe7duwMAbGxssHnzZowfP16tzpEjRzB06FBkZmYCALZv345x48aV+l7skSUiIiJLxERWi0uXLsHX1xfVqlUzWDckJAQHDhwAAAwfPhx79uzRWk/qRDYwMBAnT54EACxYsADvv/++1npr167Fyy+/DABo0KABbt26Bbm8dEOjmcgSERGRJWIiW04HDx7EgAEDAAA+Pj46x9VKmcjeunULfn5+AAAnJyckJCTA09NTa92CggI0bNgQCQkJAIBjx44hODi4VPdjIktERESWiKsWlFPDhg3FclJSkknu+fPPP4vlPn366ExiAUChUGDYsGHi8d69eys0NiIiIiJTYSJbTv/8849YrlGjhsH6T58+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YykaeDTAkuAl5g6FLBiHFpBBHFpARETmIAgCZDKZucMgC8YeWSIiIrJITGLJECayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVViIktEREREVomJLBERERFZJSayRERERGSVmMgSERERkVVSmDsAIiKiqkYpKKEUlJK1J5fJIZexb4qqHiayREREJtZ8TXNcT7quu0KeE7A8s6i8wBmwy9LbXlOvpvh75t8SRkhkHfjPNyIiIhNr5tUMMsgkaUsGGZ6p/owkbRFZGyayREREJhYWHAYBgiRtCRCwOGixJG0RWRsmskRERCYW4BOA0KahUMjLN8JPIVdgcLPBCPAJkCgyIuvCRJaIiMgMwoLDUKAsKFcbBcoC9sZSlcZEloiIyAzK2yvL3lgiJrJERERmU55eWfbGEjGRJSIiMpuy9sqyN5aoCBNZIiIiE8vM/Pcxr8NSFOTYFa0dKz6c/62c51zinBMKcuwwt/0SsQ2iqkomCII0639QpZWWlgZ3d3ekpqbCzc3N3OEQEVk9mTRLyIr4l5yqKvbIEhEREZFV4ha1REREJpaRofncqF2jEH47HIXKgqLhBB89LjoxuyZgVzR+wEauQL/G/bBr1C4TRktkudgjS0REZGLOzpqP9/svQKEiDbDLEhNXAEVluyzALguFijQs6zdf41qiqoo9skREVGpKQQmloJSsPblMDrmsavetFK9gcODmAWhbkEshVyCkSQhXKiBSwUSWiIhKrfma5riedF13hTwnYPn/9youcC7qUdSjqVdT/D3zbwkjtE5hwWHYd30fADuNc1w3lkhT1f7nLxERlUkzr2aQQZqp9zLI8Ez1ZyRpy9oV98ralFhXluvGEmnHRJaIiEotLDgMAqRZ80mAwJ5GFWHBYUUTvlSwN5ZIOw4toArHsXRUHobeP5mZgIdb0UdZSlqBwYkvfP9IQ208Zxm3WAU47lObAJ8ADPALwYH/P7aRKzCQvbFEWjGRrSRu376N9evXY//+/bh79y5ycnLg4+ODjh07YsKECQgJCTFbbBxLR+Vh1PsHRe8fj5XufP+Y0L/jOcuOPY3avdv9XTGRLeTPiEgndktUAmvWrEGrVq2wYsUKXLx4EcnJycjOzsbt27ex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",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import FixedLocator, FixedFormatter, NullLocator\n",
    "\n",
    "x = [0.5, 0.75, 1, 1.25, 1.5, 1.75, 2]\n",
    "loss_trans = [0.94,3.23,14.89,58.76,184.73,485.17,1100]    \n",
    "losses_gds = [0.94,3.16,14.39,56.70,178.29,468.50,1100]   \n",
    "\n",
    "plt.figure(figsize=(7,5))\n",
    "\n",
    "plt.scatter(x, losses_gds, marker=\"v\", color=\"green\", s=200, label=\"RAG\")\n",
    "plt.scatter(x, loss_trans, marker=\"+\", color=\"blue\", s=200, label=\"Trained TF\")\n",
    "\n",
    "ax = plt.gca()\n",
    "ax.set_xscale(\"log\")\n",
    "\n",
    "# 只显示 0.5, 1, 1.5, 2\n",
    "ticks = [0.5, 1, 1.5, 2]\n",
    "ax.xaxis.set_major_locator(FixedLocator(ticks))\n",
    "ax.xaxis.set_major_formatter(FixedFormatter(['0.5', '1', '1.5', '2']))\n",
    "ax.xaxis.set_minor_locator(NullLocator())   \n",
    "\n",
    "plt.xlabel(r\"$\\alpha \\;\\;\\text{where } x \\sim U(-\\alpha, \\alpha)$\", fontsize=23)\n",
    "plt.ylabel(\"Loss\", fontsize=23)\n",
    "plt.legend()\n",
    "plt.grid(False)\n",
    "\n",
    "ax.spines[\"top\"].set_visible(False)\n",
    "ax.spines[\"right\"].set_visible(False)\n",
    "\n",
    "plt.savefig(\"R1_out_distrubtion.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c8530684-f2d3-4060-a281-d05caf751872",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6tSptGjRgoMHD7oufV/tPemNYp08dF1n2bJlLFq0iBdeeMFVHhgYyPTp012Xq7766is0TWP69OmuXx4zZswgLCyMuLg4OnTowHvvvcfQoUN58MEHAfj4449ZtGiRa58JCQk4HA4efPBBoqKiAKhXr16usX300UfUqFGDyZMnA1CnTh3+/vtvJk6cmGN9f39/ypbN+iVWrlw51y+vnMpKk5xe4wEDBrjWR0dHM3bsWPr27ev2BWK32/nwww+pX7++q8zf3x+r1XrV59FkMrl+8QPExMSwbt06vvvuO6+/QKZMmULHjh155ZVXAKhduzZr167ljz/+yLF+UFCQqzH98thyKitNiuNr/9Zbb9GoUSO3eG699VYA0tLS+Oijj5g5c6ar/eqzzz5jyZIlfP755wwePJijR49y++2306hRI9djvJZx48bRqlUrAF599VXuu+8+MjMz8fPzY8yYMbz66quuqx7Vq1fnjTfe4JVXXimdyWPBggUEBQVht9vRNI3HHnuM0aNHu9bXq1fPrZ1j+/btHDhwgODgYLf9ZGZmcvDgQZKSkkhISOCuu+5yrTMajTRq1Mh1ZlG/fn3atm1LvXr1iI2NpUOHDnTv3p0yZcrkGOPu3bvd9gfQtGnT/D70UuNqr/HSpUuZMGECe/bsITk5GYfDQWZmJunp6QQEBABgNpu57bbbruvYH3zwAV988QVHjx4lIyMDm83m0TPqanbv3k3Xrl3dypo2bZpr8hDuivNrv23bNh566KEc1x08eBC73U6zZs1cZSaTicaNG7N7924g6zJdt27d+PPPP+nQoQNdunTh7rvvvuoxL3+s2e2ip0+fplq1amzfvp34+HjGjRvnquN0Oj2es+txXcnDElCGriO2XvdBvT1Gbtq0acNHH32E2WymUqVKHtfurmyDSE1N5Y477uDrr7/22Je3l4EMBgNLlixh7dq1LF68mGnTpvHaa6+xYcMGYmJivNpHcaGay1L+gZOFcpzc5PYaHz58mPvvv59+/foxbtw4wsPDWbNmDU899RQ2m831YfD397+uRua5c+fy8ssvM3nyZJo2bUpwcDBvv/02GzZsuL4HWcwEWsowqeufhXKc3BTn1/5aQ3pcy7333suRI0dYuHAhS5YsoW3btvTv359Jkybluo3JZHL9P/txa5oGZH33jRkzxnVF5XJ+fn75ivW6koei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0r17d6pVq4bFYqFcuXLceeedjBs3zu25PHLkCEeOHEFRFNfflY9j1apVPPDAA0RERGCxWKhVqxbDhw8nPT091+dhzZo1tG7dmuDgYMLCwujWrRsHDhzwiHP//v307t2bmJgYLBYL4eHh1K9fnwEDBsgPB+FBLluJfDlw4ABNmjShXr169OrVi3PnzmE2mwEYOnQoZrOZ5s2bExkZyZkzZ/jll1/o3r07U6dO5YUXXvD6OIMHD2blypXcf//9xMbG8vPPPzN69GhsNpvrS/ha7HY7HTp04MKFC3Tr1o309HTmzp3Lww8/zB9//EGHDh1cdY8fP87dd99NQkICHTt25Pbbb2fv3r20b9+ee+65x+u4t23bxt13343BYKBz585ERUWRmJjIrl27+PTTT3nttdcICwtj1KhRvPfeewAMGDDAtf3lyfSjjz6if//+hIWF8cADD1C+fHk2b97MuHHjWLFiBStWrHA999nWr1/PhAkT6NixIy+88AI7d+7kp59+YvXq1axfv57q1asDcOLECRo3bkxaWhr33XcfPXr0IC0tjf379/Phhx8yadIkjEb5uhCX8eFw8KKYyJ5k6HKHDh3SAR3QR44cmeN2Bw8e9ChLSUnR69Wrp4eGhnrMzgforVq1civr2bOnDugxMTH6iRMnXOVnzpzRw8LC9ODgYN1qtbrKV6xYoQP6qFGjcnwMnTt3dqu/dOlSHdBjY2Pd6v/3v//VAX3cuHFu5Z9//rnrca9YsSLHx325gQMH6oD+888/e6w7e/asR4xRUVE57mfnzp260WjU69ev77HdhAkTPCaByn4eAP3jjz92q//xxx/rgH7//fe7yqZOnaoD+nvvvedx7HPnzl3zcYrSRy5biXypWLEir732Wo7rsn/VXi4oKIhevXqRlJTEpk2bvD7OiBEjiIyMdC1HRETQuXNnUlJS2Lt3r9f7effdd91+nbdt25aoqCi3WKxWK99//z3ly5dn0KBBbtv37t2bOnXqeH28bP7+/h5lZcuW9Xr7Tz75BIfDwbRp0zy2e+WVVyhXrhzffPONx3a1a9emT58+bmV9+vShVq1a/Pbbb5w5c+aacYaHh3sdpyg95DxU5Ev9+vU9LpVkO336NG+++Sa///47R44cISMjw239iRMnvD7OHXfc4VFWpUoVABITE73aR1hYGDExMTnuZ926da7lvXv3YrVaadSoERaLxa2uoijcfffdXieshx9+mPfee4+uXbvSo0cP2rdvT8uWLalcubJX22dbv349AIsWLWLZsmUe600mE3v27PEob9asGarq/htRVVWaNWvG/v372b59O+3ateOBBx5g6NCh9O/fn2XLltGxY0datWqV4w8AIUCSh8inChUq5Fh+/vx57rzzTo4ePUqzZs1o164dYWFhGAwGtm3bxvz587FarV4fJyQkxKMs+xq80+n0ah+hoaE5lhuNRreG9+TkZADKly+fY/3cHnNO7rrrLuLi4hg/fjxz5sxhxowZANx5551MnDiRNm3aeLWf8+fPA3jdvnOtWLPLk5KSgKwOBevXr2f06NEsXLiQ7777DoCbbrqJ119/nYceeihPxxUlnyQPkS+53VT4+eefc/ToUd544w2GDx/utu7NN99k/vz5hRHedclOVKdPn85x/alTp/K0vxYtWvD777+TkZHBhg0b+PXXX/nwww+577772LFjh1e/7rNjSk5OJjg42Otj5xZrdvnlCbVu3br88MMP2O12tmzZwu+//87UqVPp0aMHlSpVolmzZl4fV5R80uYhboiDBw8C0LlzZ491q1evLuxw8qROnTpYLBa2bNnicXak67rbJa688Pf3p3Xr1kyePJlhw4aRkZHBkiVLXOsNBkOuZ1F33XUXcOnylbfi4+M9ujNrmsbatWtRFIX69et7bGMymWjSpAljxoxh6tSp6LrOggUL8nRcUfJJ8hA3RFRUFABr1qxxK58zZw4LFy70RUhes1gsdO/enVOnTrm6z2abPXt2jm0LuVm3bh2ZmZke5dm//P38/Fxl4eHhnD17Nsf6zz33HEajkRdeeIGjR496rE9MTGTr1q0e5fv27eOzzz5zK/vss8/Yt28f9913H+XKlQNgy5Ytrst114pTCJDLVuIGeeKJJ5g4cSIvvPACK1asICoqiu3bt7Ns2TIefPBBfvzxR1+HeFUTJkxg6dKlvPrqq6xcudJ1n8eCBQvo2LEjf/zxh0dDdE4mTpzIihUraNmyJTExMfj5+fHnn3+ybNkyqlevTteuXV1177nnHjZv3sy9995LixYtMJvNtGzZkpYtW1K3bl0+/PBD+vXrR506dejUqRM1atQgJSWFf/75h5UrV9KrVy8+/vhjt+PHxsby4osvsnDhQm699VZ27tzJr7/+SkREBFOmTHHV+/LLL/nkk09o2bIlNWrUICQkhF27drFw4ULCw8Pp3bt3wT25okSQ5CFuiCpVqrBy5UpeeeUVli5disPhoGHDhixevJhjx44V+eRRtWpV1q1bx5AhQ1i8eDErV67kjjvuYPHixXz//fdAzo34V+rXrx+hoaFs2LCBlStXous61apVY9iwYbz00ktu+xgxYgQXLlxgwYIFrF69GqfTyahRo2jZsiWQ1cW2QYMGvPPOO6xatYpff/2V0NBQqlWrxksvvUTPnj09jt+kSROGDx/O8OHDmTp1KgaDgS5duvDWW2+5tbU8+uijZGZmEh8fz8aNG7FarVSpUoV+/foxePBgqlWrlt+nVJQwMraVEHnUvHlz1q1bR1JSEkFBQb4OJ0dxcXG0adOGUaNGyfD04oaQNg8hcpGQkOBR9tVXXxEfH0+7du2KbOIQojDIZSshclG3bl1uv/12brnlFtf9KXFxcQQHBzNp0iRfhyeET0nyECIXffv25ddff2Xz5s2kpaVRrlw5HnvsMUaMGMFNN93k6/CE8Clp8xBCCJFn0uYhhBAizyR5CCGEyDNJHkIIIfJMkocQQog8k+QhhBAizyR5CCGEyDNJHkIIIfJMkocQQog8k+QhhBAiz/4f7oOZ0wgOjs8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display_learning(cos_sim_list, grad_norm_list, p_norm_list, title1=\"Partial cosine\",\n",
    "                 title2=\"Partial diff\", y_lim_u=2.5,\n",
    "                 title3=\"Preds diff\", second_axis=True,\n",
    "                 y_lim_u2=1,  color_add=0.2, loc_sec = 'lower left',\n",
    "                 y_lim_l2=0.8,\n",
    "                 rw=1, num_iter_os=len(cos_sim_list[0])*100, title=\"sim_layer1_doc2_dim10_R_w_all_0.pdf\",\n",
    "                 allow_download=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d140d49a-2f15-45f5-a2e8-e8fcd48ce3fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fn7Url3b7fpNmjTh66+/pmLFigQGBuZZJyIigqSkJNq1aweAzWZj586dNGlytfFQkiRat25N69atmThxIpGRkfz4448MHz7cZXu33347P/30k1PZ1q1b3Y7ZmyRJzrchu7jk9x7v3LkTRVGYPXu2oyH5m2++cWuber3ece05P4mJibRq1YoXXnjBUZbb68ldt99+u8sBp7S897Ik59uQXVxK83vfsGFD1qxZ43T5K1etWrXQ6/UkJiY6Ln1brVa2b9/udDmuQoUK9OvXj379+tG2bVtGjhxZYPIoSJMmTThw4IBHx0t3lbr7PG7GE088QXh4OD169GDjxo0cPXqUhIQEXn75ZU6dOgXA//3f//HGG2+wdOlS/vnnH1544QXHzXyQ0wg6ffp0duzYwYkTJ/jhhx+4ePEit99+e577HDx4MIcOHWLkyJEcOHCAxYsXEx8fXwzPtmyrXbs2VquVefPm8e+///L5558zf/58tx4bFRXFn3/+yYEDB7h06RJWq9WlTp06ddixYwcrV67k4MGDTJgwge3bt3sU48svv8xvv/3GrFmzOHToEO+99564ZFUESsN7P2bMGLZv384LL7zAn3/+yT///MOHH37IpUuX8PPzY8iQIYwcOZLffvuNffv2MXDgQLKysnj22WcBmDhxIsuWLePw4cPs3buX5cuX53uMccfEiRNZtGgRkydPZu/evezfv58lS5Ywfvz4m95mrnKRPHx9fdmwYQM1atTgkUce4fbbb+fZZ5/FZDI5zkRGjBjBU089Rb9+/RynrNdetw4MDGTDhg10796dunXrMn78eGbPnp3vjVs1atTg+++/Z+nSpTRq1Ij58+czffr0Ynm+ZVmjRo14++23mTlzJvXr1+fLL79kxowZbj124MCB1KtXj6ZNm1KhQgVHj5RrPf/88zzyyCP06dOHe+65h8uXLzv9EnVHixYt+OSTT5gzZw6NGjVi1apVRfJlLe9Kw3tft25dVq1axZ49e2jevDktW7Zk2bJljktvb7zxBr169eKpp56iSZMmHD58mJUrVzraTvV6PWPGjKFhw4a0a9cOjUbDkiVLPIrhWjExMSxfvpxVq1bRrFkzWrRowTvvvOM48ykMt+bzyM7O5tChQ9SpU6fQ1/QEQRCEksmTY325OPMQBEEQipZIHoIgCILHRPIQBEEQPCaShyAIguAxj5JH7o0ngiAIQtnjyTHereSRO9RHZmbmzUUkCIIglHi5x3h3prFw6w5zjUZDaGgo587lDFnh5+fn0UTpgiAIQsmlKAqZmZmcO3eO0NBQNBrNDR/j1n0ekDPC5enTp0lOTi50oIIgCELJExoaStWqVd0aG8zt5JHLbrdjsVhuOjhBEASh5NHr9W6dceTyOHkIgiAIgmi4EARBEDwmkocgCILgMZE8BEEQBI+J5CEIgiB4TCQPQRAEwWMieZQQqqqSlpaG6PwmCHkT35GSRSSPEiI9PZ2goCDS09O9HYoglEjiO1KyiOQhCIIgeEwkD0EQyqwvvviC559/nqZNm2IwGJAkifj4eI+3oygK8+bNo0GDBvj4+FChQgX69u3Lv//+W/RBlxIieQiCUGaNHz+ejz/+mOPHjxMREXHT23n++ed5+eWXUVWVl19+mW7duvHDDz/QrFkzDh06VIQRlx4ieQiCUGYtWLCAY8eOcfHiRQYPHnxT21i3bh0LFiygXbt2/PHHH8ycOZPPP/+cpUuXkpyczIsvvljEUZcObg3JLgiCUBp17ty50Nv45JNPAJg6darTPBf33XcfHTp0YNWqVZw4cYIaNWoUel+liTjzEARBKEBCQgJ+fn60bt3aZV1MTAwA69evL+6wvE6ceQiCUKqkpaU5LRsMBgwGwy3ZV2ZmJmfPnqV+/fp5Dldep04dgHLZ7iGSRymzaNEijh496lgeNGgQu3fvZtu2bY6ybt264evryw8//OAoa9iwIV26dGH27NmOsipVqjBw4ECmTp3qmLvY39+fESNG8NZbb5GVlQXkzCQ5fvx45s+fz/nz5x2PHzduHD/++CP79u1zlD3++ONcvHiRNWvWOMpat25N3bp1iYuLc5TVrl2bJ554gsmTJzvKwsLCePHFF5k+fTpWqxXIOTCMHj2ad999l9TUVAAkSWLixInEx8dz/Phxx+NfeOEFtm/fzvbt2x1l3bt3R6/Xs3TpUkdZ48aN6dixI++8846jrGrVqjz33HNMmTLFcRNaQEAAw4cP58033yQ7O9vptfjggw+4ePGi4/GxsbF8/fXX/PPPP46yJ554gtOnT5OQkOAoa9euHVFRUSxatMhRVrduXfr27ev0WoSHhzN06FCmTZuGzWYDwGg0MmrUKN555x3HATT3tfjss884efKk4/EvvfQSiYmJ/PHHH46yBx98EICff/7ZUdakSRNat27NvHnzHGXVq1fnmWeecXotAgMDeeWVV5g5cyYmkwkArVbLuHHjeP/997l06ZLTa/HVV19x8OBBR9nTTz/NsWPH2LBhg6OsQ4cOVK1alS+//BKA6Ohonn76aW6kevXqTsuxsbFMmjTpho+7GbmfuaCgoDzXBwYGOtUrT8R8HiVEWloaQUFBpKamOj6QgiBclfsdOXnypNN3xN0zjzfeeIMxY8YQFxdH//793drnmTNnqFq1Kq1bt2bTpk0u61evXk3Xrl15+eWXmTNnjtvPpSwQZx6CIJQqgYGBxfYDK/eMI78zi9wzwPzOTMoy0WAuCIKQDz8/PyIiIjh69Ch2u91lfW5bR27bR3kikocgCEIB2rdvT2ZmJomJiS7rVq5cCeS0ZZU34rKVUORyG99l2fm3iU2xkWVJwWrLxq4qaCSZAGMYeq0vNpuFTGsKinr1150sadBIWuyqDUW1Y7GZsNnNAOi0Pug1RlQUFMWGXVWwK9ac/ys2bKoViy0bm2LGVxdIgE9FVFXBZEnHZM9AURSnfRm1vvgZQrHZzZzPOEqa6SIBhjBCfKtg0PggyTJZljRSss6RbU3H3xCCvyEUq91MtjUNsy0biz0bszWTLEsKJmsGWo0Bo84fP31wzvPU+JBlScNsz0Kv8cGo88NszSLNdJEsaxomawYWezYyMpIkI0sysqxFKxvw0wcBEpczT5KSfQ5VVZElGQUFu2JDUXKeiyTJ6LVGjFo/FNWO2ZaFTbEiIaGoClmWFLKtGaiqgixr0Eo6NBqd43W2K1ZsdgtWxYKi2FBQUFXF+T2RtSiKHZtiwa5YUVEd8ciSBiQJVVWQkNBo9GhlPfJ/v1Mt9pzXSVEVZElGQsKu2lEUO4pqJ9SvKtMfcm1bKA6XLl3i0qVLhIeHEx4e7igfNGgQS5YsYcKECaxevdpxr8evv/5KQkICXbt2JTIy0isxe5NIHsJNOZt6mG3Hl3LwQhKXM09itmVhsZn+O5hcPdhISKiIPhnlltWz6iZr0Y6Yu2DBAkdD919//eUoy+0B16ZNG5577jkA3nvvPSZPnuzSe6tjx44899xzLFiwgCZNmnD//fdz9uxZvv76a0JDQ516qpUnInkIblMUhbUHP2PV/o9INV1w6zEicQiesCseZpsb2LRpEwsXLnQqS0xMdLoElZs8CvLRRx/RoEEDPv74Y+bMmYO/vz8PP/ww06ZNo1atWkUac2khuuqWECW9q26GKZlJv3Yh3XTpxpUF4SbpNEbee+xAnutK+nekvBFnHsINZVlSmfhLRzItKd4OpcSTkJAkDbKkyWmPUe1ObQYFP+a/NgP+O2NT1f/aExQUVQFUNLIOg9YXSZJRVRVJAlnSIiE5HmdXrI52Do2sQyNrHWeABo0vPvoAZEmDotqx263YVCuKYkeWc9qYtBo9eo0PWlmPRtYhSzJIgAo2xYLNbkEjazHq/DFofZFlLbKkwWY3Y/2vTUqWNNhV23+XM7NQ/3suBq0fAYZQDFpfbIoFRbVj0Pph1Plh1AYQ6lf1lr03QtESyUMokMmSwYTlHfJNHD66ACr4RxLiG0GgsQIhvhGE+VVHp9GTab6CyZaFXmtEJxvw1QfhZwhGr/FFI2uw2i1kWq6QbUnHqPPDRxeITpNzs5ei5hx4FdWGLGmRkdBpjeg0RlRVxWozYVFMyLkHXXIacjUaHbKkRStr0Wv90Gv0ZFpSSc2+iEbWYNQF4qP1Q5Z1yP8dcBVUTNY0Mi0pSEhUDKiJXmvEpthIzTqLVbGgqioGrQ+BPpXQylpsio0M02X0Wl+MWj+XzgHXU5Schn2tVu9UdqPHCUJJJZKHUKC31/Ulw5x8XanEXdVi6HP3JEJ8b36OhOKi1/reME5fveuvXq2sJcy/ep71tbKWYN9KbscgyzKyrHcpE4TSSiQPIV8bDn3B8eQ/Xcr73zObljV7eSEiQRBKCvHTR8hThimZJTtjXcqfaDpNJA5BEETyEPI2d/3T2FWbU9mdER1oV+dJL0UkCEJJIpKH4OJs6mGOJ//lVGbQ+jK4zUdeikgQhJJGJA/BRV6Xqwa2fh+91uiFaARBKIlE8hCcWGxZHDi/2aks3K8GDarc66WIBEEoiUTyEJz8sGem09hUAA82GO6laARBKKlE8hCcbP73G6dlo9afFtEPeykaQRBKKpE8CuH06dO8++67dO3alRo1aqDX66lcuTK9evUiKSnJ2+F5LOnYj5htWU5lbWo97qVoBEEoyUTyKIR58+bxyiuv8O+//9K1a1dGjBhBmzZtWLZsGa1ateLrr7/2dogeWblvvtOyJMn0aDjSS9EIglCSiTvMC6F58+YkJCTQvn17p/KNGzfSqVMnhgwZQs+ePTEYDF6K0H1ZlnROpzqPZlo7vKnoYSUIQp7EmUchPPLIIy6JA6Bt27Z07NiRK1euOCagKel++ftduG7ujQcbjPBKLIIglHwiedwiOp0OAK22dJzcbT32g9Oyjy6AepVaeCkaQRBKutJxZCtlTpw4we+//05ERAQNGjTIs47ZbMZsNjuW09LSiis8Fyev7HUZObdJ9e5eikYQhNJAJI8iZrVaeeqppzCbzcycORONRpNnvRkzZjB58uRiji5vy/6c5VLWo+GrXohEEMoHVVVZtmwZe/bs4cyZM1itrtPvSpLEp59+6oXo3COmoS1CiqLw1FNPsXjxYgYOHMjHH3+cb928zjyqV6/ulSk2X/r2dizXdNGt4B/J6w9uKNYYBOFGyso0tIcPH+aBBx7g0KFDFHT4lSQJu91ejJF5Rpx5FBFFUXjmmWdYvHgxTz75JPPnzy+wvsFgKBG9sP69uNMpcQC0qvmol6IRhLJv6NChHDx4kCFDhtC3b18iIiJKTdvotUpfxCWQoigMGDCARYsW0bdvX+Lj40vNLHG/7b8+yUl0rvesV2IRhPJg48aNPPTQQ7z//vveDqVQSscRrgS7NnH06dOHzz//PN92jpLo+kEQK/hHotf6eikaQSj7AgICqF27trfDKDSRPAoh91LVokWLePTRR/niiy9KVeI4eWUvJluGU1nzyIe8FI0glA9dunRh8+bNN65YwonLVoUwZcoUFi5ciL+/P3Xr1uX11193qdOzZ08aN25c/MG54bd9H7iUdb5tkBciEYTy46233qJly5aMHDmSqVOnYjSWzlEcRPIohGPHjgGQkZHBtGnT8qwTFRVVYpPHvrPOParCfKvhqw/wUjSCUD5ERESwcuVKWrZsyccff0ydOnXy7D0mSRJr1qzxQoTuEcmjEOLj44mPj/d2GDflbOphsqzONyY2qXG/l6IRhPJj165ddOnShZSUFAD++OOPPOtJklSMUXlOtHmUU7/tc+3p0e32wV6IRBDKl2HDhpGSksLMmTM5ceIEVqsVRVFc/kryPR4gzjzKrb/OrHNaDvapjL8x1EvRCEL5sXPnTvr06cPIkaV7ugNx5lEOXcw4SablilPZXdXv81I0glC+BAYGUqlSJW+HUWjlInls2rSJnj17Eh0djcFgQKPRuPyVxjs8b1bel6yGeCESQSh/evTowdq1a1EUxduhFEqZP2J+/vnn9O/fH1VVqVmzJs2bNy9XiSIve06vdloONFYg2Lf0/xIShNJg5syZdOnShSeeeIJZs2ZRtWpVb4d0U8r8UXTq1KmEhISwYsUKmjdv7u1wvC4l6zzppktOZY2qdvFSNIJQ/jRu3BiLxcKOHTv45ptvCAkJyber7pEjR7wQoXvKfPI4efIkzz77rEgc//l17zyXsvvueMELkQhC+aQoCjqdjho1ajjK8hpdt6QPeF7mk0dkZCQWi8XbYZQYu06tdFr2N4QS5l/dS9EIQvmTe3NxaVfmG8wHDhzI8uXLSU5OvnHlMi4l6zyppgtOZQ2rdvZSNIIglGZl/sxjxIgR/Pvvv7Ru3Zrx48fTqFGjfCeSufY0siz6bb/rWFb33fGiFyIRBKG0K/PJA6BJkyYsXryYp59+Ot86kiRhs9mKMari98fJX52W/Q0hVAyI9FI0glA+TJkyBUmSGDp0KKGhoUyZMsWtx0mSxIQJE25xdDevzE9DO2/ePIYNG4ZOp6NNmzYFztoVFxdXzNFddaun2EzNvsBrS5s5lbWMfpT+LVznLxeEkqi0TkMryzKSJLF//37q1q3r9kRxYhpaL3vnnXeoWrUqmzdvplq1at4Ox2uW//WuS1n3O18q/kAEoZxZty5nKKDcy+K5y6VdmU8e586d4/nnny/XicOm2Nh89FunMj+9uGQlCMWhffv2BS6XVmW+t1Xt2rUdQx+XV0v3vIlNce6u3KrmY16KRhCEsqDMJ49XXnmFZcuWcfz4cW+H4hWKopBwaKFTmVbW07PRa16KSBDKt7/++ovPPvuMtLSr8+lkZ2czZMgQqlatSq1atZg/f74XI3RPmb9sVatWLdq3b0/Tpk0ZNmxYgV1127VrV8zR3Xo///02VrvJqaxt7SfQymX+rReEEun1119n06ZNDBgwwFE2duxYPvroI/z9/bl06RJDhw6lVq1adOlScocOKvO9rXJ7OuQ+zYJm5/Jmz4Zb0ZPk1JV9vP7b/ahcHb1TI+uY22sfWq2+SPYhCMWltPa2ul50dDStW7fmiy++AMBmsxEeHs5tt91GQkICycnJNGnShKZNm7J8+XIvR5u/Mv/zc+LEiSV+OsdbwWTJ4K3fezslDoBW0Y+KxCEIXnTx4kWqV786JND27dtJS0tj8ODBGI1GqlSpQo8ePVixYoUXo7yxMp88Jk2a5O0Qip3JksGUX2Mw2TKdyn31QTzeZLKXohIEAUCr1WI2mx3LCQkJSJJEx44dHWVhYWFcunQpr4eXGGW+wVyj0fDEE094O4xicz7tKKN/asHlrFNO5bKkYVSXH8VZhyB4WVRUlNO9Ht9++y3R0dFERl7tOn/69GnCwsK8EZ7bynzyCAwMdDpFLMuuZJ1lyq9dyLamu6x7puW7VA6s5YWoBEG41lNPPcWePXu45557aNeuHXv27OF///ufU50///yTOnXqeClC95T55NG8eXP27Nnj7TCKxYLEl7ApVpfyB+78P5pFPuSFiARBuN6LL77Io48+yo4dO9i0aRP33XcfY8eOdazfu3cve/bs4d577/VilDdWLto8OnTowKJFiwocGLG0O5d2hMOXtjuVScgMaPk290Q97KWoBEG4nsFg4OuvvyYtLQ1JkggICHBaX6lSJXbt2kVUVJR3AnRTmU8eq1evpkOHDgwYMIB58+bRrFkzKlWq5NIDq6SPYHkjcVtecSkb3PYjGlfr6oVoBEG4kfy6G4eHhxMeHl7M0XiuXNzn4Q5vj2BZmD7sp67sY+pv9zmVhfvVYNpDG4syREHwqrJyn0dZUebPPMrKCJYF+XL7OJeyJ5vP8EIkgiCUF2U+eZSVESwLcir1H6fligHR3F65jZeiEQShPCjzva3KOptiw2LLciprFS1GzBUE4dYq82ceuRITE4mPj2f37t2kpaURGBjIXXfdxdNPP02bNiX7V7qqqlgvbcJyZSfWKzuwXtlJSMtv0QXV59CFrS71G1TpUPxBCoJQrpSL5PHKK68wd+5cp8ERVVVl586dfPrpp/zf//0fb7/9tpejzJ8kSaRsfxp71glHmfXKDnRB9dl7doNzXSSqBN1W3CEKglDOlPnLVgsXLmTOnDnUqVOHL7/8kjNnzmCz2Th79iyLFy+mbt26zJkzh0WLFnk71ALpQu52WrZe2QnA8WTnGyB99IFu9zATBMF7LBYLK1as4O2332bq1KmOcpPJxIULF1AUpYBHe1+ZP8p8+OGHVKtWjaSkJPr27UvlypWRJIlKlSrx+OOPs3XrVqpWrcoHH3zg7VALpAtp5rScmzzOpx91Kg/zK7/T7QpCafHTTz9Ro0YNHnzwQV599VWnAVz//PNPIiIiWLJkifcCdEOZTx579+6lV69eBAUF5bk+KCiIXr16sXfv3mKOzDMuZx4pu1EVKxmmy07l1UPuLM6wBEHwUGJiIr1798ZgMDBnzhyXca2aN29O7dq1+f77770UoXvKRZvHjZSG+T6uTx4oZlIuJmJXbU7F9Sq2KsaoBEHw1NSpUwkODmbnzp2Eh4dz+fJllzpNmzYlKSnJC9G5r8yfedx55518//33ZGRk5Lk+PT2d77//njvvLNm/2GV9CBo/51FxTx53Pa2tX6WjS5kgCCVHUlISPXr0KHAIkurVq3Pu3LlijMpzZT55PP/885w6dYqWLVvy/fffOyZYuXTpEt999x2tWrXi1KlTDBkyxMuR3tj1Zx+mS1ucljWyDn9DcDFGJAgl3/bt2+nevTvBwcH4+fnRokULvvnmG7cfHx8fjyRJ+f4lJCR4FI/ZbL7h8CopKSklvuNLmb9sNWDAAHbt2sV7773HY4/l3Dwny7KjJ4Oqqrz00kv069fPm2G6RRfSFNOpqx96H9Nx4GpbTqCh5A+mJgjFad26dcTExGA0Gnn88ccJCAjg+++/p0+fPpw8eZIRI0a4va0ePXrQuHFjl3JPR7+tWbMm27dvL7DOli1buO22kt3lvswnD4C5c+fy6KOP5nmTYL9+/Wjbtq23Q3TL9WceIUo6WgKxkdNmUymwpjfCEoQSyWazMXDgQGRZZsOGDY4D/8SJE2nevDljx46ld+/eTjP4FaRnz57079+/0HH16tWL119/nbi4OAYMGOCyftasWfz999+8+eabhd7XrVQukgdA27ZtS02SyI8upInTsgaoKFk5o+ZMLRsddpcXohKEkmnt2rUcOXKEAQMGOJ0xBAUFMXbsWPr378/ChQuZOHFiscY1cuRIvv/+e5577jkWL17smM/8tddeY8uWLWzevJnGjRvz4osvFmtcnio3yaMskHWBaALqYU8/4CirIlkcyaNOhebeCk0QSpzctoiuXV3ntImJiQFg/fr1bm9v165dXL58GZvNRlRUFJ07d76pecb9/f3ZuHEjL774It98841jKohZs2YhSRKPPfYYH3zwAQaDweNtF6cymTxOnDhx40p5qFGjRhFHUvR0IXe7JI9coX5VvRGSIBSrtLQ0p2WDwZDngfbQoUMAec4FXrlyZfz9/R113DF37lynZR8fH2JjYxk1apTb28gVEhLCl19+ydy5c9m+fTvJyckEBgY6JqsrDcpk8oiKivL43g1JkrDZbDeu6GX6kKaYTix2LEdIV+csD/Kp4I2QBKFYVa9e3Wk5NjbW6Q7tXKmpqQD53iAcGBjoqFOQ6Oho5s2bR0xMDNWqVSM5OZm1a9cyZswYRo8eja+vLy+99JLnTwQICwujW7duN/VYbyuTyaNr165uJ4+DBw9y9OjRG1csIbSB9Z2WQ7ia8IzagOurC0KZc/LkSaeurrf68k779u2d5gWqWrUqTz31FE2aNKFp06ZMmjSJIUOGoNWWycNpvsrks/3tt99uWOfUqVNMnDiR1atXA3lfFy2JNH7OPUOMkooRBROaEt8vXBCKQmBgoFvT0OaeceR3dpGWlkZISMhNx3HnnXfSpk0bfv/9d/bv30+DBg3cfuy+fft477332L59OykpKXlOgS1JEkeOHLnp+G61cne0SU1NZfTo0dSrV4/4+HjuuusuVq9eza+//urt0Nyi8akOOJ9VBWNDlsrdWykIBcpt68irXePcuXNkZGTk2R7iidy7xDMzM91+zPr167n77ruZP38+e/bswWQyoaqqy58YVbeEsFgszJo1i1q1avHmm29SpUoVvvrqK7Zv306nTp28HZ7bJI0B2RjhVBYk2ZGlMnkSKQg3LfdS06pVq1zWrVy50qnOzbDb7ezYsQPA7XtFAEaPHo3NZmPBggVkZ2dz8uRJjh49mudfSVYuksfChQupU6cOo0aNQqPRMHfuXPbv30+fPn28HdpN0fhFOS0HSza0skgegnCtTp06UbNmTRYvXszu3bsd5ampqUyfPh29Xs/TTz/tKD979iz//POPy2WunTt3umzbbrczevRoDh8+TMeOHYmIiHCpk589e/bw+OOP88wzz6DRaDx/YiVEmT7i/PLLL4wdO5a///4bPz8/JkyYwKuvvoq/v7+3QysUjW8NrJc3O5aDsaPV6L0YkSCUPFqtlgULFhATE0O7du2chic5fvw4s2bNchpaZMyYMSxcuJC4uDinO8mbNm1Kw4YNadiwIVWrViU5OZn169dz8OBBqlWrxoIFCzyKy8/Pj4oVKxbRs/SeMpk8kpKSGDVqFBs3bkSj0TB48GBiY2PLxBsGoPGNcloOkuzoZKN3ghGEEqxjx45s2rSJ2NhYvv76a6xWKw0aNGDmzJluX3kYMWIEW7duZfXq1SQnJ6PX66lduzbjx49n+PDhHje6d+/enY0bN97M0ylRJDV3Yu8yRJZlJEmiVq1axMbGut0o1ry59+7QTktLIygoiNTU1Bv2JMn89yPS/njBsXxG1bHUpwVTH0i4xVEKgvd48h0pyS5cuECbNm3o1q0bb7zxBr6+vt4O6aaUyTMPyBkt9/Dhw07XNG8kr+5yJZH2ujOPYOwYtKXzAygI5c3jjz+Ov78/77//PvHx8dStWzfPZChJEmvWrPFChO4pk8mjuIZX/+KLL9i4cSM7d+7kr7/+wmKxuFwvvRU0vs49O3wlBT9NyR4HRxCEHNfO/5GRkcEff/yRZ72SPsNpmUwecXFxxbKf8ePHc/z4ccLDw4mIiOD48ePFst/rbxQECJXL3NVHQSiTSvr9G+4qF111b5UFCxZw7NgxLl68yODBg4ttv5LGh0zVuYtfiFQ2PpCCIJQOZfLMo7h07tzZa/tOQYsfV9togrAWUFsQBKFoieRRSqWoGqpec0k0QDV7LxhBEPK1aNEiAB5++GECAgIcy+7wpMNPcRPJw0vMZrNjBjFwnaPgRlKuu2zlq7g/to4gCMWnf//+SJJEixYtCAgIcCwXRFVVJEkSyUNwNWPGDCZPnnxTj1UUhRSck4fRduN5CQRBKH6fffYZkiQ5hjAprg49t5pIHl4yZswYhg8f7lhOS0tzmeQmPyZbOqnXnXnoLJeKND5BEIrG9V33i+tWgltNJA8vyW/qTHekZl8kRXV+62TrFVR7NpLGpyjCEwRBKJDoqlsKpZkuuVy2ArAkb/dCNIIgeOLkyZOsXbuWrKwsR5miKMycOZPWrVvTuXNnfvnlFy9G6J4ynzySk5Nv2Bh94sQJNmzYUEwRFV6a6QIWZM6rOqdy08klXopIEAR3TZgwgUcffRSd7ur3d9q0aYwZM4YtW7awdu1aevbsyfbtJfvHYJlNHps2baJBgwZUqFCBkJAQWrZsme9IlnFxcXTs2LGYI7x5GaYrAPylOF+iyj71Lapi8UZIgiC4KTExkc6dOzuSh6qqvPfee9x2222cOHGCbdu24efnx1tvveXlSAtWJts8Dhw4QExMDNnZ2dStWxedTkdSUhL33nsvr7/+OqNGjSqS/SxYsIBNmzYB8NdffznKcseuadOmDc8991yR7OtaGZZkAP5WfOmsuXpWpVqSMZ9bhbHKA0W+T0EQisaFCxecZh7cvXs3Fy9eZNKkSVSrVo1q1arRs2dP1q9f78Uob6xMJo/p06eTnZ3NkiVLeOyxxwDYtm0b/fr1Y+zYsWRkZDB16tRC72fTpk0sXLjQqSwxMZHExETH8q1IHpmWFCDnLvMTip4a8tWzjeyTX4nkIQglmKIoTuNbJSQkIEkS9957r6OsatWqnDt3zhvhua1MXrZat24d3bt3dyQOyJmrIykpifbt2zN9+nTGjh1b6P3Ex8fnOXF97l98fHyh95GXLMvVs42/VOeh2M1nfkKxZdyS/QqCUHg1atRg27ZtjuWlS5cSERFBvXr1HGXnzp0jODjYC9G5r0wmj/Pnz9OgQQOX8sDAQFasWEGnTp2YOXMmo0eP9kJ0hZdtvZo89io+XDskomrPInV7f9H2IQglVK9evUhMTKR37948+eSTbNq0iV69ejnV2bdvHzVr1vRShO4pk5etwsPD8+1hZTQa+fnnn3nwwQd56623UBQFPz+/Yo6wcLIt6Y7/Z6HhmBRITfXq8zWd/pErWx4lsPEctH5RXohQEIT8vPrqq6xatYoffvgBgIYNGzJp0iTH+uPHj7Nt27YS/+O2TCaP2rVrOxqy82IwGPjpp5946KGHmD17NpUrVy7G6ArPbHMex2q7tiY1lQNgz75a5+xyLp79BX2lzgTcEYs+rGVxhykIQh4CAwPZunUrf//9NwC33347Go3zfVs//PADTZs29UZ4biuTl61iYmL4+++/2bNnT751jEYjP/30E506deLs2bPFGF3hmW3ZTstp+gqEtvkFSXP9VLQqlvOrubyuDVe2PYU9+0zxBSkIQoHq169P/fr1XRJHZGQkPXr0oGrVql6KzD1l8szjscce46+//mLPnj00atQo33q5l7Cef/75YpsFsChY7M7Jw6j1w1ChPaFtVpCc+ABqHg3mphOLsZz/ndD2a9EF3l5coQqCUIDExER2795NWloagYGBNG7cmNatW3s7LLdIqqqK+UtLgLS0NIKCgkhNTSUwMLDAuiN+uIsMc7Jj+c6IDrzcIafLsC3zKJkH3yb7xJeoVteRdmVjFcI6rEfrX7Ib4wThep58R0q6zZs3M2DAAA4fPgxcHYIdoE6dOsTFxdGyZcm+1FwmL1t5aubMmXTq1MnbYbjNpjjPGuij83f8X+sXTdBd86j0wGkCGs5G0gU51VVMZ0je2BW7qWT3IReEsmrv3r107dqVQ4cO0blzZ6ZNm0ZcXBzTp0+nS5cuHDx4kJiYGPbt2+ftUAtUJi9beeqff/5x3BVeGtjtzt1wfa9LEJAzz7l/3WH4RD7BlcSeWJO3Xn185lHSdg8jpIUYC0sQituUKVOwWCysWLGCbt26Oa0bNWoUv/32Gw899BBTpkxhyZKS+x0VZx6lkF21Oy37GoLzrasxVCC0zXK0wY2dyk2nvsVyecstiE4QhIIkJCTQu3dvl8SRq1u3bvTu3Zt169YVc2SeEcmjFFKvSx5++uAC68v6EELbrEDShTiVp+15FdHkJQjFKzU1lejo6ALrREdHk5pasmcHFcmjFFJxPuAHGMJu+BiNsRIBd0xwKrMmb8V06tsijU0QhIJVqVKFrVu3FlgnKSmJKlWqFFNEN0ckj1LGYstyKQswhrr1WN9aQ9D41XIqS/97PKpiK5LYBEG4sYceeoiEhAQmTJiAyWRyWmcymYiNjWXdunX06NHDSxG6RzSYlyKn969Bquj6ayTQUMGtx0uynoAGM0jZenXASHvmEUynvsWnRt8ii1MQhPxNmDCB5cuXM336dD766COaN29OpUqVOH/+PNu3b+fixYvUrFmTCRMm3HhjXlQmk0f37t09qp87F0dJlpF8gg3xA5B1RuoFqJwNgzRfQJII8q3o9naMVR9BF9IU65UdV7d94E2M1R939DMXBOHWCQsLY+vWrbz22mssWbKEFStWONYZjUYGDBjAzJkzCQ1174qCt5TJmwRl2fOrcZIkYbfbb1zxFrnRDVB/rZrN32vmOJVlGGFvFLzd75hHzzn79A+kbHnUqSyk9U8YI+6/qdgFoTiUpZsEc1mtVv755x/HHea33Xab0/S0JVmZPPM4evSot0MoUopi598drg3b/iaod9LzZGms0hNNwG3Y0/9xlGX88waGyt3F2YcgFCOdTpfn9BGlQZlMHtdO8VgWWLNTCY64jey0c6iq4rQuOBMuHf+D8Mgmbm9PkmT8640kdcezV/dxeTPWy4now9sUWdyCIFw1bdo0MjMzmTx5cr5nFxaLhUmTJhEYGFjih2QXva1KAYNfKO0HxPPQ2K1IDZtidR6Ek382fuLxNn1qPIHGt4ZTWeahuYUJUxCEfPz+++9MnDiRsLCwAi9L6fV6wsPDGTdunLhJUCg6voGVyYiqyolKzuWn/v6VjOQTHm1LknX41n7Zqcx0+kdsmaVndGFBKC0WLVpESEgIL7744g3rDh06lNDQUOLi4oohspsnkkcpk2G5wtlQsF3zzqmqwsFEzz9ovlEDkDTXzqKokHXkg8IHKQiCk82bN9O5c2cMBsMN6xoMBjp37kxiYmIxRHbzRPIoZbIsKdi0Emevu6n8cNJi0i8f82hbsj4Yn6j+zts/ugDlupkKBUEonDNnzng0J3l0dHSJn6ROJI9SJnf+8tPhOA1SYrdms3XJKyh2z+4W96vtfBqtWlPIPr6osGEKgnANWZaxWq03rvgfq9V6U7ccFKeSHZ3gwvTfWYHJ4Hr2cenETvaunefR9rQBdTFUdr6pMvPgOy6DLwqCcPOqVKnimLPcHX///XeJn4ZWJI9SxmK/OhbOkSqg+DrPW/737++w6YvBpF047PaIuX51hjkt2zOPYDq9tLChCoLwn7Zt27J27VqOHTt2w7rHjh1j7dq1tGvX7tYHVggieZQyNrvZ8X+7RkJu0QFJdu67e/KvFfwy+16WTb+HxMUvcnTnd5gyLuW7TX3Fe9EG3+VUlnlwthiuXRCKyNChQ7FarfTu3ZtLl/L/Ll6+fJlHH30Um83GkCFDijFCz5XJmwTLMvt1I+AGVbuTyC538ufKt1zqZqed48Senzix5yeQJKrcdi933vsy4TWcE4UkSfjXHUHKticdZdbkJKyXNqGv0PbWPBFBKEeaNGnCsGHDePfdd7njjjsYPHgwHTt2pFq1agCcPn2aNWvW8PHHH3Px4kWGDx9Okybu3/jrDWVybKvSyJ1xexRFYcjXzpPI9L/nbVpEP8LhpC/4c+VbWLJSbrivKrd34p7eb2H0D3eUqYqNi7/VxZ519T4PQ8QDhLZednNPSBCKWGkf20pVVcaNG8dbb72Foih5rtdoNLz22mu8/vrrJX6oIJE8Sgh3vhgZpmRG/Oh81jD83q+pV6kFAJasFPaue5+jO7/FnJlc4P78w6Lo8OwiAsKiHGWZh+aRtmeYU73wLn+iC7rT8yckCEWstCePXEeOHCEuLo7Nmzdz7tw5ACpXrkzr1q3p378/tWrVusEWSgaRPEoId74Y/17axczVPZ3Kpj+4iTD/6k5lqqqSfvEIF/7dytmDGzh3aCM2i+u9Gwa/MDo8u4jQqjkDsym2DC6siEa1XE08PpFPEdwsvnBPThCKQFlJHmWFaDAvRZIzT7uUBflGuJRJkkRgxdrUbvEkbZ/+mIcn7KTx/eMx+Dn37TVnXibh06cdNxfKWn/8ag11qpN94ivsWZ4NfSIIQtknkkcpciX7+jtOJbTyjfs8aPW+3N5uEN2G/UpwxB1O68yZl1n/WT/HZS6/2i+CxudqBdVG5sF3Cxm5IAhljUgepUhq9nmnZY2kyadm3nwDK9N58LdUrNnSqTz90lE2LHwWu82MbAjHN+oZp/VZRz/B7pK4BEEoz0TyKEXSTJedlrUavcfb0BkDaNdvgcsZyKXjO9n+4zhUVcWv7nC4JjGp9izS/yrZcwsIglC8RPIoRTLMzj2odBrjTW1HZwyg/YB4fIOc20uO7viGg5vj0PpF4RP5tNO67BNfYLlUskf5FASh+IjkUYpkWlKclg1a37wrusE3qDLtByxEq3fexq7lUzl3eBMB9achaZ17tKTuflmMeSUIAiCSR6mSbUlzWjbqAgq1veCI22jR5x2nMlWxk/jlULKzzATcOclpnS1lN5kHXO9kFwSh/BHJoxQxXTfPhq+u8H3dq9e/j/qdhzmVWbKusHHRIPTV+6MNdG4bSd87EcvFjYXeryAIpZtIHqWIxZbttOxvCCmS7dbvNIyqd3R1Kks5u49t348h8K73cfqYqHauJP0Pe7brPSeCIJQfInmUIteOqAsQYAjLp6ZnJFmmZZ93CKxQ26n8xJ/LOfz3n/jfEetUrpjOcHFVI7KOxaGqrmP0CIJQ9onkUYrYFOeZyAJ9KhTZtnXGANr2W4DO6Hwp7M+Vb5GmNkVfsZNTuWq9QuqO57iwIoq0Pa+Sfeo7rKl/o16X4MToN+WXasvCmrYf84V1mM//jvncKqxXdqJYrqAqFuzZp7Gl/YPddEF0xCiFxJDspYiK86/8YJ/KRbr9wAo1adV3Huvj+0PuQV9VSfzqZdr+7y00GUewZx1zeoySfZrMQ+/Aof8KJA1a/7qgMWDPPI5qTUHS+iFpA5GNFdEYKiFp/XIea0tHyTqFYrmEpA9FY4wASYtqNwEKkmyAa+6gl2Q9kmwESUK1ZaEqZvjvzEfS+iPrQ0HWotqzQbUj64KQNP4olovYs88iSTKSPgxZF5RzH4skg2oHxYrdfAEl+wwgoQ26E61/HeymM9gzj/0Xj4qkMaIxVkHSBaKYL6CYL4JsyNmPLhBJG4CsDUQ2VkI2hKOYL2HPPoU94wj2zH9RbBnI+lAkrR+K6SKK+RySxg+NXyQa3xrI+jAkbSCqYka1Z4E9G9WehT37LPasY6jWdDT+tdEFNcx5nrb0nOcv6wEJ1Z6Fak3Dnn0aJfs0SBKSLhhJ4wOKGVVV0Bgj0PhFgmLDbr6IarmMYrmMYk0FJCRJBo0PstYfSeOPpPMHSYtivohivohqTUWxpiHJWmR9OJI+mJzfoIqjDoo15/VVPZkSWULWh6ENqk9Y+zWefXAFrxDJo5TIMKe4lIX5VSvy/VS5rSONuo1mz68zHGV2q4kNX4yg9eMz8Mv+CdPJr/LfgGrHlr7fuciWgWrLQDGdId/Difki9vQDhX8CRcB6ZVux7s+W5v70pPasY1gu/H7z+2KXe/u5wXpVAbstA7Lyq+BJ4gBQUSyXUCxXPHyc4C3islUpkZxxyqXsViQPgNvbDybqroedyhS7hU1fjSLV8CghrX9CG9TwluxbKN9kQ/iNKwklgkgepcTlrDySh2/VW7IvSZK459FZ1Gj0kFO5qtjZsuRlTh5PJrzTTsK77MH/trHoK9yL7HNrYhFKP0kXjGysjGyoxI0OObKhYvEEJRSauGxVSlzJch2YUKv1fGwrd8kaHS0fn4NW58O/O76+ukJV2fHjOP5a/Q4RddpSsWZLKtzRn6CgCCSs2NP3Y0vbByhofKOQDRVQbZko1pScdgLTeVTFAuS0Ycg+VdEYKqBYkrGbzpPbtoAkg92SUzd3RjXFck37gx+SxvDftXUVxZqKaklGxY6k8QVkVFsqqjUNSR+G5r/kppgv5bQVoOZce5E0IGmQ9SHIPlVQbdnYUnZhzz6D7FMZrV8tJF0QkqTJaaPJPoNiS0Ojr4BsrIiqWHPaAWzpqLZ0FEsyiukcivkysiFnvxrfGmj86yDrQ3Mai61pyIYKyD6VUa2p2DOPoZjO57Q92NKRZCOSxgdJ64uk8UXWhaDxi0LS+mJL3Yst4yBIOmRdAEgaVMUKquKorzFGIPtWy4nZkoKqmHLaj1CxZ53CnnUi57U3VEA2hOe0teiCc15nVUG1Z6Pa0nMuN1rTUVUrsj4c2VgRWReCpAsAxZLTxmFLz2kfkyRkXSiysWJOG4tqz2mL0VXEYjJjs2Ris2SjM/hgMNiRJUAbhKLqkCULWC6jmC8i64um+7lw64nkUUpcP6KuLN36t06WNTTvNROtwZeDiXFO68wZlzi260eO7frxan2NHt/gCALCayLLGjJTvsOSnYqs0aHRGTD4hmD0D0dr8EeSZOy2y2Sn7sKcnYrRPxy/4KrYbSayUs6i2CwYA8Ix+IWiqiqK3Yoka5BlLZIso9ovYbdbsJmzsFmy0PsE4hNYCUnWYjWlodjN6H0qoDPWwmbOxJx1BiQZvTEAnaECGp0RWWtAsVuwW3P2mXFlHapiwz+0Bn4hjZGsMmqKDbstG7stpxeZRlcNWdZiNWdiM19GRUWSZHSGKvgEVsLoH44uNBCNzkh21hVMaRfIPHmSjOQ/sVmy0BkD0GiNmDL2kp12Aa3eF7+QavgGVUZnrI3W4ItitmC3mVHsNhS7Fbs1G6tpB4rdhjEgHJ+AlthtFqymNFTFjqzVo6oqlqwrWLJOo9iPoig2ZFmLRu/zX+KzoChW9D7BGAMiQFWxmlOwZp/AnJ2C1ZSBqthQFQWNzoDW4IdW74dW54Mky5iz9mHJSsFmzsBmyUZVFWRZg6TRIWt0SJKM1ZSOJTsVSZbRGvxRFTuWrLzbMGStAeW/1xRJQm8MRO8bQlClurTrt+DWfKCFIiWSRymRarrktKyVdcWyX0mWafLgJHSGAPaunVtgXcVuIePycTIuHy+wXkl38WjxNphfOeN+g3mpYM/pZFEQR+IAUFUs2alYslNdxloTSi7R5lFKZJidh2O/2RF1b4YkSTSMeZUWj72N/zVzngtCUTP4Bhf5Nrdv30737t0JDg7Gz8+PFi1a8M0333i0DbPZzJQpU6hTpw5Go5EqVaowaNAgLly4UOTxlhbizKOUyLyuq25hRtS9WdF39yb67t6kXz7GuYMbufDvFi4cTcKUfrHYYxFKH1mjR7FbCqyjL+LksW7dOmJiYjAajTz++OMEBATw/fff06dPH06ePMmIESNuuA1FUejRowcrV66kRYsW9OrVi0OHDrFgwQLWrFnD1q1bqVCh6G7YLS0kVdwCXCKkpaURFBREamoqgYGuAx5O+qUTZ9MOO5arBNUltvvq4gwxT6qqYs1OxZydgjkjmYzknMtWqqriG1wFo18oimLHZsnCnJmMOfMydqsJRbEjyxp8Aiuh9wnGlHGRzCun0egM+AZXRaszYkq/iDk7NefauqxFVRVUuxVVVZE1WiSNFp3eD1lrwJKdQnbaBVAVdD5ByLIWS3YKluw0dEZ/DL45DbGW7DRs5gzsNjN2mxmN1oCs0WP0D8MvtAaSrCHj8nGy084hSRokWUajNaDRGgCw2cyoditagz86gx9IMqpiw5KdSnbaBcyZyY52Ab1PEMaACvgEVSYgtAZ6vxCspgxsliyMfmH4BFbCak4n88opzBmXsZjSsVuzkTV6NLqcuGRZg6wzojcGIEky2ekXMGVcQqM1ojMGIGt0jgOy3jcYvU9wzmNlLYpiw27JRlHsaLQGJEnGnJWMKeMysqxBa/RHZwjA4Bucsy1ZC5KM3WbGZs7EZsnCbs1GsdvQ+wY76ml0PsgaLYrdhqrYHP9qDf7ofYIAFaspHQCfwEr4BFREawxAljVYstPISjmD3Wb+r/3HgMWU9l97TQoG/zAqRt+T52ftRt+R69lsNm677TZOnTrF1q1bady4MQCpqak0b96cY8eOcfDgQSIjIwvcTlxcHM888wx9+/blyy+/RPqvA8f8+fMZMmQIgwYN4qOPPrphPGWNSB4lxI2+GKOXtnCaw7x2eDNGdvmuOEMUBK/yNHmsWrWKmJgYBgwYwGeffea0buHChfTv35/JkyczceLEArfTqlUrtmzZwrFjx5wSjaqq1K5dm/Pnz3Px4kV8fHxu7omVUqLNo5Qw251v5fUzBHsnEEEoJRISEgDo2rWry7qYmBgA1q9fX+A2TCYTSUlJ1KtXz+UMRZIkunTpQmZmJjt27CiaoEsR0eZRBLZv305sbCybN2/GarXSoEEDhg8fzmOPPVZk+xgf8wsXMo6TnHWGlKxz1K7QvMi2LQilSVqa86RoBoMBg8HgUu/QoZwB1+rUqeOyrnLlyvj7+zvq5OfIkSMoipLnNq7d9qFDh2jbtq1b8ZcVInkUUlE0yLkjzL86Yf7Vi2RbglCaVa/u/D2IjY1l0qRJLvVSU1MBCAoKynM7gYGBjjr5cWcb19YrT0TyKASbzcbAgQORZZkNGzY4GuQmTpxI8+bNGTt2LL17975hg5wgCO47efKkU5tHXmcdwq0n2jwKYe3atRw5coT//e9/jsQBOb9Sxo4di8ViYeHChd4LUBDKoMDAQKe//JJH7tlCfmcFuQ3wBXFnG9fWK09E8iiEomiQEwTh1ri2PeJ6586dIyMjI9+2jFw1a9ZEluV820YKalcp68Rlq0IoTIOc2WzGbL46REPuL5vrGwMFQciR+91w9+6C9u3bM2PGDFatWsXjjz/utG7lypWOOgXx8fGhefPmbN26lePHj7t01V29ejV+fn40bdrUk6dSNqjCTevSpYsKqIcOHcpzfZUqVdTAwMA818XGxqqA+BN/4s/Dv5MnT7r1/bRarWrNmjVVg8Gg7tq1y1GekpKi1q1bV9Xr9erRo0cd5WfOnFH379+vpqSkOG3ns88+UwG1b9++qqIojvIPP/xQBdRBgwa5FU9ZI24SLISuXbuyevVqDh06RO3atV3WV61alYyMjDyvl15/5qEoCpcvXyY8PNxxB+v10tLSqF69ukuDoVA6iffTM6qqkp6eTpUqVZBl966459cb8vjx48yaNcupN2T//v1ZuHAhcXFx9O/f31GuKArdu3d3DE/Svn17Dh8+zA8//EBUVBRJSUnlcngScdmqENxpTAsJyXt+grz6pgcHB7u139yGQqFsEO+n+zxtmO7YsSObNm0iNjaWr7/+2nEf1syZM+nTp49b25BlmWXLlvHGG2/w+eef88477xAaGsqzzz7L66+/Xi4TB4jhSQpl7NixzJgxg6+++srlmuq5c+eIiIjg3nvvZc2aNUWyP0+HZxBKNvF+CqWZ6G1VCLmNbatWrXJZ526DnCAIQmkkkkchdOrUiZo1a7J48WJ2797tKE9NTWX69Ono9XqefvrpItufwWAgNjZW3BRVRoj3UyjNxGWrQvKkQU4QBKGsEMmjCGzbti3PgRHdbZATBEEobUTyEARBEDwm2jwEQRAEj4nkIQiCIHhMJI9SYvv27XTv3p3g4GD8/Pxo0aIF33zzjbfDKjeioqKQJCnPvw4dOrjUN5vNTJkyhTp16mA0GqlSpQqDBg3iwoUL+e7jyy+/pHnz5vj5+RESEsIDDzzAH3/8kW998ZkQvEncYV4KFNeEU0LBgoKCGDZsmEt5VFSU07KiKPTo0cMxnEWvXr04dOgQCxYsYM2aNWzdutXlruRp06Yxfvx4IiMjGTx4MOnp6SxZsoRWrVqxZs0aWrdu7VRffCYEr/PSmFqCm6xWq1qrVq0CB3c7duyY9wIsJyIjI9XIyEi36no6kN7BgwdVrVar1q1b12lQvl27dqkGg0G9/fbbVbvd7igXnwmhJBDJo4RbuXKlCqgDBgxwWRcfH68C6uTJk70QWfniSfJo2bKlCrgcwBVFUWvWrKn6+fmpWVlZjvIxY8aogLpw4UKXbfXv318F1PXr1zvKxGdCKAlEm0cJJyacKjnMZjPx8fFMnz6d9957j6SkJJc6JpOJpKQk6tWr5zL9sCRJdOnShczMTHbs2OEo9/Q9Fp8JoSQQbR4lXGEmnBKK1rlz5xgwYIBTWbNmzfjqq6+oVasWAEeOHEFRlHxnlrt2dru2bds6/u/v70/lypULrJ9LfCaEkkCceZRwucO95zcUdWBgYL5DwgtFZ8CAAaxZs4bz58+TmZnJrl27eOqpp9i+fTudOnUiPT0dcO/9urZe7v89rX+jfYjPhHCriTMPQXBDbGys03Ljxo1ZtGgRAJ9//jmffPIJw4cP90ZoguAV4syjhHNnwilPJ8gRis7zzz8PQGJiIuDe+3Vtvdz/e1r/RvsQnwnhVhPJo4TL65p3rnPnzpGRkZHv9XXh1gsPDwcgMzMTgJo1ayLLcr5tDnm1V9SpU4eMjAzOnTvndv1r111LfCaE4iKSRwknJpwq2XJ7XOXeKOjj40Pz5s05cOAAx48fd6qrqiqrV6/Gz8+Ppk2bOso9fY/FZ0IoEbzdV1gomNVqVWvWrFngDWFHjx71Wnzlwf79+9XMzMw8yytXruxyH4anNwkeOHDA45sExWdC8DaRPEqBtWvXqjqdTg0ICFAHDhyoDh8+XI2MjFQBddasWd4Or8yLjY1VAwIC1Pvvv1994YUX1JEjR6o9evRQdTqdCqhjxoxxqm+329WYmBgVUFu0aKGOGjVK7dWrlypJkhodHa1euHDBZR+vv/66CqiRkZHq8OHD1YEDB6oBAQGqwWBQN23a5FJffCYEbxPJo5RISkpSu3XrpgYGBqo+Pj5q8+bN1SVLlng7rHIhISFBfeyxx9Q6deqogYGBqlarVStXrqz26NFDXblyZZ6PMZlM6qRJk9RatWqper1erVy5svrcc8+p586dy3c/X3zxhdq0aVPVx8dHDQoKUrt3767u3Lkz3/riMyF4k5gMShAEQfCYaDAXBEEQPCaShyAIguAxkTwEQRAEj4nkIQiCIHhMJA9BEATBYyJ5CIIgCB4TyUMQBEHwmEgegiAIgsdE8hBKDEmS6NChQ6G2kZCQgCRJTJo0qUhiEgQhb2IyKMGJJEke1RcDFBSd3JF5jx075tU4BMEdInkITq6fMQ/g3XffJTU1Nc91RWn//v34+voWahvNmzdn//79jnk2BEG4NcTYVsINRUVFcfz4cXGWcYuJMw+hNBFtHsJNOXbsGJIk0b9/f/bv38/DDz9MWFgYkiQ5Dn4//vgjffv2pXbt2vj6+hIUFETbtm35/vvv89xmXm0e/fv3R5Ikjh49yty5c7ntttswGAxERkYyefJkFEVxqp9fm0dUVBRRUVFkZGTwf//3f1SpUgWDwUDDhg357rvv8n2Offr0ITQ0FH9/f9q3b8+GDRuYNGkSkiSRkJDg1mv1xx9/0Lt3b2rUqIHBYKBChQo0a9aMadOmOb2Wx48f5/jx40iS5Pi7/nls2LCBBx98kPDwcAwGA3Xq1GH8+PFkZWXl+zps2rSJDh06EBAQQHBwML169eLw4cMucR46dIgBAwYQHR2NwWAgNDSURo0aMWzYMPHDQXAhLlsJhXL48GFatGhBgwYN6N+/P5cvX0av1wMwZswY9Ho9bdq0ISIigosXL/LTTz/Ru3dv5s6dy0svveT2fkaOHMn69et54IEHiImJYenSpUyaNAmLxeI4CN+I1Wqla9euXLlyhV69epGVlcWSJUt47LHH+O233+jatauj7unTp2nVqhVnz56lW7du3HXXXRw4cIAuXbpw7733uh337t27adWqFRqNhh49ehAZGUlKSgr79u3j448/Zty4cQQHBxMbG8u7774LwLBhwxyPvzaZfvjhhwwdOpTg4GAefPBBKlasyI4dO5g2bRrr1q1j3bp1jtc+19atW5kxYwbdunXjpZdeYu/evfz4449s3LiRrVu3UrNmTQDOnDlD8+bNyczM5P7776dPnz5kZmZy6NAhPvjgA2bNmoVWKw4XwjW8OBy8UErkTjJ0raNHj6qACqgTJ07M83FHjhxxKUtPT1cbNGigBgUFuczOB6jt27d3KuvXr58KqNHR0eqZM2cc5RcvXlSDg4PVgIAA1Ww2O8rXrVunAmpsbGyez6FHjx5O9X///XcVUGNiYpzqP/nkkyqgTps2zan8008/dTzvdevW5fm8rzV8+HAVUJcuXeqy7tKlSy4xRkZG5rmdvXv3qlqtVm3UqJHL42bMmOEyCVTu6wCo8+fPd6o/f/58FVAfeOABR9ncuXNVQH333Xdd9n358uUbPk+h/BGXrYRCqVy5MuPGjctzXe6v2mv5+/vTv39/UlNT2b59u9v7mTBhAhEREY7l8PBwevToQXp6OgcOHHB7O++8847Tr/NOnToRGRnpFIvZbObbb7+lYsWKjBgxwunxAwYMoF69em7vL5ePj49LWVhYmNuP/+ijj7DZbMybN8/lca+99hoVKlTgq6++cnlc3bp1GThwoFPZwIEDqVOnDr/88gsXL168YZyhoaFuxymUH+I8VCiURo0auVwqyXXhwgXeeOMNfv31V44fP052drbT+jNnzri9n7vvvtulrFq1agCkpKS4tY3g4GCio6Pz3M6WLVscywcOHMBsNtO0aVMMBoNTXUmSaNWqldsJ67HHHuPdd9/l4Ycfpk+fPnTp0oV27dpRtWpVtx6fa+vWrQCsXLmSNWvWuKzX6XT8888/LuWtW7dGlp1/I8qyTOvWrTl06BB79uyhc+fOPPjgg4wZM4ahQ4eyZs0aunXrRvv27fP8ASAIIJKHUEiVKlXKszw5OZlmzZpx4sQJWrduTefOnQkODkaj0bB7926WLVuG2Wx2ez+BgYEuZbnX4O12u1vbCAoKyrNcq9U6NbynpaUBULFixTzr5/ec83LPPfeQkJDA9OnTWbx4MXFxcQA0a9aMmTNn0rFjR7e2k5ycDOB2+86NYs0tT01NBXI6FGzdupVJkyaxYsUKvvnmGwBuu+02pkyZwqOPPurRfoWyTyQPoVDyu6nw008/5cSJE0ydOpXx48c7rXvjjTdYtmxZcYR3U3IT1YULF/Jcf/78eY+217ZtW3799Veys7NJSkri559/5oMPPuD+++/n77//duvXfW5MaWlpBAQEuL3v/GLNLb82odavX5/vvvsOq9XKzp07+fXXX5k7dy59+vShSpUqtG7d2u39CmWfaPMQbokjR44A0KNHD5d1GzduLO5wPFKvXj0MBgM7d+50OTtSVdXpEpcnfHx86NChA7Nnz2bs2LFkZ2ezevVqx3qNRpPvWdQ999wDXL185a7ExESX7syKorB582YkSaJRo0Yuj9HpdLRo0YLJkyczd+5cVFVl+fLlHu1XKPtE8hBuicjISAA2bdrkVL548WJWrFjhjZDcZjAY6N27N+fPn3d0n821aNGiPNsW8rNlyxZMJpNLee4vf6PR6CgLDQ3l0qVLedZ/4YUX0Gq1vPTSS5w4ccJlfUpKCrt27XIpP3jwIJ988olT2SeffMLBgwe5//77qVChAgA7d+50XK67UZyCAOKylXCLPPXUU8ycOZOXXnqJdevWERkZyZ49e1izZg2PPPIIP/zwg7dDLNCMGTP4/fffGT16NOvXr3fc57F8+XK6devGb7/95tIQnZeZM2eybt062rVrR3R0NEajkT/++IM1a9ZQs2ZNHn74YUfde++9lx07dnDffffRtm1b9Ho97dq1o127dtSvX58PPviAIUOGUK9ePbp3706tWrVIT0/n33//Zf369fTv35/58+c77T8mJoaXX36ZFStWcOedd7J3715+/vlnwsPDmTNnjqPe559/zkcffUS7du2oVasWgYGB7Nu3jxUrVhAaGsqAAQOK7sUVygSRPIRbolq1aqxfv57XXnuN33//HZvNRpMmTVi1ahUnT54s8cmjevXqbNmyhVGjRrFq1SrWr1/P3XffzapVq/j222+BvBvxrzdkyBCCgoJISkpi/fr1qKpKjRo1GDt2LK+88orTNiZMmMCVK1dYvnw5GzduxG63ExsbS7t27YCcLraNGzfm7bffZsOGDfz8888EBQVRo0YNXnnlFfr16+ey/xYtWjB+/HjGjx/P3Llz0Wg09OzZkzfffNOpraVv376YTCYSExPZtm0bZrOZatWqMWTIEEaOHEmNGjUK+5IKZYwY20oQPNSmTRu2bNlCamoq/v7+3g4nTwkJCXTs2JHY2FgxPL1wS4g2D0HIx9mzZ13KvvjiCxITE+ncuXOJTRyCUBzEZStByEf9+vW56667uOOOOxz3pyQkJBAQEMCsWbO8HZ4geJVIHoKQj8GDB/Pzzz+zY8cOMjMzqVChAv/73/+YMGECt912m7fDEwSvEm0egiAIgsdEm4cgCILgMZE8BEEQBI+J5CEIgiB4TCQPQRAEwWMieQiCIAgeE8lDEARB8JhIHoIgCILHRPIQBEEQPCaShyAIguCx/weTJKEtnWZYtQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display_learning(cos_sim_list_o, grad_norm_list, p_norm_list, title1=\"Partial cosine\",\n",
    "                 title2=\"Partial diff\", y_lim_u=2.5,\n",
    "                 title3=\"Preds diff\", second_axis=True,\n",
    "                 y_lim_u2=1,  color_add=0.2, loc_sec = 'lower left',\n",
    "                 y_lim_l2=0.8,\n",
    "                 rw=1, num_iter_os=len(cos_sim_list[0])*100, title=\"sim_cos_pre_layer1_doc5_dim10_5000_GD++.pdf\",\n",
    "                 allow_download=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a9788c4-7cb4-4282-b160-8d51e4f375e3",
   "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.10.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
