{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "ebb5b8d0-9719-4969-ba66-f47d13e0bea9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as patches\n",
    "import matplotlib.ticker as mticker\n",
    "\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.colors import TwoSlopeNorm, LinearSegmentedColormap\n",
    "from matplotlib.patches import FancyArrowPatch\n",
    "from scipy.special import softmax\n",
    "from utils.funcs import *\n",
    "from utils.data_utils import *\n",
    "from utils.plot_utils import *\n",
    "from src.models import *\n",
    "from utils.config import Config\n",
    "from run_experiments import set_seed\n",
    "\n",
    "import os, re\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True\n",
    "})\n",
    "\n",
    "# Create a custom colormap that centers 'cividis' with white at zero\n",
    "cividis_with_white = LinearSegmentedColormap.from_list(\n",
    "    'cividis_white_center', \n",
    "    ['#0D2758', 'white', '#A32015'],  # Colors at low, middle, and high points in 'cividis'\n",
    "    N=256\n",
    ")\n",
    "device = 'cpu'  # Replace with 'cuda' if using GPU"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "32c4d6af-d901-458c-b990-08ad89ea40f0",
   "metadata": {},
   "source": [
    "#### Define key quantities for all plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "3fc9a952-25e3-4e40-b59b-508f16745261",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_head = 1  # Example values for `n_head`\n",
    "d = 5  # Fixed value for `d`\n",
    "n_sam = 10000 # number of samples to evaluate error\n",
    "#covariance = \"isotropic\"\n",
    "covariance = \"KCM 0.5\"\n",
    "base_dir = f\"saved_models/{covariance}\"\n",
    "\n",
    "activation_ls = ['softmax', 'linear']\n",
    "activation_dict = {\n",
    "    \"softmax\": nn.functional.softmax,\n",
    "    \"linear\": None\n",
    "}\n",
    "\n",
    "loss_func = torch.nn.MSELoss()\n",
    "\n",
    "pattern = re.compile(\n",
    "    r\"Activation_(.+?)_L_(\\d+)_d_(\\d+)$\"\n",
    ")\n",
    "\n",
    "L_ls = set()\n",
    "\n",
    "# Load values of L for which experiments have been saved\n",
    "for name in os.listdir(base_dir):\n",
    "    match = pattern.match(name)\n",
    "    if match:\n",
    "        L_ls.add(int(match.group(2)))  # L value to extract from directory name\n",
    "        \n",
    "L_ls = sorted(L_ls)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "69fac663-f782-4525-9836-0cae048281e3",
   "metadata": {
    "tags": []
   },
   "source": [
    "#### Visualize evolution of error with L"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "0a82d281",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize a list to store error lists for each model\n",
    "all_model_errors = []\n",
    "\n",
    "# Loop through each value in `n_head_ls`\n",
    "for activation in activation_ls:\n",
    "    # Initialize a list to store errors for different `L` values for this model\n",
    "    model_errors = []\n",
    "    for L in L_ls:\n",
    "        try:\n",
    "            # Define the model path\n",
    "            directory = base_dir+f\"/Activation_{activation}_L_{L}_d_{d}\"\n",
    "            model_path, _ = find_latest_checkpoint(directory)\n",
    "\n",
    "            # Load the model state_dict\n",
    "            model_head_1_load = torch.load(model_path, map_location=torch.device(device))\n",
    "            model_head_1 = model_head_1_load['model']  # Assuming the model is saved under the key 'model'\n",
    "            config = model_head_1_load['config']\n",
    "            \n",
    "            # Create the model architecture\n",
    "            model = MultiHeadAttention( n_embd = config.n_embd,\n",
    "                                        n_head = config.n_head,\n",
    "                                        n_out = config.n_out,\n",
    "                                        bias = False,\n",
    "                                        activation = activation_dict[config.activation],\n",
    "                                        normalize = config.normalize\n",
    "                                    )\n",
    "            model.load_state_dict(model_head_1, strict=True)\n",
    "            model.eval()  # Set the model to evaluation mode\n",
    "        \n",
    "            # Generate new data with varying `L`\n",
    "            evaluate_kernel_data = LinearReg({\n",
    "                \"L\": L,\n",
    "                \"dx\": d,\n",
    "                \"dy\": 1,\n",
    "                \"number_of_samples\": n_sam,\n",
    "                \"noise_std\": config.noise_std,\n",
    "                \"covariance\": covariance\n",
    "            })\n",
    "            \n",
    "            # Generate the data\n",
    "            zs_q, zs, ys_q = evaluate_kernel_data.__generatedata__()\n",
    "            \n",
    "            # Ensure data is on the same device as the model\n",
    "            zs_q, zs, ys_q = zs_q.to(device), zs.to(device), ys_q.to(device)\n",
    "\n",
    "            # Compute the model's output\n",
    "            method_output = model(zs_q, zs).squeeze(-1)\n",
    "\n",
    "            # Compute the error using MSELoss\n",
    "            error = loss_func(method_output, ys_q.squeeze(-1)).item() #+ 0.1\n",
    "            model_errors.append(error)\n",
    "\n",
    "        #print(f\"Errors for activation={activation}: {model_errors}\")\n",
    "\n",
    "        except Exception as e:\n",
    "            print(f\"Failed to evaluate model for activation={activation} and L={L}. Error: {e}\")\n",
    "            model_errors.append(np.NAN)  # Append an empty list for models that failed\n",
    "        \n",
    "    # Append the error list for this model to the main list\n",
    "    all_model_errors.append(model_errors)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "788c9a08-c610-4d4a-afe2-a61249ff3345",
   "metadata": {},
   "outputs": [],
   "source": [
    "# evaluate Bayes optimal estimator (ridge)\n",
    "lam = config.noise_std**2 * d # optimal parameter lambda for Ridge\n",
    "model_errors = []\n",
    "\n",
    "for L in L_ls:\n",
    "    evaluate_kernel_data = LinearReg({\n",
    "        \"L\": L,\n",
    "        \"dx\": d,\n",
    "        \"dy\": 1,\n",
    "        \"number_of_samples\": n_sam,\n",
    "        \"noise_std\": config.noise_std,\n",
    "        \"covariance\": covariance\n",
    "    })\n",
    "    \n",
    "    # generate data\n",
    "    zs_q, zs, ys_q = evaluate_kernel_data.__generatedata__()\n",
    "    x, y = zs[:,:,:-1], zs[:,:,-1].unsqueeze(-1)\n",
    "    x_q = zs_q[:,:,:-1]\n",
    "\n",
    "    # Compute the model's output\n",
    "    \n",
    "    method_output = ridge_estimator(x,y,x_q, lam=lam)\n",
    "    \n",
    "    # Compute the error using MSELoss\n",
    "    loss_func = torch.nn.MSELoss()\n",
    "    error = loss_func(method_output, ys_q).item() #+ 0.1\n",
    "    model_errors.append(error)\n",
    "    \n",
    "if len(all_model_errors)<=2:\n",
    "    all_model_errors.append(model_errors)\n",
    "else:\n",
    "    all_model_errors[2]= model_errors\n",
    "\n",
    "# Print the full list of errors\n",
    "#print(\"All model errors:\", all_model_errors)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "fe8a0bfc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define colors, labels, and markers for the lines\n",
    "colors = ['dodgerblue', 'sandybrown', 'forestgreen',\n",
    "          '#d62728', '#9467bd', '#8c564b']\n",
    "#markers = ['o', 's', '^', 'D', 'v', 'X']\n",
    "linestyles = [\n",
    "    '-',                    # solid\n",
    "    '-.',                   # dash-dot\n",
    "    ':',                   # dotted\n",
    "    '--',                    # dashed\n",
    "    (0, (5, 1)),            # long dash\n",
    "    (0, (3, 1, 1, 1))       # dash-dot-dot\n",
    "]\n",
    "\n",
    "labels = [f'{activation} attention' for activation in activation_ls] + [r'$L$-Bayes optimal']\n",
    "\n",
    "# Create the plot\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "\n",
    "for idx in range(len(all_model_errors)):\n",
    "    ax.plot(\n",
    "        L_ls,\n",
    "        all_model_errors[idx],\n",
    "        color=colors[idx],\n",
    "        #linestyle=':',\n",
    "        linestyle=linestyles[idx],\n",
    "        linewidth=2,\n",
    "        label=labels[idx]\n",
    "    )\n",
    "\n",
    "# Plot noise level\n",
    "line = ax.axhline(\n",
    "    config.noise_std ** 2,\n",
    "    linestyle=\"--\",\n",
    "    linewidth=2,\n",
    "    color=\"slategray\"\n",
    ")\n",
    "\n",
    "ax.annotate(\n",
    "    r\"noise level\",\n",
    "    xy=(0.99, config.noise_std ** 2),\n",
    "    xycoords=ax.get_yaxis_transform(),\n",
    "    xytext=(0, -6),          # ← move up by 6 points\n",
    "    textcoords=\"offset points\",\n",
    "    ha=\"right\",\n",
    "    va=\"top\",\n",
    "    fontsize=18,\n",
    "    color=line.get_color(),\n",
    ")\n",
    "\n",
    "# Customize the plot (OO style)\n",
    "ax.set_xlabel(r'Prompt Length $L$', fontsize=24)\n",
    "ax.set_ylabel(r'ICL Risk $\\mathcal{R}_L^{\\mathrm{ICL}}$', fontsize=24)\n",
    "ax.set_ylim(bottom=0)\n",
    "ax.tick_params(axis='both', labelsize=15)\n",
    "ax.legend(fontsize=20, loc='upper right')\n",
    "ax.grid(True, linestyle='-', linewidth=0.5, alpha=0.3)\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save and show\n",
    "fig.savefig(f\"figures/loss_comparison_{covariance}.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "28429d47-0035-4174-869f-ae7954518fa5",
   "metadata": {},
   "source": [
    "## Compare Dynamics of Trained One-Layer Transformer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "75e23366-0055-4886-99d8-56ed0a7aa2a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dict of norm diffs between training trajectories for all L\n",
    "norm_diff = dict()\n",
    "saved_steps = dict()\n",
    "\n",
    "# store test loss over training steps\n",
    "test_loss = {\"softmax\":dict(),\n",
    "              \"linear\":dict()}\n",
    "\n",
    "for L in L_ls:\n",
    "    try:\n",
    "         # Define the model path\n",
    "        directory_s = base_dir+f\"/Activation_softmax_L_{L}_d_{d}\"\n",
    "        _, step_s = find_latest_checkpoint(directory_s)\n",
    "        \n",
    "        directory_l = base_dir+f\"/Activation_linear_L_{L}_d_{d}\"\n",
    "        _, step_l = find_latest_checkpoint(directory_l)\n",
    "        \n",
    "        last_step = min(step_s,step_l)\n",
    "        path_s = directory_s + f\"/step_{0}.pth\"\n",
    "        \n",
    "        # Load the model state_dict\n",
    "        model_head_1_load = torch.load(path_s, map_location=torch.device(device))\n",
    "        config = model_head_1_load['config']\n",
    "        save_every = config.save_log_every_step\n",
    "        \n",
    "        # Create the model architectures\n",
    "        model_s = MultiHeadAttention( n_embd = d+1,\n",
    "                                    n_head = n_head,\n",
    "                                    n_out = 1,\n",
    "                                    bias = False,\n",
    "                                    activation = activation_dict['softmax']\n",
    "                                )\n",
    "        \n",
    "        model_l = MultiHeadAttention( n_embd = d+1,\n",
    "                                    n_head = n_head,\n",
    "                                    n_out = 1,\n",
    "                                    bias = False,\n",
    "                                    activation = activation_dict['linear']\n",
    "                                )\n",
    "        \n",
    "        norm_diff[L] = []\n",
    "        saved_steps[L] = []\n",
    "        test_loss[\"softmax\"][L] = []\n",
    "        test_loss[\"linear\"][L] = []\n",
    "        \n",
    "        for step in range(0, last_step+1, save_every):\n",
    "            path_s = directory_s + f\"/step_{step}.pth\"\n",
    "            path_l = directory_l + f\"/step_{step}.pth\"\n",
    "\n",
    "            # Load the softmax model state_dict\n",
    "            model_head_1_load = torch.load(path_s, map_location=torch.device(device))\n",
    "            model_head_1 = model_head_1_load['model']  # Assuming the model is saved under the key 'model'\n",
    "\n",
    "            model_s.load_state_dict(model_head_1, strict=True)\n",
    "            \n",
    "            # Load the linear model state_dict\n",
    "            model_head_0_load = torch.load(path_l, map_location=torch.device(device))\n",
    "            model_head_0 = model_head_0_load['model']  # Assuming the model is saved under the key 'model'\n",
    "\n",
    "            model_l.load_state_dict(model_head_0, strict=True)\n",
    "            \n",
    "            norm_diff[L].append(weight_l2_distance(model_l, model_s))\n",
    "            saved_steps[L].append(step)\n",
    "            \n",
    "    except Exception as e:\n",
    "        print(f\"Failed to evaluate model for L={L}. Error: {e}\")\n",
    "        #pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "5a9cdfb2-1f0a-45ca-b408-cae3fadb8003",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# List of L to plot\n",
    "L_toplot = [10, 50, 100, 200, 1000]\n",
    "#L_toplot = range(80,101,5)\n",
    "\n",
    "L_toplot = list(set(L_toplot) & set(norm_diff.keys())) # keep only L for which we have values\n",
    "L_toplot.sort()\n",
    "\n",
    "# Define colors and linestyles\n",
    "colors = plt.cm.viridis(np.linspace(0.1, 0.9, len(L_toplot)))\n",
    "linestyles = [\n",
    "    '-',                    # solid\n",
    "    '--',                   # dashed\n",
    "    '-.',                   # dash-dot\n",
    "    ':',                    # dotted\n",
    "    (0, (5, 1)),            # long dash\n",
    "    (0, (3, 1, 1, 1))       # dash-dot-dot\n",
    "]\n",
    "\n",
    "# Create the plot\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "for idx,L in enumerate(L_toplot):\n",
    "    # Plot with dotted lines and empty markers\n",
    "    plt.plot(\n",
    "        saved_steps[L], norm_diff[L], \n",
    "        color=colors[idx], linewidth=2,\n",
    "        linestyle='-',\n",
    "        label=f\"L={L}\"\n",
    "    )\n",
    "    \n",
    "# Customize the plot\n",
    "ax.ticklabel_format(axis=\"x\", style=\"sci\", scilimits=(0, 0))\n",
    "ax.set_xlabel(r\"Training step $t$\", fontsize=24)\n",
    "ax.set_ylabel(r\"$\\|\\theta^{\\mathrm{lin}}(t)-\\theta^{\\mathrm{soft}}(t)\\|_2$\", fontsize=24)\n",
    "ax.set_xlim(0,3e5)\n",
    "ax.set_ylim(0)\n",
    "ax.tick_params(axis='both', labelsize=15)\n",
    "ax.legend(fontsize=20, loc='upper right')\n",
    "ax.grid(True, linestyle='-', linewidth=0.5, alpha=0.3)\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save the plot as a PDF and display it\n",
    "fig.savefig(f\"figures/parameters_comparison_{covariance}.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2d2665c8-830e-4cd0-b623-7b76cb5e9592",
   "metadata": {},
   "source": [
    "## Visualizing similarity of gradients and model outputs at initializations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "958fd915-aa22-4e7f-8301-136e04cd67e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "grad_diff = []\n",
    "output_diff = []\n",
    "# also stores mean norms and outputs for relative comparisons\n",
    "grad_norm = {\"softmax\":[],\n",
    "            \"linear\":[]}\n",
    "mean_output = {\"softmax\":[],\n",
    "            \"linear\":[]}\n",
    "\n",
    "set_seed(376)\n",
    "\n",
    "# Initialize the model architectures (we will use the same initialization for all values of L)\n",
    "model_s = MultiHeadAttention( n_embd = d+1,\n",
    "                            n_head = n_head,\n",
    "                            n_out = 1,\n",
    "                            bias = False,\n",
    "                            activation = activation_dict['softmax']\n",
    "                        )\n",
    "\n",
    "model_l = MultiHeadAttention( n_embd = d+1,\n",
    "                            n_head = n_head,\n",
    "                            n_out = 1,\n",
    "                            bias = False,\n",
    "                            activation = activation_dict['linear'],\n",
    "                             normalize = True\n",
    "                        )\n",
    "# initialize same weights for both architectures\n",
    "model_l.load_state_dict(model_s.state_dict())\n",
    "\n",
    "for L in L_ls:\n",
    "    try:\n",
    "                # Generate new data with varying `L`\n",
    "        evaluate_kernel_data = LinearReg({\n",
    "            \"L\": L,\n",
    "            \"dx\": d,\n",
    "            \"dy\": 1,\n",
    "            \"number_of_samples\": n_sam,\n",
    "            \"noise_std\": config.noise_std,\n",
    "            \"covariance\": covariance\n",
    "        })\n",
    "\n",
    "        # Generate the data\n",
    "        zs_q, zs, ys_q = evaluate_kernel_data.__generatedata__()\n",
    "\n",
    "        # Ensure data is on the same device as the model\n",
    "        zs_q, zs, ys_q = zs_q.to(device), zs.to(device), ys_q.to(device)\n",
    "\n",
    "        model_s.zero_grad()\n",
    "        model_l.zero_grad()\n",
    "        \n",
    "        # Compute the models' outputs\n",
    "        output_s = model_s(zs_q, zs).squeeze(-1)\n",
    "        output_l = model_l(zs_q, zs).squeeze(-1)\n",
    "\n",
    "        # Compute the error using MSELoss\n",
    "        error_s = loss_func(output_s, ys_q.squeeze(-1))\n",
    "        error_l = loss_func(output_l, ys_q.squeeze(-1))\n",
    "        \n",
    "        # compute the gradients\n",
    "        error_s.backward()\n",
    "        grads_s = [p.grad.clone() for p in model_s.parameters()]\n",
    "        \n",
    "        error_l.backward()\n",
    "        grads_l = [p.grad.clone() for p in model_l.parameters()]\n",
    "\n",
    "        # gradient difference norm\n",
    "        diff_sq = 0.0\n",
    "        gs_norm = 0.0\n",
    "        gl_norm = 0.0\n",
    "        for gs, gl in zip(grads_s, grads_l):\n",
    "            diff_sq += torch.norm(gs - gl).item() ** 2\n",
    "            gs_norm += torch.norm(gs).item() ** 2\n",
    "            gl_norm += torch.norm(gl).item() ** 2\n",
    "        \n",
    "        output_diff.append(torch.norm(output_s - output_l).item()**2/n_sam)\n",
    "        mean_output[\"softmax\"].append(torch.norm(output_s).item()**2/n_sam)\n",
    "        mean_output[\"linear\"].append(torch.norm(output_l).item()**2/n_sam)\n",
    "        \n",
    "        grad_diff.append(diff_sq)\n",
    "        grad_norm[\"softmax\"].append(gs_norm)\n",
    "        grad_norm[\"linear\"].append(gl_norm)\n",
    "            \n",
    "    except Exception as e:\n",
    "        print(f\"Failed to evaluate model for L={L}. Error: {e}\")\n",
    "        #pass\n",
    "        output_diff.append(np.NAN)\n",
    "        grad_diff.append(np.NAN)\n",
    "        grad_norm[\"softmax\"].append(np.NAN)\n",
    "        grad_norm[\"linear\"].append(np.NAN)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "3cc1bee6-1dca-4697-b18f-35e8b8abec97",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create the plot\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "\n",
    "if covariance=='isotropic': # different linewdiths depending on covariance\n",
    "    lw=4\n",
    "else:\n",
    "    lw=2\n",
    "\n",
    "ax.plot(\n",
    "    L_ls,\n",
    "    output_diff,\n",
    "    color='dodgerblue',\n",
    "    linestyle='-',\n",
    "    linewidth=lw,\n",
    "    label=r'$\\mathbf{E}[\\|T[\\hat{\\mu}_L](z_{\\mathrm{q}})-T^{\\mathrm{lin}}[\\hat{\\mu}_L](z_{\\mathrm{q}})\\|^2]$'\n",
    ")\n",
    "\n",
    "# Customize the plot\n",
    "ax.set_ylim(bottom=0)\n",
    "\n",
    "if covariance=='isotropic': # different fontsize depending on covariance\n",
    "    ax.set_xlabel(r'Prompt Length $L$', fontsize=32)\n",
    "    ax.set_ylabel(r'$\\mathbf{E}\\big[\\|T[\\hat{\\mu}_L](z_{\\mathrm{q}})-T^{\\mathrm{lin}}[\\hat{\\mu}_L](z_{\\mathrm{q}})\\|^2\\big]$', fontsize=26)\n",
    "    ax.ticklabel_format(axis=\"y\", style=\"sci\", scilimits=(0, 0))\n",
    "    ax.tick_params(axis='both', labelsize=24)\n",
    "    ax.yaxis.get_offset_text().set_fontsize(20)\n",
    "else:\n",
    "    ax.set_xlabel(r'Prompt Length $L$', fontsize=24)\n",
    "    ax.set_ylabel(r'$\\mathbf{E}\\big[\\|T[\\hat{\\mu}_L](z_{\\mathrm{q}})-T^{\\mathrm{lin}}[\\hat{\\mu}_L](z_{\\mathrm{q}})\\|^2\\big]$', \n",
    "                  fontsize=24)\n",
    "    ax.ticklabel_format(axis=\"y\", style=\"sci\", scilimits=(0, 0))\n",
    "    ax.tick_params(axis='both', labelsize=15)\n",
    "    ax.yaxis.get_offset_text().set_fontsize(14)\n",
    "\n",
    "\n",
    "ax.grid(True, linestyle='-', linewidth=1, alpha=0.3)\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save and show\n",
    "fig.savefig(f\"figures/output_difference_{covariance}.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "d41abd8b-1bc2-4f3b-ba55-3b741276de15",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create the plot\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "\n",
    "ax.plot(\n",
    "    L_ls,\n",
    "    grad_diff,\n",
    "    color='forestgreen',\n",
    "    linestyle='-',\n",
    "    linewidth=lw,\n",
    "    label=r'$\\|\\nabla\\mathcal{R}_L^{\\mathrm{ICL}}-\\nabla\\mathcal{R}_L^{\\mathrm{ICL, lin}}\\|_2^2$'\n",
    ")\n",
    "\n",
    "# Customize the plot (OO style)\n",
    "\n",
    "if covariance=='isotropic': # different fontsize depending on covariance\n",
    "    ax.set_xlabel(r'Prompt Length $L$', fontsize=32)\n",
    "    ax.set_ylabel(r'$\\|\\nabla\\mathcal{R}_L^{\\mathrm{ICL}}-\\nabla\\mathcal{R}_L^{\\mathrm{ICL, lin}}\\|_2^2$', \n",
    "                  fontsize=32)\n",
    "    ax.yaxis.get_offset_text().set_fontsize(20)\n",
    "    ax.tick_params(axis='both', labelsize=24)\n",
    "else:\n",
    "    ax.set_xlabel(r'Prompt Length $L$', fontsize=24)\n",
    "    ax.set_ylabel(r'$\\|\\nabla\\mathcal{R}_L^{\\mathrm{ICL}}-\\nabla\\mathcal{R}_L^{\\mathrm{ICL, lin}}\\|_2^2$', \n",
    "                  fontsize=24)\n",
    "    ax.yaxis.get_offset_text().set_fontsize(13)\n",
    "    ax.tick_params(axis='both', labelsize=15)\n",
    "ax.ticklabel_format(axis=\"y\", style=\"sci\", scilimits=(0, 0))\n",
    "ax.set_ylim(bottom=0)\n",
    "ax.grid(True, linestyle='-', linewidth=1, alpha=0.3)\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save and show\n",
    "fig.savefig(f\"figures/gradient_difference_{covariance}.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eae86c87-c98b-47e7-9c12-027bd91eb506",
   "metadata": {},
   "source": [
    "## Visualizing evolution of ICL risk during training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "224e956e-5bc4-4bcc-9d09-ecb0ccf6d5e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# store test loss over training steps\n",
    "loss_dyn = {\"softmax\":dict(),\n",
    "              \"linear\":dict()}\n",
    "\n",
    "steps_dyn = {\"softmax\":dict(),\n",
    "              \"linear\":dict()}\n",
    "\n",
    "L_toplot = [10, 100, 1000]\n",
    "plot_every = 1000 # load and plot a data point every plot_every iterations\n",
    "\n",
    "for activation in activation_ls:\n",
    "    for L in L_toplot:\n",
    "        try:\n",
    "             # Define the model path\n",
    "            directory = base_dir+f\"/Activation_{activation}_L_{L}_d_{d}\"\n",
    "            #_, last_step = find_latest_checkpoint(directory)\n",
    "            last_step = 300000\n",
    "            \n",
    "            path = directory + f\"/step_{0}.pth\"\n",
    "\n",
    "            # Create the model architecture\n",
    "            model = MultiHeadAttention( n_embd = d+1,\n",
    "                                        n_head = n_head,\n",
    "                                        n_out = 1,\n",
    "                                        bias = False,\n",
    "                                        activation = activation_dict[activation]\n",
    "                                    )\n",
    "\n",
    "\n",
    "            loss_dyn[activation][L] = []\n",
    "            steps_dyn[activation][L] = []\n",
    "            \n",
    "            # Generate new data with varying `L`\n",
    "            evaluate_kernel_data = LinearReg({\n",
    "                \"L\": L,\n",
    "                \"dx\": d,\n",
    "                \"dy\": 1,\n",
    "                \"number_of_samples\": n_sam,\n",
    "                \"noise_std\": config.noise_std,\n",
    "                \"covariance\": covariance\n",
    "            })\n",
    "\n",
    "            # Generate the data\n",
    "            zs_q, zs, ys_q = evaluate_kernel_data.__generatedata__()\n",
    "            \n",
    "            for step in range(0, last_step+1, plot_every):\n",
    "                path = directory + f\"/step_{step}.pth\"\n",
    "\n",
    "                # Load the softmax model state_dict\n",
    "                model_head_1_load = torch.load(path, map_location=torch.device(device))\n",
    "                model_head_1 = model_head_1_load['model']  # Assuming the model is saved under the key 'model'\n",
    "\n",
    "                model.load_state_dict(model_head_1, strict=True)\n",
    "                \n",
    "                # Compute the model's output\n",
    "                method_output = model(zs_q, zs).squeeze(-1)\n",
    "\n",
    "                loss_dyn[activation][L].append(loss_func(method_output, ys_q.squeeze(-1)).item())\n",
    "                steps_dyn[activation][L].append(step)\n",
    "\n",
    "        except Exception as e:\n",
    "            print(f\"Failed to evaluate model for activation {activation} and L={L}. Error: {e}\")\n",
    "            #pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3033527-8527-4f2b-9b14-64d92708a530",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define colors and linestyles\n",
    "colors = dict()\n",
    "colors[\"softmax\"] = plt.cm.Blues(np.linspace(0.2, 0.9, len(L_toplot))) \n",
    "colors[\"linear\"] = plt.cm.Reds(np.linspace(0.2, 0.9, len(L_toplot)))\n",
    "\n",
    "linestyle = {\"softmax\":\"-\",\n",
    "            \"linear\":\"-.\"}\n",
    "\n",
    "# Create the plot\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "for activation in activation_ls:\n",
    "    for idx, L in enumerate(L_toplot):\n",
    "        plt.plot(\n",
    "            steps_dyn[activation][L], loss_dyn[activation][L], \n",
    "            color=colors[activation][idx], linewidth=2, \n",
    "            linestyle=linestyle[activation],\n",
    "            label=f\"{activation}, L={L}\"\n",
    "        )\n",
    "    \n",
    "# Customize the plot\n",
    "ax.ticklabel_format(axis=\"x\", style=\"sci\", scilimits=(0, 0))\n",
    "ax.set_xlabel(r\"Training step $t$\", fontsize=20)\n",
    "ax.set_ylabel(r\"$\\mathcal{R}_L^{\\mathrm{ICL}}$\", fontsize=20)\n",
    "if covariance=='isotropic':\n",
    "    ax.set_xlim(0,1e5)\n",
    "else:\n",
    "    ax.set_xlim(0,2e5)\n",
    "ax.set_ylim(0)\n",
    "ax.tick_params(axis='both', labelsize=15)\n",
    "ax.xaxis.get_offset_text().set_fontsize(15)\n",
    "ax.legend(fontsize=18, loc='upper right')\n",
    "ax.grid(True, linestyle='-', linewidth=0.5, alpha=0.3)\n",
    "fig.tight_layout()\n",
    "\n",
    "# Save the plot as a PDF and display it\n",
    "fig.savefig(f\"figures/dynamic_test_loss_{covariance}.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e1aed55-14f7-4468-b79a-62ab662e5e62",
   "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
