{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setup\n",
    "\n",
    "Requirements: Install the jaxopt package."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: CUDA_VISIBLE_DEVICES=0\n"
     ]
    }
   ],
   "source": [
    "%env CUDA_VISIBLE_DEVICES=0\n",
    "\n",
    "import jax\n",
    "from jax import numpy as jnp\n",
    "from jax import nn\n",
    "import numpy as np\n",
    "from flax import linen as nn\n",
    "from flax.linen import initializers as nni\n",
    "from flax.traverse_util import flatten_dict, unflatten_dict\n",
    "from jax import random as jr\n",
    "from util import *\n",
    "import optax\n",
    "import pickle\n",
    "import argparse\n",
    "from matplotlib import cm\n",
    "\n",
    "from model import Transformer\n",
    "from tasks import Task, ModPSeq2SeqTask"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## SimpleTask"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# L = Lipschitz constant\n",
    "# seed = random seed\n",
    "# The following function trains single layer transformers on SimpleTask. Models are trained with max training length selected from train_lengths, \n",
    "#   and tested on sequences of lengths in test_lengths.\n",
    "def run(L, seed):\n",
    "    \n",
    "    rng = RNG(seed)\n",
    "    vocab_size = 3\n",
    "    problem = Task(vocab_size, 0, 1)\n",
    "    \n",
    "    max_length = 80\n",
    "\n",
    "    d_model = 16\n",
    "    heads = 1\n",
    "    width = 256\n",
    "    \n",
    "    # initialize model\n",
    "    model = Transformer(vocab_size, max_length, 1, d_model, heads, width, 0, False)\n",
    "    p0 = model.init(rng.next(), vmap(lambda key: problem.sample(max_length, key, 1))(rng.next(2))[0])\n",
    "    p0 = flatten_dict(p0[\"params\"], sep=\".\")\n",
    "\n",
    "    criterion = lambda f, y: (y - f)**2\n",
    "\n",
    "    @partial(jit, static_argnames=\"mutable\")\n",
    "    def f(p, *args, **kwargs):\n",
    "        p = dict(params=unflatten_dict(p, sep=\".\"))\n",
    "        return model.apply(p, *args, **kwargs)\n",
    "        \n",
    "    @jit\n",
    "    def loss_fn(p, batch):\n",
    "        x, y = batch\n",
    "        # only compute prediction on second token onwards\n",
    "        return vmap(criterion)(f(p, x)[:,1:], y).mean()\n",
    "\n",
    "    @jit\n",
    "    def test_loss_fn(p, batch):\n",
    "        x, y = batch\n",
    "        # only compute prediction on last token\n",
    "        return vmap(criterion)(f(p, x)[:,-1], y[:,-1]).mean()\n",
    "\n",
    "    models = []\n",
    "\n",
    "    # maximum training lengths\n",
    "    train_lengths = [i for i in jnp.arange(4, 21)]\n",
    "    \n",
    "    train_losses = []\n",
    "\n",
    "    # loop over train_lengths\n",
    "    for train_length in train_lengths:\n",
    "\n",
    "        p = p0\n",
    "        lr = 3e-3\n",
    "        steps = 2**13\n",
    "        save_every = steps // 128\n",
    "        batch_size = 2**10\n",
    "        max_size = 2**20 # 2**24\n",
    "        epoch_len = max_size // batch_size\n",
    "        sample_fn = lambda k: vmap(lambda key: problem.sample(train_length, key, L))(jr.split(k, epoch_len * batch_size))\n",
    "\n",
    "        def batch_iterator(key):\n",
    "            while True:\n",
    "                key, subkey = jr.split(key)\n",
    "                batches = sample_fn(subkey)\n",
    "                for i in range(epoch_len):\n",
    "                    yield tree_map(lambda x: x[batch_size * i : batch_size * (i + 1)], batches)\n",
    "                    \n",
    "        iterator = batch_iterator(rng.next())\n",
    "                    \n",
    "        # muP scaling for Adam\n",
    "        opt = optax.multi_transform(\n",
    "        {\n",
    "            'embed': optax.adam(learning_rate = lr),\n",
    "            'hidden': optax.adam(learning_rate = lr/d_model)\n",
    "        },\n",
    "        {\n",
    "            'wte':'embed',\n",
    "            'unembed':'embed',\n",
    "            'Q':'hidden',\n",
    "            'K':'hidden',\n",
    "            'V':'hidden',\n",
    "            'O':'hidden',\n",
    "            'layer1.kernel': 'hidden',\n",
    "            'layer1.bias': 'hidden',\n",
    "            'layer2.kernel': 'hidden'\n",
    "        })\n",
    "\n",
    "        @jit\n",
    "        def step_fn(p, batch, opt_state):\n",
    "            loss, g = jax.value_and_grad(loss_fn)(p, batch)\n",
    "            updates, opt_state = opt.update(g, opt_state, p)\n",
    "            p = optax.apply_updates(p, updates)\n",
    "            return p, opt_state, loss\n",
    "\n",
    "\n",
    "        train_loss = []\n",
    "        test_loss = []\n",
    "\n",
    "        opt_state = opt.init(p0)\n",
    "        for i in trange(steps):\n",
    "            batch = next(iterator)\n",
    "            loss = loss_fn(p, batch)\n",
    "            if loss < 1e-5 or jnp.isinf(loss):\n",
    "                break\n",
    "            p, opt_state, loss = step_fn(p, batch, opt_state)\n",
    "            train_loss.append(loss)\n",
    "        \n",
    "        print(\"final loss = \", loss)\n",
    "        train_losses.append(loss)\n",
    "        models.append(p)\n",
    "        \n",
    "    # evaluate models on test_lengths\n",
    "    \n",
    "    test_samples = 2**10\n",
    "    test_rng = rng.next()\n",
    "    test_lengths = [i for i in jnp.arange(4, 81, 4)]\n",
    "    all_losses = []\n",
    "    for test_length in test_lengths:\n",
    "        test_losses = []\n",
    "        testx, testy = vmap(lambda key: problem.sample(test_length, key, L))(jr.split(test_rng, test_samples))\n",
    "        for p in models:\n",
    "            test_loss = test_loss_fn(p, (testx, testy))\n",
    "            test_losses.append(test_loss)\n",
    "        all_losses.append(test_losses)\n",
    "        \n",
    "    all_losses = np.array(all_losses)\n",
    "        \n",
    "    return all_losses, models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# number of random seeds to consider. each trial takes ~30 minutes\n",
    "num_trials = 5\n",
    "seeds = [i for i in jnp.arange(0, num_trials)]\n",
    "\n",
    "# Lipschitz constants to consider\n",
    "Ls = [i for i in jnp.arange(2, 6, 0.5)]\n",
    "\n",
    "\n",
    "# loop over all Lipschitz constants L and seeds\n",
    "all_results = []\n",
    "for L in Ls:\n",
    "    results = []\n",
    "    for seed in seeds:\n",
    "        res, _ = run(L, seed)\n",
    "        results.append(res)\n",
    "    results = np.array(results)\n",
    "    results = np.mean(results, axis=0)\n",
    "    all_results.append(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Generic family 'serif' not found because none of the following families were found: Times, Palatino, New Century Schoolbook, Bookman, Computer Modern Roman\n",
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Generic family 'serif' not found because none of the following families were found: Times, Palatino, New Century Schoolbook, Bookman, Computer Modern Roman\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot test loss as a function of test length, for varying train lengths.\n",
    "results = all_results[1]\n",
    "train_lengths = np.arange(4, 21)\n",
    "test_lengths = np.arange(4, 81, 4)\n",
    "\n",
    "gradient = np.linspace(0, 1, results.shape[1])\n",
    "colors = cm.viridis(gradient)\n",
    "\n",
    "plt.style.use('style.mplstyle')\n",
    "for i in np.arange(0, results.shape[1], 2):\n",
    "    plt.plot(test_lengths, [result[i] for result in results], label = train_lengths[i], color = colors[i])\n",
    "plt.xlabel(\"Test length\")\n",
    "plt.ylabel(\"Test loss\")\n",
    "plt.yscale(\"log\")\n",
    "plt.legend(bbox_to_anchor=(1.22, 1.02), loc=\"upper right\", fontsize = 12)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot limiting test loss as a function of train length.\n",
    "plt.plot(train_lengths, results[-1], marker = 'o', color = colors[0])\n",
    "plt.ylabel(\"Test loss\")\n",
    "plt.xlabel(\"Train length\")\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot minimum train length needed to obtain loss <= epsilon\n",
    "epsilon = 1e-2\n",
    "Ns = []\n",
    "for i in range(len(Ls)):\n",
    "    Ns.append(train_lengths[jnp.argmax(all_results[i][-1, :] < epsilon)])\n",
    "plt.plot(Ls, Ns, color = colors[0], marker = 'o')\n",
    "plt.xlabel(r'$\\omega$')\n",
    "plt.ylabel(\"N\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Mod P Task"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# delta = periodicity parameter in ModPTask\n",
    "def run(delta, seed):\n",
    "    rng = RNG(seed)\n",
    "    \n",
    "    problem = ModPSeq2SeqTask(delta, 1) # attend to position == 1 mod k.\n",
    "    vocab_size = 2\n",
    "\n",
    "    max_length = 40*delta\n",
    "\n",
    "    d_model = 16\n",
    "    heads = 1\n",
    "    width = 256\n",
    "\n",
    "    # init model\n",
    "    model = Transformer(vocab_size, max_length, 1, d_model, heads, width, delta, True)\n",
    "    p0 = model.init(rng.next(), vmap(lambda key: problem.sample(max_length, key))(rng.next(2))[0])\n",
    "    p0 = flatten_dict(p0[\"params\"], sep=\".\")\n",
    "\n",
    "    criterion = lambda f, y: (y - f)**2\n",
    "\n",
    "    @partial(jit, static_argnames=\"mutable\")\n",
    "    def f(p, *args, **kwargs):\n",
    "        p = dict(params=unflatten_dict(p, sep=\".\"))\n",
    "        return model.apply(p, *args, **kwargs)\n",
    "        \n",
    "    @jit\n",
    "    def loss_fn(p, batch):\n",
    "        x, y = batch\n",
    "        # only compute prediction on delta onwards\n",
    "        return vmap(criterion)(f(p, x)[:,delta-1:], y).mean()\n",
    "\n",
    "    @jit\n",
    "    def test_loss_fn(p, batch):\n",
    "        x, y = batch\n",
    "        # only compute prediction on last token\n",
    "        return vmap(criterion)(f(p, x)[:,-1], y[:,-1]).mean()\n",
    "\n",
    "    models = []\n",
    "\n",
    "    train_lengths = [i for i in jnp.arange(delta, 5*delta+1, delta)]\n",
    "    \n",
    "    train_losses = []\n",
    "\n",
    "    for train_length in train_lengths:\n",
    "\n",
    "        p = p0\n",
    "        lr = 3e-3\n",
    "        steps = 2**13\n",
    "        save_every = steps // 128\n",
    "        batch_size = 2**10\n",
    "        max_size = 2**20 # 2**24\n",
    "        epoch_len = max_size // batch_size\n",
    "        sample_fn = lambda k: vmap(lambda key: problem.sample(train_length, key))(jr.split(k, epoch_len * batch_size))\n",
    "\n",
    "        def batch_iterator(key):\n",
    "            while True:\n",
    "                key, subkey = jr.split(key)\n",
    "                batches = sample_fn(subkey)\n",
    "                for i in range(epoch_len):\n",
    "                    yield tree_map(lambda x: x[batch_size * i : batch_size * (i + 1)], batches)\n",
    "                    \n",
    "        iterator = batch_iterator(rng.next())\n",
    "                    \n",
    "        # muP scaling\n",
    "        opt = optax.multi_transform(\n",
    "        {\n",
    "            'embed': optax.adam(learning_rate = lr),\n",
    "            'hidden': optax.adam(learning_rate = lr/d_model)\n",
    "        },\n",
    "        {\n",
    "            'wte':'embed',\n",
    "            'PeriodicPositionalEncoding_0.wpe': 'embed',\n",
    "            'unembed':'embed',\n",
    "            'Q':'hidden',\n",
    "            'K':'hidden',\n",
    "            'V':'hidden',\n",
    "            'O':'hidden',\n",
    "            'layer1.kernel': 'hidden',\n",
    "            'layer1.bias': 'hidden',\n",
    "            'layer2.kernel': 'hidden'\n",
    "        })\n",
    "\n",
    "        @jit\n",
    "        def step_fn(p, batch, opt_state):\n",
    "            loss, g = jax.value_and_grad(loss_fn)(p, batch)\n",
    "            updates, opt_state = opt.update(g, opt_state, p)\n",
    "            p = optax.apply_updates(p, updates)\n",
    "            return p, opt_state, loss\n",
    "\n",
    "\n",
    "        train_loss = []\n",
    "        test_loss = []\n",
    "\n",
    "        opt_state = opt.init(p0)\n",
    "        for i in trange(steps):\n",
    "            batch = next(iterator)\n",
    "            loss = loss_fn(p, batch)\n",
    "            if loss < 1e-5 or jnp.isinf(loss):\n",
    "                break\n",
    "            p, opt_state, loss = step_fn(p, batch, opt_state)\n",
    "            train_loss.append(loss)\n",
    "        print(\"final loss = \", loss)\n",
    "        train_losses.append(loss)\n",
    "        models.append(p)\n",
    "        \n",
    "    # evaluate on test lengths\n",
    "    \n",
    "    test_samples = 2**10\n",
    "    test_rng = rng.next()\n",
    "\n",
    "    test_lengths = [i for i in jnp.arange(delta, 20*delta + 1, delta)]\n",
    "    all_losses = []\n",
    "    for test_length in test_lengths:\n",
    "        test_losses = []\n",
    "        testx, testy = vmap(lambda key: problem.sample(test_length, key))(jr.split(test_rng, test_samples))\n",
    "        for p in models:\n",
    "            test_loss = test_loss_fn(p, (testx, testy))\n",
    "            test_losses.append(test_loss)\n",
    "        all_losses.append(test_losses)\n",
    "        \n",
    "    all_losses = np.array(all_losses)\n",
    "        \n",
    "    return all_losses, models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# number of random seeds to consider. each trial takes ~10 minutes\n",
    "num_trials = 5\n",
    "seeds = [i for i in jnp.arange(num_trials)]\n",
    "\n",
    "# periodicity parameters delta\n",
    "deltas = [i for i in range(3, 9)]\n",
    "\n",
    "\n",
    "# loop over delta and seed\n",
    "all_results = []\n",
    "for delta in deltas:\n",
    "    results = []\n",
    "    for seed in seeds:\n",
    "        res, _ = run(delta, seed)\n",
    "        results.append(res)\n",
    "    results = np.array(results)\n",
    "    results = np.mean(results, axis=0)\n",
    "    all_results.append(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Generic family 'serif' not found because none of the following families were found: Times, Palatino, New Century Schoolbook, Bookman, Computer Modern Roman\n",
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Generic family 'serif' not found because none of the following families were found: Times, Palatino, New Century Schoolbook, Bookman, Computer Modern Roman\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot test loss as a function of test length, for varying train lengths.\n",
    "results = all_results[-1]\n",
    "train_lengths = np.arange(5, 26, 5)\n",
    "test_lengths = np.arange(5, 101, 5)\n",
    "\n",
    "gradient = np.linspace(0, 1, results.shape[1])\n",
    "colors = cm.viridis(gradient)\n",
    "\n",
    "plt.style.use('style.mplstyle')\n",
    "for i in np.arange(0, results.shape[1]):\n",
    "    plt.plot(test_lengths, [result[i] for result in results], label = train_lengths[i], color = colors[i])\n",
    "plt.xlabel(\"Test length\")\n",
    "plt.ylabel(\"Test loss\")\n",
    "plt.yscale(\"log\")\n",
    "plt.legend(bbox_to_anchor=(1.22, 1.02), loc=\"upper right\", fontsize = 12)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot limiting test loss as a function of train length\n",
    "plt.plot(train_lengths, results[-1], marker = 'o', color = colors[0])\n",
    "plt.ylabel(\"Test loss\")\n",
    "plt.xlabel(\"Train length\")\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot limiting test loss as delta varies.\n",
    "gradient = np.linspace(0, 1, len(all_results))\n",
    "colors = cm.viridis(gradient)\n",
    "\n",
    "for i in range(len(all_results)):\n",
    "    plt.plot(np.arange(1, 6), all_results[i][-1, :], color = colors[i], marker = 'o', label = r'$\\Delta = $' + str(deltas[i]))\n",
    "plt.yscale(\"log\")\n",
    "plt.xlabel(\"Train length/\" + r'$\\Delta$')\n",
    "plt.ylabel(\"Test loss\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot Attention Probabilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2, 80, 1, 16)\n",
      "(2, 80, 16)\n"
     ]
    }
   ],
   "source": [
    "# generate test samples\n",
    "rng = RNG(0)\n",
    "test_samples = 1024\n",
    "test_length = 80\n",
    "problem = ModPSeq2SeqTask(5, 1)\n",
    "testx, testy = vmap(lambda key: problem.sample(test_length, key))(jr.split(rng.next(), test_samples))\n",
    "\n",
    "# initialize empty model\n",
    "max_length = 80\n",
    "delta = 5\n",
    "model = Transformer(2, max_length, 1, 16, 1, 256, delta, True)\n",
    "p0 = model.init(rng.next(), vmap(lambda key: problem.sample(80, key))(rng.next(2))[0])\n",
    "p0 = flatten_dict(p0[\"params\"], sep=\".\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, models = run(delta, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# x = input sequence\n",
    "# p = model\n",
    "# output attention probabilities on the sequence x (length T sequence)\n",
    "def compute_attn_logits(x, p):  \n",
    "    T = testx.shape[-1]\n",
    "    x = model.embed(x, p['wte'])\n",
    "    repeat_count = (max_length + delta - 1) // delta\n",
    "    wpe_big = jnp.tile(p['PeriodicPositionalEncoding_0.wpe'], (repeat_count, 1))\n",
    "    x = x + wpe_big[:T]\n",
    "    \n",
    "    attn = jnp.einsum(\"...ij,jm,km,...lk -> ...il\", x, p['Q'][0], p['K'][0], x)\n",
    "        \n",
    "    attn = attn/model.d\n",
    "    attn = jnp.where(jnp.tri(T), attn, -jnp.inf)\n",
    "    attn = nn.softmax(attn)\n",
    "\n",
    "    return attn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mean and std of k mod p tokens\n",
    "yes_mean = []\n",
    "yes_std = []\n",
    "\n",
    "# mean and std of remaining tokens\n",
    "no_mean = []\n",
    "no_std = []\n",
    "\n",
    "# compute average attention for each model\n",
    "for p in models:\n",
    "    attn = compute_attn_logits(testx, p)\n",
    "    \n",
    "    last_attn = attn[:, -1, :]\n",
    "    last_attn = last_attn.reshape(-1)\n",
    "    last_attn = last_attn.reshape(-1, 5)\n",
    "    \n",
    "    yes_mean.append(last_attn.mean(axis=0)[1])\n",
    "    yes_std.append(last_attn.std(axis=0)[1])\n",
    "    \n",
    "    no_mean.append(last_attn[:, [0, 2, 3, 4]].mean())\n",
    "    no_std.append(last_attn[:, [0, 2, 3, 4]].std())\n",
    "yes_mean = np.array(yes_mean)\n",
    "yes_std = np.array(yes_std)\n",
    "no_mean = np.array(no_mean)\n",
    "no_std = np.array(no_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Generate plot\n",
    "gradient = np.linspace(0, 1, 2)\n",
    "colors = cm.viridis(gradient)\n",
    "\n",
    "\n",
    "plt.style.use('style.mplstyle')\n",
    "\n",
    "plt.plot(np.arange(5, 26, 5), yes_mean, label = r'$= k$' + 'mod p', color = colors[0])\n",
    "plt.fill_between(np.arange(5, 26, 5), yes_mean - yes_std, yes_mean+yes_std, color = colors[0], alpha = 0.5)\n",
    "\n",
    "plt.plot(np.arange(5, 26, 5), no_mean, label = r'$\\neq k$' + 'mod p', color = colors[1])\n",
    "plt.fill_between(np.arange(5, 26, 5), no_mean - no_std, no_mean+no_std, color = colors[1], alpha = 0.5)\n",
    "\n",
    "plt.plot([5, 25], [1./16, 1./16], linestyle = 'dashed', color = 'black')\n",
    "\n",
    "plt.xlabel(\"Train Length\")\n",
    "plt.ylabel(\"Attention probabilities\")\n",
    "\n",
    "plt.legend(loc=\"lower right\", bbox_to_anchor=(1.0, 0.1), fontsize = 12)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jax",
   "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
